KR102409033B1 - System for cloud streaming service, method of image cloud streaming service using alpha level of color bit and apparatus for the same - Google Patents

System for cloud streaming service, method of image cloud streaming service using alpha level of color bit and apparatus for the same Download PDF

Info

Publication number
KR102409033B1
KR102409033B1 KR1020150117789A KR20150117789A KR102409033B1 KR 102409033 B1 KR102409033 B1 KR 102409033B1 KR 1020150117789 A KR1020150117789 A KR 1020150117789A KR 20150117789 A KR20150117789 A KR 20150117789A KR 102409033 B1 KR102409033 B1 KR 102409033B1
Authority
KR
South Korea
Prior art keywords
image
level
cloud streaming
area
region
Prior art date
Application number
KR1020150117789A
Other languages
Korean (ko)
Other versions
KR20160131827A (en
Inventor
이동수
Original Assignee
에스케이플래닛 주식회사
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by 에스케이플래닛 주식회사 filed Critical 에스케이플래닛 주식회사
Publication of KR20160131827A publication Critical patent/KR20160131827A/en
Application granted granted Critical
Publication of KR102409033B1 publication Critical patent/KR102409033B1/en

Links

Images

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/20Servers specifically adapted for the distribution of content, e.g. VOD servers; Operations thereof
    • H04N21/23Processing of content or additional data; Elementary server operations; Server middleware
    • H04N21/236Assembling of a multiplex stream, e.g. transport stream, by combining a video stream with other content or additional data, e.g. inserting a URL [Uniform Resource Locator] into a video stream, multiplexing software data into a video stream; Remultiplexing of multiplex streams; Insertion of stuffing bits into the multiplex stream, e.g. to obtain a constant bit-rate; Assembling of a packetised elementary stream
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/20Servers specifically adapted for the distribution of content, e.g. VOD servers; Operations thereof
    • H04N21/21Server components or server architectures
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/20Servers specifically adapted for the distribution of content, e.g. VOD servers; Operations thereof
    • H04N21/23Processing of content or additional data; Elementary server operations; Server middleware
    • H04N21/234Processing of video elementary streams, e.g. splicing of video streams, manipulating MPEG-4 scene graphs
    • H04N21/2343Processing of video elementary streams, e.g. splicing of video streams, manipulating MPEG-4 scene graphs involving reformatting operations of video signals for distribution or compliance with end-user requests or end-user device requirements
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/20Servers specifically adapted for the distribution of content, e.g. VOD servers; Operations thereof
    • H04N21/23Processing of content or additional data; Elementary server operations; Server middleware
    • H04N21/236Assembling of a multiplex stream, e.g. transport stream, by combining a video stream with other content or additional data, e.g. inserting a URL [Uniform Resource Locator] into a video stream, multiplexing software data into a video stream; Remultiplexing of multiplex streams; Insertion of stuffing bits into the multiplex stream, e.g. to obtain a constant bit-rate; Assembling of a packetised elementary stream
    • H04N21/23614Multiplexing of additional data and video streams
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/20Servers specifically adapted for the distribution of content, e.g. VOD servers; Operations thereof
    • H04N21/23Processing of content or additional data; Elementary server operations; Server middleware
    • H04N21/238Interfacing the downstream path of the transmission network, e.g. adapting the transmission rate of a video stream to network bandwidth; Processing of multiplex streams
    • H04N21/2383Channel coding or modulation of digital bit-stream, e.g. QPSK modulation

Abstract

클라우드 스트리밍 서비스 시스템, 알파 레벨을 이용한 이미지 클라우드 스트리밍 서비스 방법 및 이를 위한 장치가 개시된다. 본 발명에 따른 클라우드 스트리밍 서버는 어플리케이션 실행화면을 렌더링하고, 알파 레벨을 기반으로 어플리케이션 실행화면에 상응하는 프레임 화면을 적어도 하나의 분할 영역으로 분할하고, 적어도 하나의 분할 영역에서 각각 사용자의 단말로 제공할 적어도 하나의 이미지를 캡처하고, 알파 레벨에 기반하여 스틸 이미지 인코딩 기법을 선택하고, 선택된 스틸 이미지 인코딩 기법으로 적어도 하나의 이미지를 스틸 이미지 인코딩하여 사용자의 단말로 전송할 수 있다. 이에 따라 이미지 기반의 클라우드 스트리밍 서비스 시 캡처된 이미지를 보다 자연스럽고 효율적으로 인코딩하는 것이 가능하다.A cloud streaming service system, an image cloud streaming service method using an alpha level, and an apparatus therefor are disclosed. The cloud streaming server according to the present invention renders the application execution screen, divides the frame screen corresponding to the application execution screen based on the alpha level into at least one divided area, and provides each of the user terminals in the at least one divided area At least one image to be used may be captured, a still image encoding technique may be selected based on the alpha level, and the at least one image may be still image-encoded using the selected still image encoding technique and transmitted to the user's terminal. Accordingly, it is possible to encode the captured image more naturally and efficiently in the case of an image-based cloud streaming service.

Description

클라우드 스트리밍 서비스 시스템, 알파 레벨을 이용한 이미지 클라우드 스트리밍 서비스 방법 및 이를 위한 장치{SYSTEM FOR CLOUD STREAMING SERVICE, METHOD OF IMAGE CLOUD STREAMING SERVICE USING ALPHA LEVEL OF COLOR BIT AND APPARATUS FOR THE SAME}Cloud streaming service system, image cloud streaming service method using alpha level, and apparatus therefor

본 발명은 이미지 기반의 클라우드 스트리밍 서비스 기술에 관한 것으로, 특히 어플리케이션 실행화면에서 알파 레벨에 따라 화면을 분리하여 서비스를 처리함으로써 효율적인 인코딩을 수행할 수 있는 클라우드 스트리밍 서비스 시스템, 알파 레벨을 이용한 이미지 클라우드 스트리밍 서비스 방법 및 이를 위한 장치에 관한 것이다.The present invention relates to an image-based cloud streaming service technology, and in particular, a cloud streaming service system that can perform efficient encoding by separating the screen according to the alpha level in the application execution screen and processing the service, and image cloud streaming using the alpha level It relates to a service method and an apparatus therefor.

인터넷의 급속한 발달은 개인의 통신 속도를 급격히 향상시키는 결과를 가져왔으며, 이러한 통신 속도의 향상은 원격지에 위치한 컴퓨터에 접속하여 대용량의 데이터를 다운로드 또는 업로드 하거나, 원격지 컴퓨터 제어 프로그램을 사용하여 마치 원격지 컴퓨터에 로컬 로그인한 것과 같이 원격지 컴퓨터를 이용할 수 있는 환경을 제공하고 있다.The rapid development of the Internet has resulted in a rapid increase in individual communication speed, and this communication speed improvement is like downloading or uploading large amounts of data by accessing a computer located at a remote location, or using a remote computer control program as if it were a remote computer. It provides an environment where you can use a remote computer as if you were logged in locally.

또한, 스마트폰과 같은 이동통신 단말에서 구동되는 어플리케이션이 다양하게 개발되면서, 비교적 낮은 성능의 사용자 단말에서 높은 성능을 필요로 하는 어플리케이션을 구동하기 위한 가상화 기술들이 많이 제안되고 있다. In addition, as applications driven in a mobile communication terminal such as a smart phone are developed in various ways, virtualization technologies for driving applications requiring high performance in a user terminal with relatively low performance have been widely proposed.

그 중에서 어플리케이션을 서버에서 구동시키고 구동화면은 비디오 인코딩(Encoding)을 통해 압축하여 클라이언트로 전송하고, 클라이언트는 전송된 비디오를 재생하여 마치 자신의 단말에서 어플리케이션이 구동되는 것과 같은 효과를 내는 화면 가상화 기반의 클라우드 스트리밍 서비스가 각광받고 있는 추세이다.Among them, a screen virtualization-based system that runs the application on the server, compresses the driving screen through video encoding, and transmits it to the client, and the client plays the transmitted video to have the same effect as if the application is running on its own terminal of cloud streaming services are in the spotlight.

클라우드 스트리밍 서비스는 기본적으로 비디오 코덱 기반의 클라우드 스트리밍 기법이 적용되었다. 그러나 메뉴 디스플레이와 같이 정적인 화면을 서비스 하는 경우에도 불필요하게 화면 전체를 캡처하고 비디오 코덱을 이용하여 동작하게 되어 시스템 전체적으로 비효율적인 측면이 존재하였다.The cloud streaming service basically applied the video codec-based cloud streaming technique. However, even when a static screen such as a menu display is provided, the entire screen is unnecessarily captured and the video codec is used to operate, which is inefficient as a whole system.

따라서, 사용자 요청에 따라 실행된 어플리케이션의 실행화면에서 정적인 부분의 변화된 이미지만을 캡처하여 사용자의 단말로 제공하되, 이미지를 캡처할 때 알파 레벨에 따라 분할된 영역에서 각각 이미지를 캡처하여 인코딩함으로써 알파 레벨 별로 효율적인 스틸 이미지 인코딩을 수행할 수 있는 이미지 기반의 클라우드 스트리밍 서비스 기술이 절실하게 대두된다.Therefore, only the changed image of the static part on the execution screen of the application executed according to the user's request is captured and provided to the user's terminal. An image-based cloud streaming service technology that can perform efficient still image encoding for each level is urgently needed.

한국 공개 특허 제2015-0065069호, 2015년 6월 12일 공개 (명칭: 디스플레이 장치, 디스플레이 장치의 영상 표시 방법 및 컴퓨터 판독가능 기록매체)Korean Patent Laid-Open Patent No. 2015-0065069, published on June 12, 2015 (Title: Display device, image display method of display device, and computer-readable recording medium)

본 발명의 목적은, 이미지 기반의 클라우드 스트리밍 서비스 시 알파 레벨 별로 캡처된 이미지를 적합한 스틸 이미지 인코딩 기법으로 자연스럽고 효율적이게 처리하는 것이다.It is an object of the present invention to naturally and efficiently process images captured for each alpha level in an image-based cloud streaming service using a suitable still image encoding technique.

또한, 본 발명의 목적은 캡처 단계에서 인코딩 방식에 따라 이미지가 분할됨으로써 인코딩 시 해당 이미지의 속성을 파악하기 위해 컬러 수를 카운트 하는 등의 부가처리를 생략하도록 하는 것이다.Another object of the present invention is to omit additional processing such as counting the number of colors in order to understand the properties of the image during encoding by dividing the image according to the encoding method in the capture step.

또한, 본 발명의 목적은 사용자 단말에서 프레임의 변화된 이미지만을 렌더링하여 디스플레이 하도록 함으로써 사용자 단말의 성능이 낮더라도 클라우드 스트리밍 서비스를 원활하게 제공하는 것이다.In addition, it is an object of the present invention to provide a cloud streaming service smoothly even if the performance of the user terminal is low by rendering and displaying only the changed image of the frame in the user terminal.

상기한 목적을 달성하기 위한 본 발명에 따른 클라우드 스트리밍 서버는 어플리케이션 실행화면을 렌더링하고, 알파 레벨을 기반으로 어플리케이션 실행화면에 상응하는 프레임 화면을 적어도 하나의 분할 영역으로 분할하는 프레임 분할부; 상기 적어도 하나의 분할 영역에서 각각 사용자의 단말로 제공할 적어도 하나의 이미지를 캡처하는 캡처부; 상기 알파 레벨에 기반하여 스틸 이미지 인코딩 기법을 선택하고, 선택된 스틸 이미지 인코딩 기법을 이용하여 상기 적어도 하나의 이미지를 스틸 이미지 인코딩하는 인코딩부; 및 스틸 이미지 인코딩된 상기 적어도 하나의 이미지를 사용자의 단말로 전송하는 스트리밍부를 포함한다.A cloud streaming server according to the present invention for achieving the above object is a frame dividing unit for rendering an application execution screen, and dividing the frame screen corresponding to the application execution screen into at least one divided area based on the alpha level; a capture unit configured to capture at least one image to be provided to a user's terminal in each of the at least one divided area; an encoding unit that selects a still image encoding method based on the alpha level and encodes the at least one image as a still image by using the selected still image encoding method; and a streaming unit for transmitting the still image-encoded at least one image to a user's terminal.

이 때, 적어도 하나의 분할 영역은 상기 알파 레벨이 제1 레벨에 상응하는 제1 영역, 상기 알파 레벨이 제2 레벨에 상응하는 제2 영역 및 상기 알파 레벨이 제3 레벨에 상응하는 제3 영역 중 적어도 하나에 상응할 수 있다.In this case, the at least one divided region includes a first region having the alpha level corresponding to a first level, a second region having the alpha level corresponding to a second level, and a third region having the alpha level corresponding to a third level. may correspond to at least one of

이 때, 알파 레벨은 알파 값이 255에 상응하는 상기 제1 레벨, 상기 알파 값이 128을 기준으로 기설정된 범위 내에 포함되는 상기 제2 레벨 및 상기 알파 값이 0에 상응하는 제3 레벨 중 적어도 하나에 상응할 수 있다.In this case, the alpha level is at least one of the first level having an alpha value of 255, the second level including the alpha value within a preset range based on 128, and a third level having the alpha value corresponding to 0 can correspond to one.

이 때, 상기 제1 영역은 상기 프레임 화면 중 불투명 영역에 상응하고, 상기 제2 영역은 상기 프레임 화면 중 반투명 영역에 상응하고, 상기 제3 영역은 상기 프레임 화면 중 투명 영역에 상응할 수 있다.In this case, the first area may correspond to an opaque area of the frame screen, the second area may correspond to a translucent area of the frame screen, and the third area may correspond to a transparent area of the frame screen.

이 때, 인코딩부는 상기 적어도 하나의 이미지가 상기 제1 영역에서 캡처된 경우에 JPEG 스틸 이미지 인코딩 기법으로 스틸 이미지 인코딩을 수행하고, 상기 적어도 하나의 이미지가 상기 제2 영역에서 캡처된 경우에 PNG 스틸 이미지 인코딩 기법으로 스틸 이미지 인코딩을 수행할 수 있다.In this case, the encoding unit performs still image encoding using a JPEG still image encoding technique when the at least one image is captured in the first area, and a PNG still image when the at least one image is captured in the second area. Still image encoding may be performed using an image encoding technique.

이 때, 인코딩부는 상기 적어도 하나의 이미지가 상기 제3 영역에서 캡처된 경우에 스틸 이미지 인코딩을 수행하지 않을 수 있다.In this case, the encoding unit may not perform still image encoding when the at least one image is captured in the third area.

이 때, 캡처부는 상기 프레임 화면의 이전 프레임 화면과 상기 적어도 하나의 분할 영역을 비교하여 상기 적어도 하나의 분할 영역 별로 변화된 부분을 상기 적어도 하나의 이미지로 캡처할 수 있다.In this case, the capture unit may compare the previous frame screen of the frame screen with the at least one divided area, and capture the changed part for each of the at least one divided area as the at least one image.

또한, 본 발명에 따른 알파 레벨을 이용한 이미지 클라우드 스트리밍 서비스 방법은 어플리케이션 실행화면을 렌더링하고, 알파 레벨을 기반으로 어플리케이션 실행화면에 상응하는 프레임 화면을 적어도 하나의 분할 영역으로 분할하는 단계; 상기 적어도 하나의 분할 영역에서 각각 사용자의 단말로 제공할 적어도 하나의 이미지를 캡처하는 단계; 상기 알파 레벨에 기반하여 스틸 이미지 인코딩 기법을 선택하고, 선택된 스틸 이미지 인코딩 기법을 이용하여 상기 적어도 하나의 이미지를 스틸 이미지 인코딩하는 단계; 및 스틸 이미지 인코딩된 상기 적어도 하나의 이미지를 사용자의 단말로 전송하는 단계를 포함한다.In addition, the image cloud streaming service method using an alpha level according to the present invention comprises the steps of rendering an application execution screen, and dividing a frame screen corresponding to the application execution screen into at least one divided area based on the alpha level; capturing at least one image to be provided to each user's terminal in the at least one divided area; selecting a still image encoding scheme based on the alpha level, and still image encoding the at least one image using the selected still image encoding scheme; and transmitting the still image-encoded at least one image to a terminal of a user.

이 때, 적어도 하나의 분할 영역은 상기 알파 레벨이 제1 레벨에 상응하는 제1 영역, 상기 알파 레벨이 제2 레벨에 상응하는 제2 영역 및 상기 알파 레벨이 제3 레벨에 상응하는 제3 영역 중 적어도 하나에 상응할 수 있다.In this case, the at least one divided region includes a first region having the alpha level corresponding to a first level, a second region having the alpha level corresponding to a second level, and a third region having the alpha level corresponding to a third level. may correspond to at least one of

이 때, 알파 레벨은 알파 값이 255에 상응하는 상기 제1 레벨, 상기 알파 값이 128을 기준으로 기설정된 범위 내에 포함되는 상기 제2 레벨 및 상기 알파 값이 0에 상응하는 제3 레벨 중 적어도 하나에 상응할 수 있다.In this case, the alpha level is at least one of the first level having an alpha value of 255, the second level including the alpha value within a preset range based on 128, and a third level having the alpha value corresponding to 0 can correspond to one.

이 때, 상기 제1 영역은 상기 프레임 화면 중 불투명 영역에 상응하고, 상기 제2 영역은 상기 프레임 화면 중 반투명 영역에 상응하고, 상기 제3 영역은 상기 프레임 화면 중 투명 영역에 상응할 수 있다.In this case, the first area may correspond to an opaque area of the frame screen, the second area may correspond to a translucent area of the frame screen, and the third area may correspond to a transparent area of the frame screen.

이 때, 스틸 이미지 인코딩하는 단계는 상기 적어도 하나의 이미지가 상기 제1 영역에서 캡처된 경우에 JPEG 스틸 이미지 인코딩 기법으로 스틸 이미지 인코딩을 수행하고, 상기 적어도 하나의 이미지가 상기 제2 영역에서 캡처된 경우에 PNG 스틸 이미지 인코딩 기법으로 스틸 이미지 인코딩을 수행할 수 있다.In this case, the step of encoding the still image may include performing still image encoding using a JPEG still image encoding technique when the at least one image is captured in the first area, and capturing the at least one image in the second area. In this case, still image encoding may be performed using the PNG still image encoding technique.

이 때, 스틸 이미지 인코딩하는 단계는 상기 적어도 하나의 이미지가 상기 제3 영역에서 캡처된 경우에 스틸 이미지 인코딩을 수행하지 않을 수 있다.In this case, the encoding of the still image may not perform encoding of the still image when the at least one image is captured in the third area.

이 때, 캡처하는 단계는 상기 프레임 화면의 이전 프레임 화면과 상기 적어도 하나의 분할 영역을 비교하여 상기 적어도 하나의 분할 영역 별로 변화된 부분을 상기 적어도 하나의 이미지로 캡처할 수 있다.In this case, the capturing may include comparing a previous frame screen of the frame screen with the at least one divided area, and capturing a changed portion for each of the at least one divided area as the at least one image.

또한, 본 발명의 과제 해결을 위한 또 다른 수단으로써, 상술한 방법을 실행시키기 위하여 매체에 저장된 컴퓨터 프로그램을 제공한다.In addition, as another means for solving the problems of the present invention, there is provided a computer program stored in a medium for executing the above-described method.

또한, 본 발명에 따른 클라우드 스트리밍 서비스 시스템은 어플리케이션 실행화면을 렌더링하고, 알파 레벨을 기반으로 어플리케이션 실행화면에 상응하는 프레임 화면을 적어도 하나의 분할 영역으로 분할하고, 상기 적어도 하나의 분할 영역에서 각각 사용자의 단말로 제공할 적어도 하나의 이미지를 캡처하고, 상기 알파 레벨에 기반하여 선택된 스틸 이미지 인코딩 기법으로 상기 적어도 하나의 이미지를 스틸 이미지 인코딩하여 상기 단말로 전송하는 클라우드 스트리밍 서버; 및 상기 클라우드 스트리밍 서버로부터 스틸 이미지 인코딩된 상기 적어도 하나의 이미지를 수신하여 렌더링하고, 렌더링된 상기 적어도 하나의 이미지를 상기 사용자에게 디스플레이 하는 단말을 포함한다.In addition, the cloud streaming service system according to the present invention renders an application execution screen, divides a frame screen corresponding to the application execution screen based on the alpha level into at least one divided area, and each user in the at least one divided area a cloud streaming server that captures at least one image to be provided to a terminal of , encodes the at least one image using a still image encoding technique selected based on the alpha level, and transmits the still image to the terminal; and a terminal that receives and renders the at least one still image-encoded image from the cloud streaming server, and displays the rendered at least one image to the user.

본 발명에 따르면, 이미지 기반의 클라우드 스트리밍 서비스 시 알파 레벨 별로 캡처된 이미지를 적합한 스틸 이미지 인코딩 기법으로 자연스럽고 효율적이게 처리할 수 있다.According to the present invention, in the case of an image-based cloud streaming service, images captured for each alpha level can be naturally and efficiently processed using a suitable still image encoding technique.

또한, 본 발명은 캡처 단계에서 인코딩 방식에 따라 이미지가 분할됨으로써 인코딩 시 해당 이미지의 속성을 파악하기 위해 컬러 수를 카운트 하는 등의 부가처리를 생략하도록 할 수 있다.In addition, in the present invention, since the image is divided according to the encoding method in the capture step, additional processing such as counting the number of colors in order to grasp the properties of the image during encoding may be omitted.

또한, 본 발명은 사용자 단말에서 프레임의 변화된 이미지만을 렌더링하여 디스플레이 하도록 함으로써 사용자 단말의 성능이 낮더라도 클라우드 스트리밍 서비스를 원활하게 제공할 수 있다.In addition, the present invention allows the user terminal to render and display only the changed image of the frame, so that the cloud streaming service can be smoothly provided even if the performance of the user terminal is low.

도 1은 본 발명의 일실시예에 따른 클라우드 스트리밍 서비스 시스템을 나타낸 블록도이다.
도 2는 도 1에 도시된 클라우드 스트리밍 서버의 일 예를 나타낸 블록도이다.
도 3은 본 발명의 일실시예에 따른 알파 레벨 별 프레임 화면을 나타낸 도면이다.
도 4는 본 발명의 일실시예에 따른 어플리케이션 실행화면의 프레임 화면을 나타낸 도면이다.
도 5는 도 4에 도시된 프레임 화면을 알파 레벨로 나타낸 도면이다.
도 6은 본 발명의 일실시예에 따라 알파 레벨에 따른 영역별로 이미지를 캡처하는 과정을 나타낸 도면이다.
도 7은 본 발명의 일실시예에 따른 알파 레벨을 이용한 이미지 클라우드 스트리밍 서비스 방법을 나타낸 동작 흐름도이다.
도 8은 본 발명의 일실시예에 따른 알파 레벨을 이용한 이미지 클라우드 스트리밍 서비스 방법에서 프레임 화면을 분할하는 방법을 상세하게 나타낸 동작 흐름도이다.
도 9는 본 발명의 일실시예에 따른 알파 레벨을 이용한 이미지 클라우드 스트리밍 서비스 방법에서 스틸 이미지 인코딩을 수행하는 방법을 상세하게 나타낸 동작 흐름도이다.
도 10은 본 발명의 다른 실시예에 따른 알파 레벨을 이용한 이미지 클라우드 스트리밍 서비스 방법에서 스틸 이미지 인코딩을 수행하는 방법을 상세하게 나타낸 동작 흐름도이다.
1 is a block diagram illustrating a cloud streaming service system according to an embodiment of the present invention.
2 is a block diagram showing an example of the cloud streaming server shown in FIG.
3 is a diagram illustrating a frame screen for each alpha level according to an embodiment of the present invention.
4 is a diagram illustrating a frame screen of an application execution screen according to an embodiment of the present invention.
FIG. 5 is a diagram illustrating the frame screen shown in FIG. 4 at an alpha level.
6 is a diagram illustrating a process of capturing an image for each region according to an alpha level according to an embodiment of the present invention.
7 is an operation flowchart illustrating an image cloud streaming service method using an alpha level according to an embodiment of the present invention.
8 is a detailed operation flowchart illustrating a method of dividing a frame screen in an image cloud streaming service method using an alpha level according to an embodiment of the present invention.
9 is a detailed operation flowchart illustrating a method of performing still image encoding in an image cloud streaming service method using an alpha level according to an embodiment of the present invention.
10 is a detailed operation flowchart illustrating a method of performing still image encoding in an image cloud streaming service method using an alpha level according to another embodiment of the present invention.

이하 본 발명의 바람직한 실시예를 첨부한 도면을 참조하여 상세히 설명한다. 다만, 하기의 설명 및 첨부된 도면에서 본 발명의 요지를 흐릴 수 있는 공지 기능 또는 구성에 대한 상세한 설명은 생략한다. 또한, 도면 전체에 걸쳐 동일한 구성 요소들은 가능한 한 동일한 도면 부호로 나타내고 있음에 유의하여야 한다. 본 발명의 실시형태는 당 업계에서 평균적인 지식을 가진 자에게 본 발명을 보다 완전하게 설명하기 위해서 제공되는 것이다. 따라서, 도면에서의 요소들의 형상 및 크기 등은 보다 명확한 설명을 위해 과장될 수 있다.Hereinafter, preferred embodiments of the present invention will be described in detail with reference to the accompanying drawings. However, detailed descriptions of well-known functions or configurations that may obscure the gist of the present invention in the following description and accompanying drawings will be omitted. Also, it should be noted that, throughout the drawings, the same components are denoted by the same reference numerals as much as possible. The embodiments of the present invention are provided in order to more completely explain the present invention to those of ordinary skill in the art. Accordingly, the shapes and sizes of elements in the drawings may be exaggerated for clearer description.

이하에서 설명되는 본 명세서 및 청구범위에 사용된 용어나 단어는 통상적이거나 사전적인 의미로 한정해서 해석되어서는 아니 되며, 발명자는 그 자신의 발명을 가장 최선의 방법으로 설명하기 위한 용어의 개념으로 적절하게 정의할 수 있다는 원칙에 입각하여 본 발명의 기술적 사상에 부합하는 의미와 개념으로 해석되어야만 한다. 따라서 본 명세서에 기재된 실시예와 도면에 도시된 구성은 본 발명의 가장 바람직한 일 실시예에 불과할 뿐이고, 본 발명의 기술적 사상을 모두 대변하는 것은 아니므로, 본 출원시점에 있어서 이들을 대체할 수 있는 다양한 균등물과 변형 예들이 있을 수 있음을 이해하여야 한다. 또한 제 1, 제 2 등의 용어는 다양한 구성요소들을 설명하기 위해 사용하는 것으로, 하나의 구성요소를 다른 구성요소로부터 구별하는 목적으로만 사용될 뿐, 상기 구성요소들을 한정하기 위해 사용되지 않는다.The terms or words used in the present specification and claims described below should not be construed as being limited to their ordinary or dictionary meanings, and the inventor is appropriate as a concept of terms for describing his invention in the best way. It should be interpreted as meaning and concept consistent with the technical idea of the present invention based on the principle that it can be defined in Therefore, the embodiments described in this specification and the configurations shown in the drawings are only the most preferred embodiment of the present invention, and do not represent all the technical spirit of the present invention, so at the time of the present application, various It should be understood that there may be equivalents and variations. In addition, terms such as 1st, 2nd, etc. are used to describe various components, and are used only for the purpose of distinguishing one component from other components, and are not used to limit the components.

도 1은 본 발명의 일실시예에 따른 클라우드 스트리밍 서비스 시스템을 나타낸 블록도이다.1 is a block diagram illustrating a cloud streaming service system according to an embodiment of the present invention.

도 1을 참조하면, 본 발명의 일실시예에 따른 클라우드 스트리밍 서비스 시스템은 클라우드 스트리밍 서버(110), 단말(120-1~ 120-N) 및 네트워크(130)를 포함한다.Referring to FIG. 1 , the cloud streaming service system according to an embodiment of the present invention includes a cloud streaming server 110 , terminals 120-1 to 120-N, and a network 130 .

클라우드 스트리밍 서버(110)는 어플리케이션 실행화면을 렌더링하고, 알파 레벨을 기반으로 어플리케이션 실행화면에 상응하는 프레임 화면을 적어도 하나의 분할 영역으로 분할한다.The cloud streaming server 110 renders the application execution screen, and divides the frame screen corresponding to the application execution screen into at least one divided area based on the alpha level.

이 때, 적어도 하나의 분할 영역은 알파 레벨이 제1 레벨에 상응하는 제1 영역, 알파 레벨이 제2 레벨에 상응하는 제2 영역 및 알파 레벨이 제3 레벨에 상응하는 제3 영역 중 적어도 하나에 상응할 수 있다.In this case, the at least one divided region is at least one of a first region having an alpha level corresponding to a first level, a second region having an alpha level corresponding to a second level, and a third region having an alpha level corresponding to a third level. can correspond to

이 때, 알파 레벨은 알파 값이 255에 상응하는 제1 레벨, 알파 값이 128을 기준으로 기설정된 범위 내에 포함되는 제2 레벨 및 알파 값이 0에 상응하는 제3 레벨 중 적어도 하나에 상응할 수 있다.In this case, the alpha level may correspond to at least one of a first level having an alpha value of 255, a second level having an alpha value within a preset range based on 128, and a third level having an alpha value of 0. can

이 때, 제1 영역은 프레임 화면 중 불투명 영역에 상응하고, 제2 영역은 프레임 화면 중 반투명 영역에 상응하고, 제3 영역은 프레임 화면 중 투명 영역에 상응할 수 있다.In this case, the first area may correspond to an opaque area of the frame screen, the second area may correspond to a translucent area of the frame screen, and the third area may correspond to a transparent area of the frame screen.

또한, 클라우드 스트리밍 서버(110)는 적어도 하나의 분할 영역에서 각각 사용자의 단말(120-1~ 120-N)로 제공할 적어도 하나의 이미지를 캡처한다.In addition, the cloud streaming server 110 captures at least one image to be provided to each user's terminals 120-1 to 120-N in at least one divided area.

이 때, 프레임 화면의 이전 프레임 화면과 적어도 하나의 분할 영역을 비교하여 적어도 하나의 분할 영역 별로 변화된 부분을 적어도 하나의 이미지로 캡처할 수 있다.In this case, by comparing the previous frame screen of the frame screen with at least one divided area, the changed portion for each at least one divided area may be captured as at least one image.

또한, 클라우드 스트리밍 서버(110)는 알파 레벨에 기반하여 스틸 이미지 인코딩 기법을 선택하고, 선택된 스틸 이미지 인코딩 기법으로 적어도 하나의 이미지를 스틸 이미지 인코딩한다.In addition, the cloud streaming server 110 selects a still image encoding method based on the alpha level, and encodes at least one image as a still image encoding method using the selected still image encoding method.

이 때, 적어도 하나의 이미지가 제1 영역에서 캡처된 경우에 JPEG 스틸 이미지 인코딩 기법으로 스틸 이미지 인코딩을 수행하고, 적어도 하나의 이미지가 제2 영역에서 캡처된 경우에 PNG 스틸 이미지 인코딩 기법으로 스틸 이미지 인코딩을 수행할 수 있다.At this time, still image encoding is performed using the JPEG still image encoding technique when at least one image is captured in the first area, and still image encoding is performed using the PNG still image encoding technique when at least one image is captured in the second area. encoding can be performed.

이 때, 적어도 하나의 이미지가 제3 영역에서 캡처된 경우에 스틸 이미지 인코딩을 수행하지 않을 수 있다.In this case, when at least one image is captured in the third area, still image encoding may not be performed.

또한, 클라우드 스트리밍 서버(110)는 스틸 이미지 인코딩된 적어도 하나의 이미지를 단말로 전송한다.In addition, the cloud streaming server 110 transmits at least one still image-encoded image to the terminal.

단말(120-1~ 120-N)은 클라우드 스트리밍 서버(110)로부터 클라우드 스트리밍 서비스에 상응하는 어플리케이션 실행화면을 수신하여 사용자에게 제공한다.The terminals 120-1 to 120-N receive the application execution screen corresponding to the cloud streaming service from the cloud streaming server 110 and provide it to the user.

또한, 단말(120-1~ 120-N)은 각각 통신망에 연결되어 클라우드 컴퓨팅 시스템 기반으로 어플리케이션을 실행할 수 있는 장치로, 이동통신단말기에 한정된 것이 아니고, 모든 정보통신기기, 멀티미디어 단말, 유선 단말, 고정형 단말 및 IP(Internet Protocol) 단말 등의 다양한 단말일 수 있다. 또한, 단말(120-1~ 120-N)은 각각 휴대폰, PMP(Portable Multimedia Played), MID(Mobile Internet Device), 스마트폰(Smart Phone), 데스크톱(Desktop), 태블릿컴퓨터(Tablet PC), 노트북(Note book), 넷북(Net Book), 개인휴대용 정보단말(Personal Digital Assistant; PDA), 스마트 TV 및 정보통신 기기 등과 같은 다양한 이동통신 사양을 갖는 모바일(Mobile) 단말일 수 있다.In addition, each of the terminals 120-1 to 120-N is a device that is connected to a communication network and can execute an application based on a cloud computing system, and is not limited to a mobile communication terminal, and includes all information and communication devices, multimedia terminals, wired terminals, It may be various terminals such as a fixed terminal and an IP (Internet Protocol) terminal. In addition, each of the terminals 120-1 to 120-N is a mobile phone, PMP (Portable Multimedia Played), MID (Mobile Internet Device), smartphone (Smart Phone), desktop (Desktop), tablet computer (Tablet PC), notebook It may be a mobile terminal having various mobile communication specifications such as a note book, a net book, a personal digital assistant (PDA), a smart TV, and an information communication device.

또한, 단말(120-1~ 120-N)은 숫자 및 문자 정보 등의 다양한 정보를 입력 받고, 각종 기능을 설정 및 단말(120-1~ 120-N)의 기능 제어와 관련하여 입력되는 신호를 입력부를 통해 제어부로 전달할 수 있다. 또한, 단말(120-1~ 120-N)의 입력부는 사용자의 터치 또는 조작에 따른 입력 신호를 발생하는 키패드와 터치패드 중 적어도 하나를 포함하여 구성할 수 있다. 이 때, 단말(120-1~ 120-N)의 입력부는 단말(120-1~ 120-N)의 표시부와 함께 하나의 터치패널(또는 터치 스크린(touch screen))의 형태로 구성되어 입력과 표시 기능을 동시에 수행할 수 있다. 또한, 단말(120-1~ 120-N)의 입력부는 키보드, 키패드, 마우스, 조이스틱 등과 같은 입력 장치 외에도 향후 개발될 수 있는 모든 형태의 입력 수단이 사용될 수 있다. 특히, 본 발명에 따른 단말(120-1~ 120-N)의 입력부는 클라우드 컴퓨팅 기반으로 컨텐츠를 업로드 하거나 다운로드 하기 위한 입력 신호를 단말(120-1~ 120-N)의 제어부로 전달할 수 있다.In addition, the terminals 120-1 to 120-N receive various information such as number and character information, set various functions, and receive signals input in relation to function control of the terminals 120-1 to 120-N. It can be transmitted to the control unit through the input unit. Also, the input unit of the terminals 120-1 to 120-N may include at least one of a keypad and a touchpad that generate an input signal according to a user's touch or manipulation. At this time, the input unit of the terminals 120-1 to 120-N is configured in the form of a single touch panel (or touch screen) together with the display unit of the terminals 120-1 to 120-N, so that input and The display function can be performed at the same time. In addition, as the input unit of the terminals 120-1 to 120-N, all types of input means that may be developed in the future may be used in addition to input devices such as a keyboard, a keypad, a mouse, and a joystick. In particular, the input unit of the terminals 120-1 to 120-N according to the present invention may transmit an input signal for uploading or downloading content based on cloud computing to the control unit of the terminals 120-1 to 120-N.

또한, 단말(120-1~ 120-N)의 표시부는 단말(120-1~ 120-N)의 기능 수행 중에 발생하는 일련의 동작상태 및 동작결과 등에 대한 정보를 표시할 수 있다. 또한, 단말(120-1~ 120-N)의 표시부는 단말(120-1~ 120-N)의 메뉴 및 사용자가 입력한 사용자 데이터 등을 표시할 수 있다. 여기서, 단말(120-1~ 120-N)의 표시부는 액정표시장치(LCD, Liquid Crystal Display), 초박막 액정표시장치(TFT-LCD, Thin Film Transistor LCD), 발광다이오드(LED, Light Emitting Diode), 유기 발광다이오드(OLED, Organic LED), 능동형 유기발광다이오드(AMOLED, Active Matrix OLED), 레티나 디스플레이(Retina Display), 플렉시블 디스플레이(Flexible display) 및 3차원(3 Dimension) 디스플레이 등으로 구성될 수 있다. 이 때, 단말(120-1~ 120-N)의 표시부가 터치스크린 형태로 구성된 경우, 단말(120-1~ 120-N)의 표시부는 단말(120-1~ 120-N)의 입력부의 기능 중 일부 또는 전부를 수행할 수 있다. 특히, 본 발명에 따른 단말(120-1~ 120-N)의 표시부는 클라우드 컴퓨팅 기반으로 제공되는 컨텐츠의 실행과 관련된 정보를 화면으로 표시할 수 있다.In addition, the display unit of the terminals 120-1 to 120-N may display information about a series of operation states and operation results that occur while the functions of the terminals 120-1 to 120-N are performed. In addition, the display unit of the terminals 120-1 to 120-N may display menus of the terminals 120-1 to 120-N and user data input by the user. Here, the display unit of the terminals 120-1 to 120-N includes a liquid crystal display (LCD), an ultra-thin liquid crystal display (TFT-LCD, Thin Film Transistor LCD), and a light emitting diode (LED, Light Emitting Diode). , organic light emitting diodes (OLED, Organic LED), active organic light emitting diodes (AMOLED, Active Matrix OLED), retina display (Retina Display), flexible display (Flexible display) and three-dimensional (3 Dimension) display, etc. have. At this time, when the display unit of the terminals 120-1 to 120-N is configured in the form of a touch screen, the display unit of the terminals 120-1 to 120-N functions as an input unit of the terminals 120-1 to 120-N. You can do some or all of them. In particular, the display unit of the terminals 120-1 to 120-N according to the present invention may display information related to execution of content provided based on cloud computing on a screen.

또한, 단말(120-1~ 120-N)의 저장부는 데이터를 저장하기 위한 장치로, 주 기억장치 및 보조 기억장치를 포함하고, 단말(120-1~ 120-N)의 기능 동작에 필요한 응용 프로그램을 저장할 수 있다. 이러한 단말(120-1~ 120-N)의 저장부는 크게 프로그램 영역과 데이터 영역을 포함할 수 있다. 여기서, 단말(120-1~ 120-N)은 사용자의 요청에 상응하여 각 기능을 활성화하는 경우, 제어부의 제어 하에 해당 응용 프로그램들을 실행하여 각 기능을 제공하게 된다. 특히, 본 발명에 따른 단말(120-1~ 120-N)의 저장부는 단말(120-1~ 120-N)을 부팅시키는 운영체제, 클라우드 컴퓨팅 기반으로 컨텐츠를 업로드 하거나 다운로드하기 위한 프로그램 등을 저장할 수 있다. 또한, 단말(120-1~ 120-N)의 저장부는 다수의 컨텐츠를 저장하는 컨텐츠 DB와 단말(120-1~ 120-N)의 정보를 저장할 수 있다. 이 때, 컨텐츠 DB는 컨텐츠를 실행하기 위한 실행 데이터와 컨텐츠에 대한 속성 정보를 포함하고, 컨텐츠 실행에 따른 컨텐츠 사용 정보 등이 저장될 수 있다. 그리고, 단말(120-1~ 120-N)의 정보는 단말 사양 정보를 포함할 수 있다.In addition, the storage unit of the terminals 120-1 to 120-N is a device for storing data, and includes a main memory and an auxiliary memory, and is an application necessary for the functional operation of the terminals 120-1 to 120-N. program can be saved. The storage unit of the terminals 120-1 to 120-N may largely include a program area and a data area. Here, when each function is activated in response to a user's request, the terminals 120-1 to 120-N execute corresponding application programs under the control of the controller to provide each function. In particular, the storage unit of the terminals 120-1 to 120-N according to the present invention can store an operating system for booting the terminals 120-1 to 120-N, a program for uploading or downloading content based on cloud computing, etc. have. In addition, the storage unit of the terminals 120-1 to 120-N may store a content DB for storing a plurality of contents and information of the terminals 120-1 to 120-N. In this case, the content DB includes execution data for executing the content and attribute information on the content, and content usage information according to the content execution may be stored. And, the information of the terminals 120-1 to 120-N may include terminal specification information.

또한, 단말(120-1~ 120-N)의 통신부는 클라우드 스트리밍 서버(110)와 네트워크(130)을 통해 데이터를 송수신하기 위한 기능을 수행할 수 있다. 여기서 단말(120-1~ 120-N)의 통신부는 송신되는 신호의 주파수를 상승 변환 및 증폭하는 RF 송신 수단과 수신되는 신호를 저잡음 증폭하고 주파수를 하강 변환하는 RF 수신 수단 등을 포함할 수 있다. 이러한 단말(120-1~ 120-N)의 통신부는 무선통신 모듈 및 유선통신 모듈 중 적어도 하나를 포함할 수 있다. 그리고, 무선통신 모듈은 무선 통신 방법에 따라 데이터를 송수신하기 위한 구성이며, 단말(120-1~ 120-N)이 무선 통신을 이용하는 경우, 무선망 통신 모듈, 무선랜 통신 모듈 및 무선팬 통신 모듈 중 어느 하나를 이용하여 데이터를 클라우드 스트리밍 서버(110)로 송수신할 수 있다. 또한, 유선통신 모듈은 유선으로 데이터를 송수신하기 위한 것이다. 유선통신 모듈은 유선을 통해 네트워크(130)에 접속하여, 클라우드 스트리밍 서버(110)에 데이터를 송수신할 수 있다. 즉 단말(120-1~ 120-N)은 무선통신 모듈 또는 유선통신 모듈을 이용하여 네트워크(130)에 접속하며, 네트워크(130)을 통해 클라우드 스트리밍 서버(110)와 데이터를 송수신할 수 있다. 특히, 본 발명에 따른 네트워크(130)는 클라우드 스트리밍 서버(110) 또는 다른 단말(120-1~ 120-N)과 통신하여 클라우드 컴퓨팅 기반으로 컨텐츠를 업로드 또는 다운로드 하는데 필요한 데이터를 송수신할 수 있다.In addition, the communication unit of the terminals 120-1 to 120-N may perform a function for transmitting and receiving data through the cloud streaming server 110 and the network 130 . Here, the communication unit of the terminals 120-1 to 120-N may include an RF transmitting means for up-converting and amplifying the frequency of the transmitted signal, and an RF receiving means for low-noise amplifying the received signal and down-converting the frequency. . The communication unit of the terminals 120-1 to 120-N may include at least one of a wireless communication module and a wired communication module. In addition, the wireless communication module is a configuration for transmitting and receiving data according to a wireless communication method, and when the terminals 120-1 to 120-N use wireless communication, a wireless network communication module, a wireless LAN communication module, and a wireless fan communication module Using any one of the data can be transmitted and received to the cloud streaming server (110). In addition, the wired communication module is for transmitting and receiving data by wire. The wired communication module may connect to the network 130 through a wire and transmit/receive data to/from the cloud streaming server 110 . That is, the terminals 120-1 to 120-N may connect to the network 130 using a wireless communication module or a wired communication module, and may transmit/receive data to and from the cloud streaming server 110 through the network 130 . In particular, the network 130 according to the present invention may communicate with the cloud streaming server 110 or other terminals 120-1 to 120-N to transmit and receive data required to upload or download content based on cloud computing.

또한, 단말(120-1~ 120-N)의 제어부는 운영 체제((OS, Operation System) 및 각 구성을 구동시키는 프로세스 장치가 될 수 있다. 예를 들어, 제어부는 클라우드 스트리밍 서버(110)에 접속하는 과정 전반을 제어할 수 있다. 별도의 서비스 어플리케이션을 통해 클라우드 스트리밍 서버(110)에 접속하는 경우, 사용자의 요청에 따라 서비스 어플리케이션을 실행되는 과정 전반을 제어할 수 있으며, 실행과 동시에 클라우드 스트리밍 서버(110)로 서비스 이용 요청이 전송되도록 제어할 수 있으며, 이때 사용자 인증에 필요한 단말(120-1~ 120-N)의 정보가 함께 전송되도록 제어할 수 있다.In addition, the control unit of the terminals 120-1 to 120-N may be a process device for driving an operating system (OS, Operation System) and each configuration. For example, the control unit is configured to be connected to the cloud streaming server 110 . It is possible to control the entire process of accessing When accessing the cloud streaming server 110 through a separate service application, the entire process of executing the service application can be controlled according to the user's request, and at the same time as the execution of the cloud streaming It is possible to control so that a service use request is transmitted to the server 110, and at this time, it is possible to control so that information of the terminals 120-1 to 120-N required for user authentication is transmitted together.

또한, 단말(120-1~ 120-N)의 제어부는 사용자의 요청에 따라 단말(120-1~ 120-N)의 저장부에 저장된 특정 컨텐츠를 실행할 수 있다. 이때, 제어부는 컨텐츠 실행에 따른 컨텐츠 사용 이력을 컨텐츠 사용 정보로 저장할 수 있다.Also, the controller of the terminals 120-1 to 120-N may execute specific content stored in the storage unit of the terminals 120-1 to 120-N according to a user's request. In this case, the controller may store the content use history according to the content execution as content use information.

또한, 단말(120-1~ 120-N)의 제어부는 컨텐츠를 실행하기 위한 실행 데이터와, 컨텐츠에 대한 속성 정보를 포함하는 컨텐츠 정보와, 컨텐츠 사용 이력에 따른 정보인 컨텐츠 사용 정보를 함께 클라우드 스트리밍 서버(110)로 전송하여 업로드 할 수 있다. 이후, 제어부는 클라우드 스트리밍 서버(110)에 전송하여 업로드된 컨텐츠에 대해서는 사용자의 요청에 따라 단말(120-1~ 120-N)의 저장부에서 삭제할 수 있으며, 클라우드 스트리밍 서버(110)에 접속하여 클라우드 스트리밍 서버(110)를 통해 컨텐츠를 실행하여 이용할 수도 있다.In addition, the control unit of the terminals 120-1 to 120-N performs cloud streaming together with execution data for executing the content, content information including attribute information about the content, and content use information that is information according to the content use history. It can be uploaded by sending it to the server 110 . Thereafter, the control unit can delete the uploaded content transmitted to the cloud streaming server 110 from the storage unit of the terminals 120-1 to 120-N according to the user's request, and access the cloud streaming server 110 to Content may be executed and used through the cloud streaming server 110 .

또한, 단말(120-1~ 120-N)의 제어부는 클라우드 스트리밍 서버(110)에 접속하여 다른 단말(120-1~ 120-N)로부터 컨텐츠를 다운로드한 후 저장부에 저장되도록 제어할 수도 있으며, 클라우드 스트리밍 서버(110)를 통해 컨텐츠 실행 시, 실행에 필요한 데이터만을 수신한 후 컨텐츠가 실행되도록 제어할 수도 있다.In addition, the control unit of the terminals 120-1 to 120-N may access the cloud streaming server 110 to download content from other terminals 120-1 to 120-N and then control it to be stored in the storage unit, , when executing content through the cloud streaming server 110, it is also possible to control so that the content is executed after receiving only the data necessary for execution.

네트워크(130)는 클라우드 스트리밍 서버(110)및 단말(120-1~ 120-N) 사이에 데이터를 전달하는 통로를 제공하는 것으로서, 기존에 이용되는 네트워크 및 향후 개발 가능한 네트워크를 모두 포괄하는 개념이다. 예를 들어, 네트워크(130)는 한정된 지역 내에서 각종 정보장치들의 통신을 제공하는 유무선근거리 통신망, 이동체 상호 간 및 이동체와 이동체 외부와의 통신을 제공하는 이동통신망, 위성을 이용해 지구국과 지구국간 통신을 제공하는 위성통신망이거나 유무선 통신망 중에서 어느 하나이거나, 둘 이상의 결합으로 이루어질 수 있다. 한편, 네트워크(130)의 전송 방식 표준은, 기존의 전송 방식 표준에 한정되는 것은 아니며, 향후 개발될 모든 전송 방식 표준을 포함할 수 있다. 또한, 도 1에서 클라우드 스트리밍 서버(110)와 단말(120-1~ 120-N) 사이에 사용되는 네트워크는 단말(120-1~ 120-N)들 상호간에 사용되는 네트워크와 상이한 것일 수도 있고, 동일한 것일 수도 있다.The network 130 is a concept that provides a path for transferring data between the cloud streaming server 110 and the terminals 120-1 to 120-N, and encompasses both existing networks and networks that can be developed in the future. . For example, the network 130 may include a wired/wireless local area network that provides communication of various information devices within a limited area, a mobile communication network that provides communication between mobile devices and between the mobile body and the outside of the mobile device, and communication between the earth station and the earth station using satellites. It may be a satellite communication network that provides Meanwhile, the transmission method standard of the network 130 is not limited to the existing transmission method standard, and may include all transmission method standards to be developed in the future. In addition, the network used between the cloud streaming server 110 and the terminals 120-1 to 120-N in FIG. 1 may be different from the network used between the terminals 120-1 to 120-N, It may be the same.

이와 같은 클라우드 스트리밍 서비스 시스템을 통해 클라우드 스트리밍 서비스를 제공함으로써, 클라우드 스트리밍 서비스 시 캡처된 이미지의 알파 레벨에 따라 보다 자연스럽고 효율적인 인코딩을 수행할 수 있다.By providing a cloud streaming service through such a cloud streaming service system, more natural and efficient encoding can be performed according to the alpha level of an image captured during the cloud streaming service.

또한, 캡처 단계에서 인코딩 방식에 따라 이미지가 분할됨으로써 인코딩 시 해당 이미지의 속성을 파악하기 위해 컬러 수를 카운트 하는 등의 부가처리를 생략하도록 할 수 있다.In addition, since the image is divided according to the encoding method in the capture step, additional processing such as counting the number of colors in order to understand the properties of the image during encoding may be omitted.

또한, 사용자 단말에서 프레임의 변화된 이미지만을 렌더링하여 디스플레이 하도록 함으로써 사용자 단말의 성능이 낮더라도 클라우드 스트리밍 서비스를 원활하게 제공할 수 있다.In addition, by rendering and displaying only the changed image of the frame in the user terminal, the cloud streaming service can be smoothly provided even if the performance of the user terminal is low.

도 2는 도 1에 도시된 클라우드 스트리밍 서버의 일 예를 나타낸 블록도이다.2 is a block diagram showing an example of the cloud streaming server shown in FIG.

도 2를 참조하면, 도 1에 도시된 클라우드 스트리밍 서버(110)는 통신부(210), 프레임 분할부(220), 캡처부(230), 인코딩부(240), 스트리밍부(250) 및 저장부(260)를 포함한다.Referring to FIG. 2 , the cloud streaming server 110 shown in FIG. 1 includes a communication unit 210 , a frame division unit 220 , a capture unit 230 , an encoding unit 240 , a streaming unit 250 and a storage unit. (260).

통신부(210)는 도 1에 도시된 네트워크와 같은 통신망을 통해 다수의 단말들과 관련된 정보를 송수신하는 역할을 한다. 특히, 본 발명의 일실시예에 따른 통신부(210)는 클라우드 스트리밍 서비스에 대한 요청을 단말로부터 수신하고, 단말이 요청한 클라우드 스트리밍 서비스에 상응하는 어플리케이션의 실행화면을 단말로 제공할 수 있다.The communication unit 210 serves to transmit and receive information related to a plurality of terminals through a communication network such as the network shown in FIG. 1 . In particular, the communication unit 210 according to an embodiment of the present invention may receive a request for a cloud streaming service from a terminal, and provide an execution screen of an application corresponding to the cloud streaming service requested by the terminal to the terminal.

이 때, 단말이 요청한 클라우드 스트리밍 서비스에 대해서 클라우드 스트리밍 서버로부터 어플리케이션 실행화면을 수신할 수 있다.At this time, it is possible to receive the application execution screen from the cloud streaming server for the cloud streaming service requested by the terminal.

프레임 분할부(220)는 어플리케이션 실행화면을 렌더링하고, 알파 레벨을 기반으로 어플리케이션 실행화면에 상응하는 프레임 화면을 적어도 하나의 분할 영역으로 분할한다.The frame divider 220 renders the application execution screen and divides the frame screen corresponding to the application execution screen into at least one divided area based on the alpha level.

이 때, 웹 어플리케이션 서버가 사용자의 요청에 상응하게 어플리케이션을 실행시키고, 어플리케이션을 실행한 결과에 상응하는 어플리케이션 실행화면을 클라우드 스트리밍 서버(110)로 전송할 수 있다. 즉, 클라우드 스트리밍 서버(110)에서는 어플리케이션을 실행한 결과 화면만을 이용하여 사용자에게 이미지 기반의 클라우드 스트리밍 서비스를 제공할 수 있다.At this time, the web application server may execute the application according to the user's request, and transmit the application execution screen corresponding to the result of executing the application to the cloud streaming server 110 . That is, the cloud streaming server 110 may provide an image-based cloud streaming service to the user using only the result screen of executing the application.

이 때, 클라우드 스트리밍 서비스를 위해 이용하는 스틸 이미지 인코더는 투명도를 나타내는 알파 채널을 포함할 수 있는 PNG와 같은 인코더가 있을 수 있고, JPEG와 같이 알파 채널이 없는 인코더가 있을 수 있다. 또한, 화면 구성 상 알파 레벨 별로 해당 부분의 특성이 다를 가능성이 높기 때문에, 알파 레벨 별로 인코딩 시 물체의 구분도 자연스러우며 인코딩 성능이 향상될 가능성이 높을 수 있다.In this case, the still image encoder used for the cloud streaming service may include an encoder such as PNG that may include an alpha channel indicating transparency, or an encoder without an alpha channel such as JPEG. In addition, since there is a high possibility that the characteristics of the corresponding part are different for each alpha level in the screen configuration, the classification of objects during encoding for each alpha level is natural and the encoding performance may be improved.

따라서, 이미지 기반의 클라우드 스트리밍 서비스에서 알파 레벨 별로 캡처 및 스틸 이미지 인코딩을 수행하기 위해서, 렌더링된 어플리케이션 실행화면에 상응하는 프레임 화면을 알파 레벨에 기반하여 분할할 수 있다. 이는, 스틸 이미지 인코딩을 수행할 때 각 이미지 영역의 특성을 확인하여 알파 레벨 별로 영역을 분리하여 인코딩하는 것보다 효율적일 수 있다.Accordingly, in order to perform capture and still image encoding for each alpha level in the image-based cloud streaming service, a frame screen corresponding to the rendered application execution screen may be divided based on the alpha level. This may be more efficient than encoding by separating the regions for each alpha level by checking the characteristics of each image region when performing still image encoding.

이 때, 적어도 하나의 분할 영역은 알파 레벨이 제1 레벨에 상응하는 제1 영역, 알파 레벨이 제2 레벨에 상응하는 제2 영역 및 알파 레벨이 제3 레벨에 상응하는 제3 영역 중 적어도 하나에 상응할 수 있다.In this case, the at least one divided region is at least one of a first region having an alpha level corresponding to a first level, a second region having an alpha level corresponding to a second level, and a third region having an alpha level corresponding to a third level. can correspond to

이 때, 프레임 화면을 구성하는 픽셀마다 알파 레벨을 체크하여 제1 영역, 제2 영역 및 제3 영역 중 어느 하나로 결정함으로써 적어도 하나의 분할 영역을 생성할 수 있다. 이 때, 렌더링하는 과정에서 프레임 화면을 구성하는 각각의 픽셀마다 컬러를 체크하면서 알파 레벨을 체크할 수 있다. In this case, at least one divided area may be generated by checking the alpha level for each pixel constituting the frame screen and determining one of the first area, the second area, and the third area. In this case, during the rendering process, the alpha level may be checked while checking the color for each pixel constituting the frame screen.

이 때, 알파 레벨은 알파 값이 255에 상응하는 제1 레벨, 알파 값이 128을 기준으로 기설정된 범위 내에 포함되는 제2 레벨 및 알파 값이 0에 상응하는 제3 레벨 중 적어도 하나에 상응할 수 있다.In this case, the alpha level may correspond to at least one of a first level having an alpha value of 255, a second level having an alpha value within a preset range based on 128, and a third level having an alpha value of 0. can

또한, 클라우드 스트리밍 서비스 시스템의 설정을 통해 알파 값이 128에 상응하는 경우에 알파 레벨을 제2 레벨에 상응하는 것으로 판단할 수도 있다.In addition, when the alpha value corresponds to 128 through the setting of the cloud streaming service system, it may be determined that the alpha level corresponds to the second level.

이 때, 제1 영역은 프레임 화면 중 불투명 영역에 상응하고, 제2 영역은 프레임 화면 중 반투명 영역에 상응하고, 제3영역은 프레임 화면 중 투명 영역에 상응할 수 있다. 예를 들어, 어플리케이션 실행화면에서 포스터나 그림과 같은 주요 이미지들은 불투명 영역에 상응할 수 있고, 포스터나 그림에 대한 설명을 포함하는 텍스트 부분은 반투명 영역에 상응할 수 있고, 뒷 배경의 라이브 채널이 항상 보여야 하기 때문에 배경이 투명 영역에 상응할 수 있다.In this case, the first area may correspond to an opaque area of the frame screen, the second area may correspond to a translucent area of the frame screen, and the third area may correspond to a transparent area of the frame screen. For example, in the application execution screen, main images such as a poster or picture may correspond to an opaque area, a text part including a description of the poster or picture may correspond to a translucent area, and a live channel in the background may correspond to an opaque area. Since it should always be visible, the background can correspond to a transparent area.

또한, 적어도 하나의 분할 영역은 알파 레벨에 따른 영역이기 때문에 위치상 서로 떨어져 있는 경우에도 동일한 영역으로 인식될 수 있다. 예를 들어, 알파 레벨이 제1 레벨에 상응하는 A, B 및 C 영역이 존재한다고 가정한다면, A, B 및 C에 상응하는 모든 영역을 포함하여 제1 영역으로 인식할 수 있다.In addition, since at least one divided area is an area according to the alpha level, even if they are spaced apart from each other in location, they may be recognized as the same area. For example, if it is assumed that regions A, B, and C corresponding to the first alpha level exist, all regions corresponding to A, B, and C may be recognized as the first region.

캡처부(230)는 적어도 하나의 분할 영역에서 각각 사용자의 단말로 제공할 적어도 하나의 이미지를 캡처한다. 즉, 제1 영역, 제2 영역 및 제3 영역에서 각각 이미지를 캡처할 수 있다.The capture unit 230 captures at least one image to be provided to each user's terminal in at least one divided area. That is, images may be captured in each of the first region, the second region, and the third region.

클라우드 스트리밍 서비스는 기본적으로 비디오 코덱 기반의 클라우드 스트리밍 기법을 적용하기 때문에 메뉴 디스플레이와 같은 정적인 화면에 대해서 클라우드 스트리밍 기법을 적용하는 경우에도 불필요하게 화면 전체를 캡처하여 비디오 코덱으로 인코딩하는 비효율적인 방법으로 클라우드 스트리밍 서비스를 수행하였다. 이러한 문제점을 해결하기 위해 본 발명은 메뉴 디스플레이 화면과 같이 프레임간 변화가 크지 않은 경우에는 클라우드 스트리밍 서버가 프레임간 변화를 검출하고, 변화된 영역을 이미지로 캡처한 뒤 스틸 이미지 압축 기법으로 인코딩하는 클라우드 스트리밍 서버(110)를 제공한다.Since the cloud streaming service basically applies the video codec-based cloud streaming technique, even when the cloud streaming technique is applied to a static screen such as a menu display, it is an inefficient way to unnecessarily capture the entire screen and encode it with a video codec. A cloud streaming service was performed. In order to solve this problem, in the present invention, when the change between frames is not large, such as a menu display screen, the cloud streaming server detects the change between frames, captures the changed area as an image, and then encodes it with a still image compression technique. A server 110 is provided.

또한, 비디오 코덱 기반의 클라우드 스트리밍 기법은 어플리케이션이 동작하는 화면에 상응하는 모든 프레임을 캡처하여 인코딩을 수행할 수 있다. 그러나 어플리케이션이 동작하는 화면 상에서 프레임간 변화가 크지 않은 경우에는 이전 프레임과 비교하여 변화된 프레임의 변화 영역만을 캡처하여 스틸 이미지 인코딩을 수행하고, 사용자의 단말 장치에 디스플레이 할 때 변화 영역을 제외한 부분은 동일하게 보여주고 변화 영역만 변화를 주는 방식으로 디스플레이 할 수 있다.In addition, the video codec-based cloud streaming technique can perform encoding by capturing all frames corresponding to the screen on which the application operates. However, if the frame-to-frame change is not significant on the screen on which the application is running, the still image encoding is performed by capturing only the change area of the frame that has changed compared to the previous frame, and the portion except the change area is the same when displayed on the user's terminal device. It can be displayed in such a way that only the change area changes.

이 때, 프레임 화면의 이전 프레임 화면과 적어도 하나의 분할 영역을 비교하여 적어도 하나의 분할 영역 별로 변화된 부분을 적어도 하나의 이미지로 캡처할 수 있다. In this case, by comparing the previous frame screen of the frame screen with at least one divided area, the changed portion for each at least one divided area may be captured as at least one image.

예를 들어, 프레임 화면을 알파 레벨에 따라 제1 영역과 제2 영역으로 분할하였다고 가정할 수 있다. 이 때, 제1 영역을 이전 프레임 화면과 비교하였을 때 제1 영역에서 변화된 부분이 있다면, 해당 부분을 제1 영역의 이미지로 캡처할 수 있다. 또한, 제2 영역을 이전 프레임 화면과 비교하였을 때 제2 영역에서 변화된 부분이 있다면, 해당 부분을 제2 영역의 이미지로 캡처할 수 있다.For example, it may be assumed that the frame screen is divided into a first area and a second area according to the alpha level. In this case, if there is a changed part in the first region when the first region is compared with the previous frame screen, the corresponding part may be captured as an image of the first region. Also, if there is a changed part in the second region when the second region is compared with the previous frame screen, the corresponding part may be captured as an image of the second region.

또한, 사용자의 단말로 전송될 프레임 전체 구간 중 프레임 변화가 적은 구간을 검출하고, 프레임 변화가 적은 구간에서 프레임들을 비교하여 이미지를 캡처할 수 있다.Also, it is possible to detect a section in which the frame change is small among the entire frame to be transmitted to the user's terminal, and compare the frames in the section in which the frame change is small to capture an image.

이 때, 사용자의 단말에서 발생하는 어플리케이션의 이벤트 유형을 감지하여 프레임 변화가 적은 구간을 검출할 수 있다. 예를 들어, 사용자의 단말에서 발생하는 입력신호에 따라 어플리케이션의 이벤트 유형이 결정될 수 있다. 입력신호에 따라 메뉴, 옵션, 안내 창과 같이 어플리케이션을 실행하였을 때 프레임의 변화가 적은 정적인 이벤트 또는 동영상 재생 및 게임 플레이와 같이 프레임이 자주 변하는 동적인 이벤트가 발생할 수 있다. 따라서, 사용자가 단말을 통해 발생시키는 입력신호로 이벤트 유형을 감지하고, 이벤트 유형이 정적인 이벤트라면, 해당 이벤트에 상응하는 프레임 전체 구간 중 프레임 변화가 적은 구간을 검출할 수 있다.In this case, it is possible to detect a section in which the frame change is small by detecting the event type of the application that occurs in the user's terminal. For example, an event type of an application may be determined according to an input signal generated from a user's terminal. Depending on the input signal, when an application is executed, such as a menu, an option, or a guide window, a static event with a small frame change or a dynamic event with a frequent frame change such as video playback and game play may occur. Accordingly, if the user detects an event type with an input signal generated through the terminal and the event type is a static event, it is possible to detect a section in which the frame change is small among the entire frame section corresponding to the event.

인코딩부(240)는 알파 레벨에 기반하여 스틸 이미지 인코딩 기법을 선택하고, 선택된 스틸 이미지 인코딩 기법으로 적어도 하나의 이미지를 스틸 이미지 인코딩한다.The encoding unit 240 selects a still image encoding method based on the alpha level, and encodes at least one still image using the selected still image encoding method.

이 때, 적어도 하나의 이미지가 제1 영역에서 캡처된 경우에 JPEG 스틸 이미지 인코딩 기법으로 스틸 이미지 인코딩을 수행하고, 적어도 하나의 이미지가 제2 영역에서 캡처된 경우에 PNG 스틸 이미지 인코딩 기법으로 스틸 이미지 인코딩을 수행할 수 있다. At this time, still image encoding is performed using the JPEG still image encoding technique when at least one image is captured in the first area, and still image encoding is performed using the PNG still image encoding technique when at least one image is captured in the second area. encoding can be performed.

즉, 이미지의 알파 레벨이 제1 레벨로, 알파 값이 255에 상응하는 경우에는 자연스러운 이미지 특성을 살릴 수 있도록 JPEG 스틸 이미지 인코딩 기법으로 이미지를 스틸 이미지 인코딩 할 수 있다.That is, when the alpha level of the image corresponds to the first level and the alpha value corresponds to 255, the image may be encoded as a still image using the JPEG still image encoding technique to preserve natural image characteristics.

이 때, JPEG 스틸 이미지 인코딩 기법은 압축 효율이 좋아서 인코딩 시 전송 데이터 량을 대폭 줄일 수 있으나, 압축 효율이 큰 만큼 인코딩 및 디코딩을 수행할 때 시스템 부하를 많이 발생시킬 수 있다.In this case, since the JPEG still image encoding technique has good compression efficiency, it is possible to significantly reduce the amount of transmitted data during encoding.

또한, 이미지의 알파 레벨이 제2 레벨로, 알파 값이 128을 기준으로 기설정된 범위 내에 포함되는 경우에는 PNG 스틸 이미지 인코딩 기법으로 이미지를 스틸 이미지 인코딩 할 수 있다.Also, when the alpha level of the image is the second level and the alpha value is within a preset range based on 128, the still image may be encoded using the PNG still image encoding technique.

이 때, PNG 스틸 이미지 인코딩 기법은 인코딩 시 이미지의 화질은 좋으나 데이터의 크기가 커져서 전송망의 대역폭이 낮은 경우에는 전송 속도가 저하될 수 있다.In this case, the PNG still image encoding technique has good image quality during encoding, but the transmission speed may be lowered when the bandwidth of the transmission network is low due to the large data size.

이 때, 적어도 하나의 이미지가 제3 영역에서 캡처된 경우에 스틸 이미지 인코딩을 수행하지 않을 수 있다. 즉, 이미지의 알파 레벨이 제3 레벨로, 알파 값이 0에 상응하는 투명한 영역인 경우에는 별도로 스틸 이미지 인코딩을 수행하지 않고 개별적으로 처리할 수 있다.In this case, when at least one image is captured in the third area, still image encoding may not be performed. That is, when the alpha level of the image is the third level and the alpha value is a transparent area corresponding to 0, it is possible to individually process the still image without separately encoding the still image.

스트리밍부(250)는 스틸 이미지 인코딩된 적어도 하나의 이미지를 단말로 전송한다.The streaming unit 250 transmits at least one still image-encoded image to the terminal.

이 때, 스틸 이미지 인코딩을 완료하고, 스틸 이미지 인코딩된 이미지를 사용자의 단말로 전송함으로써, 사용자가 단말에서 어플리케이션을 실행되는 느낌을 받을 수 있도록 이미지 기반의 클라우드 스트리밍 서비스를 제공할 수 있다.At this time, by completing still image encoding and transmitting the still image encoded image to the user's terminal, an image-based cloud streaming service can be provided so that the user can feel that the application is running on the terminal.

저장부(260)는 상술한 바와 같이 본 발명의 실시예에 따른 클라우드 스트리밍 서비스 과정에서 발생되는 다양한 정보를 저장한다.The storage unit 260 stores various information generated in the process of the cloud streaming service according to the embodiment of the present invention as described above.

실시예에 따라, 저장부(260)는 클라우드 스트리밍 서버(110)와 독립적으로 구성되어 클라우드 스트리밍 서비스를 위한 기능을 지원할 수 있다. 이 때, 저장부(260)는 별도의 대용량 스토리지로 동작할 수 있고, 동작 수행을 위한 제어 기능을 포함할 수 있다.According to an embodiment, the storage unit 260 may be configured independently of the cloud streaming server 110 to support a function for a cloud streaming service. In this case, the storage unit 260 may operate as a separate mass storage and may include a control function for performing an operation.

또한, 상술한 바와 같이 구성되는 클라우드 스트리밍 서버(110)는 하나 이상의 서버로 구현될 수 있다.In addition, the cloud streaming server 110 configured as described above may be implemented as one or more servers.

한편, 클라우드 스트리밍 서버(110)는 메모리가 탑재되어 그 장치 내에서 정보를 저장할 수 있다. 일 구현예의 경우, 메모리는 컴퓨터로 판독 가능한 매체이다. 일 구현 예에서, 메모리는 휘발성 메모리 유닛일 수 있으며, 다른 구현예의 경우, 메모리는 비휘발성 메모리 유닛일 수도 있다. 일 구현예의 경우, 저장장치는 컴퓨터로 판독 가능한 매체이다. 다양한 서로 다른 구현 예에서, 저장장치는 예컨대 하드디스크 장치, 광학디스크 장치, 혹은 어떤 다른 대용량 저장장치를 포함할 수도 있다.On the other hand, the cloud streaming server 110 is equipped with a memory can store information in the device. In one implementation, the memory is a computer-readable medium. In one implementation, the memory may be a volatile memory unit, and in another implementation, the memory may be a non-volatile memory unit. In one embodiment, the storage device is a computer-readable medium. In various different implementations, the storage device may include, for example, a hard disk device, an optical disk device, or some other mass storage device.

이와 같은 클라우드 스트리밍 서버(110)를 통해 클라우드 스트리밍 서비스를 제공함으로써, 이미지 기반의 클라우드 스트리밍 서비스 시 알파 레벨 별로 캡처된 이미지를 적합한 스틸 이미지 인코딩 기법으로 자연스럽고 효율적이게 처리할 수 있다.By providing the cloud streaming service through the cloud streaming server 110 as described above, images captured for each alpha level in the image-based cloud streaming service can be naturally and efficiently processed using a suitable still image encoding technique.

또한, 본 발명의 목적은 캡처 단계에서 인코딩 방식에 따라 이미지가 분할됨으로써 인코딩 시 해당 이미지의 속성을 파악하기 위해 컬러 수를 카운트 하는 등의 부가처리를 생략하도록 할 수 있다.In addition, it is an object of the present invention to omit additional processing such as counting the number of colors in order to understand the properties of the image during encoding by dividing the image according to the encoding method in the capture step.

또한, 본 발명의 목적은 사용자 단말에서 프레임의 변화된 이미지만을 렌더링하여 디스플레이 하도록 함으로써 사용자 단말의 성능이 낮더라도 클라우드 스트리밍 서비스를 원활하게 제공할 수 있다.In addition, an object of the present invention is to render and display only the changed image of the frame in the user terminal, so that the cloud streaming service can be smoothly provided even if the performance of the user terminal is low.

도 3은 본 발명의 일실시예에 따른 알파 레벨 별 프레임 화면을 나타낸 도면이다.3 is a diagram illustrating a frame screen for each alpha level according to an embodiment of the present invention.

도 3을 참조하면, 현재 프레임(310)과 다음 프레임(320)의 영역이 변화한 것을 확인할 수 있다.Referring to FIG. 3 , it can be confirmed that the regions of the current frame 310 and the next frame 320 have changed.

예를 들어, 현재 프레임(310)의 A 영역과 B 영역은 알파 레벨이 제1 레벨에 상응하는 제1 영역(311, 312)에 해당하고, C 영역은 알파 레벨이 제2 레벨에 상응하는 제2 영역(313)에 해당한다고 가정할 수 있다.For example, regions A and B of the current frame 310 correspond to first regions 311 and 312 having an alpha level corresponding to the first level, and region C corresponds to a second region having an alpha level corresponding to the second level. 2 may be assumed to correspond to the region 313 .

이 때, 다음 프레임(320)에서는 A 영역이 A` 영역으로 변하고, B 영역이 B` 영역으로 변하고, C 영역이 C` 영역으로 변한 것을 확인할 수 있다.At this time, in the next frame 320 , it can be seen that the region A is changed to the region A′, the region B is changed to the region B′, and the region C is changed to the region C′.

이 때, 본 발명의 일실시예에 따른 이미지 기반의 클라우드 스트리밍 서비스를 위해 변화된 곳의 이미지를 캡처한다면, 알파 레벨에 따라서 제1 영역과 제2 영역을 분할하여 이미지를 캡처할 수 있다.At this time, if an image of a changed place is captured for an image-based cloud streaming service according to an embodiment of the present invention, the image may be captured by dividing the first region and the second region according to the alpha level.

즉, 도 3에서 현재 프레임(310)의 제1 영역(311, 312)과 다음 프레임(320)의 제1 영역(321, 322)을 비교하고, 다음 프레임(320)의 A` 영역과 B` 영역을 제1 영역(321, 322)에서의 이미지로 캡처할 수 있다.That is, in FIG. 3 , the first regions 311 and 312 of the current frame 310 and the first regions 321 and 322 of the next frame 320 are compared, and regions A′ and B′ of the next frame 320 are compared. Regions may be captured as images in the first regions 321 and 322 .

또한, 도 3에서 현재 프레임(310)의 제2 영역(313)과 다음 프레임(320)의 제2 영역(323)을 비교하고, 다음 프레임(320)의 C` 영역을 제2 영역(323)에서의 이미지로 캡처할 수 있다.In addition, in FIG. 3 , the second region 313 of the current frame 310 and the second region 323 of the next frame 320 are compared, and region C′ of the next frame 320 is used as the second region 323 . It can be captured as an image from

이 때, 캡처를 수행하기 전에 알파 레벨 별로 영역을 분할하지 않고 클라우드 스트리밍 서비스를 위한 파이프라인 과정을 수행한다면, 스틸 이미지 인코딩을 수행하기 적합한 인코더가 무엇인지 판단하기 위해 다시 이미지의 컬러 정보를 체크하는 등의 부가적인 처리가 필요할 수 있다.At this time, if the pipeline process for the cloud streaming service is performed without dividing the region by alpha level before performing capture, the color information of the image is checked again to determine which encoder is suitable for still image encoding. Additional processing may be required.

따라서, 알파 레벨에 따라 분할된 영역에서 각각 이미지를 캡처하여 인코딩 절차를 진행함으로써, 이미지의 알파 레벨에 적합한 스틸 이미지 인코딩 기법을 수월하게 선택하여 보다 효율적으로 이미지를 인코딩할 수 있다.Accordingly, by performing an encoding procedure by capturing images in regions divided according to the alpha level, it is possible to more efficiently encode an image by easily selecting a still image encoding technique suitable for the alpha level of the image.

도 4는 본 발명의 일실시예에 따른 어플리케이션 실행화면의 프레임 화면을 나타낸 도면이다.4 is a diagram illustrating a frame screen of an application execution screen according to an embodiment of the present invention.

도 4를 참조하면, 본 발명의 일실시예에 따른 어플리케이션 실행화면의 프레임 화면은 불투명 영역(410)과 반투명 영역(420) 그리고 투명 영역으로 구분될 수 있다. Referring to FIG. 4 , the frame screen of the application execution screen according to an embodiment of the present invention may be divided into an opaque area 410 , a semi-transparent area 420 , and a transparent area.

이 때, 도 4와 같이 방송과 관련된 UI의 경우에는 뒷 배경의 라이브 채널을 항상 보여야 하는 요구 사항이 있을 수 있다. 따라서, 배경 부분은 투명 영역이 되고, 일반 설명부는 반투명 영역(420) 그리고 그림, 사진 및 포스터와 같은 중요한 Object는 불투명 영역(410)이 될 가능성이 높을 수 있다.In this case, in the case of a broadcast-related UI as shown in FIG. 4 , there may be a requirement to always show a live channel in the background. Accordingly, the background portion becomes the transparent area, the general description portion becomes the translucent area 420 , and important objects such as drawings, photos, and posters are highly likely to become the opaque area 410 .

이와 같이 불투명 영역(410), 반투명 영역(420) 그리고 투명 영역이 섞여 있는 프레임 화면의 경우에는 단순히 이전 프레임 화면의 영역과 비교하여 차이를 구하는 것보다, 알파 레벨 별로 영역을 나눈 후에 이전 프레임 화면의 영역과 차이를 구하는 것이 인코딩 측면에서 효율을 향상시킬 수 있다.In the case of a frame screen in which the opaque area 410, the semi-transparent area 420, and the transparent area are mixed as described above, rather than simply comparing the area of the previous frame screen to obtain a difference, the area of the previous frame screen is divided by alpha level. Finding the region and difference can improve the efficiency in terms of encoding.

도 5는 도 4에 도시된 프레임 화면을 알파 레벨로 나타낸 도면이다.FIG. 5 is a diagram illustrating the frame screen shown in FIG. 4 at an alpha level.

도 5를 참조하면, 도 4에 도시된 프레임 화면을 알파 레벨 별로 나타내면 불투명 영역(510), 반투명 영역(520) 그리고 배경에 해당 하는 모든 영역은 투명 영역(530)에 해당할 수 있다.Referring to FIG. 5 , when the frame screen shown in FIG. 4 is displayed for each alpha level, the opaque area 510 , the semi-transparent area 520 , and all areas corresponding to the background may correspond to the transparent area 530 .

즉, 불투명 영역(510)은 알파 값이 255에 상응하거나, 또는 알파 값이 250 이상에 상응하므로, 포스터나 그림과 같이 뒷 배경의 영역이 보이지 않는 이미지에 해당할 수 있다.That is, since the opaque region 510 has an alpha value of 255 or an alpha value of 250 or greater, the opaque region 510 may correspond to an image in which a background region is not visible, such as a poster or a picture.

또한, 반투명 영역(520)은 알파 값이 128에 상응하거나, 또는 알파 값이 50과 250 사이에 상응하므로, 주요 Object에 대한 부연설명과 같은 텍스트 이미지에 해당할 수 있다.Also, since the translucent area 520 has an alpha value of 128 or an alpha value between 50 and 250, it may correspond to a text image such as an amplified description of a main object.

또한, 투명 영역(530)은 알파 값이 0에 상응하거나, 또는 알파 값이 50 이하에 상응하므로, 뒷 배경의 이미지를 보이도록 투명한 배경에 해당할 수 있다.Also, since the alpha value corresponds to 0 or the alpha value corresponds to 50 or less, the transparent region 530 may correspond to a transparent background to show an image of a background background.

이 때, 도 5와 같이 알파 레벨 별로 영역을 구분하지 않고 인코딩 단에서 바로 변화를 검출한다고 가정할 수 있다. 이런 경우에는 변화 영역에 대한 이미지와 배경이 섞이게 되므로 캡처 이미지에 대한 적절한 인코더가 무엇인지 확인하는 과정에서 이미지의 컬러 수를 다시 카운트 해야 하는 등의 부가처리가 필수적으로 동반될 수 있다.In this case, it can be assumed that the change is detected at the encoding stage without dividing the region by alpha level as shown in FIG. 5 . In this case, since the image and background for the change area are mixed, additional processing such as having to count the number of colors in the image again in the process of checking what is the appropriate encoder for the captured image may be necessarily accompanied.

따라서, 어플리케이션 실행화면에서 이미지를 캡처하기 전에 알파 레벨에 따라 영역을 분할하고, 분할된 영역들을 기반으로 스트리밍 파이프 라인 과정을 수행함으로써 보다 효율적인 스틸 이미지 인코딩을 거쳐 서비스를 제공할 수 있다.Therefore, before capturing an image in the application execution screen, a service can be provided through more efficient still image encoding by dividing a region according to the alpha level and performing a streaming pipeline process based on the divided regions.

도 6은 본 발명의 일실시예에 따라 알파 레벨에 따른 영역별로 이미지를 캡처하는 과정을 나타낸 도면이다.6 is a diagram illustrating a process of capturing an image for each region according to an alpha level according to an embodiment of the present invention.

도 6을 참조하면, 본 발명의 일실시예에 따라 알파 레벨에 따른 영역별로 이미지를 캡처하는 과정은 이전 프레임(610)과 현재 프레임(620)에서 프레임 영역의 전체를 기준으로 변화를 비교하지 않고, 알파 레벨 별로 분할된 적어도 하나의 분할 영역을 기준으로 변화를 비교할 수 있다.Referring to FIG. 6 , the process of capturing an image for each region according to the alpha level according to an embodiment of the present invention does not compare changes based on the entire frame region in the previous frame 610 and the current frame 620 . , the change may be compared based on at least one divided region divided by alpha level.

예를 들어, 이전 프레임(610)의 A1, A2, 현재 프레임(620)의 A3, A4에 상응하는 영역이 모두 제1 영역에 상응하고, 이전 프레임(610)의 B1, 현재 프레임(620)의 B2에 상응하는 영역이 모두 제2 영역에 상응한다고 가정할 수 있다.For example, regions corresponding to A1 and A2 of the previous frame 610 and A3 and A4 of the current frame 620 all correspond to the first region, and B1 of the previous frame 610 and the regions of the current frame 620 . It may be assumed that all regions corresponding to B2 correspond to the second region.

또한, 이전 프레임(610)와 현재 프레임(620)에서 제1 영역과 제2 영역 중 어느 영역에도 해당하지 않는 영역은 제3 영역, 즉 배경에 상응한다고 가정할 수 있다.Also, in the previous frame 610 and the current frame 620 , it may be assumed that an area that does not correspond to any of the first area and the second area corresponds to the third area, that is, the background.

이 때, 이전 프레임(610)과 현재 프레임(620)의 변화 영역을 비교하기 위해서, 먼저 제1 영역에 상응하는 영역끼리 비교할 수 있다. 즉, 이전 프레임(610)의 A1과 A2에 해당하는 제1 영역이 현재 프레임(620)에서 변화하였는지 여부를 비교할 수 있다. In this case, in order to compare the change regions of the previous frame 610 and the current frame 620 , regions corresponding to the first region may be compared. That is, it is possible to compare whether the first area corresponding to A1 and A2 of the previous frame 610 has changed in the current frame 620 .

이 때, 이전 프레임(610)의 A1과 A2가 현재 프레임(620)에서는 A3와 A4로 변하였다고 가정한다면, 현재 프레임(620)의 제1 영역에서는 A3와 A4에 해당하는 영역을 제1 영역의 캡처 이미지로 캡처할 수 있다.At this time, if it is assumed that A1 and A2 of the previous frame 610 are changed to A3 and A4 in the current frame 620 , in the first area of the current frame 620 , the areas corresponding to A3 and A4 are divided into the first area. You can capture it as a capture image.

또한, 제1 영역에서 변화된 영역의 이미지를 캡처한 뒤에는 제2 영역과 제3 영역에서 캡처될 부분이 없는지 비교할 수 있다.Also, after capturing the image of the changed region in the first region, it may be compared whether there is a portion to be captured in the second region and the third region.

즉, 이전 프레임(610)의 B1에 해당하는 제2 영역이 현재 프레임(620)에서 변화하였는지 여부를 비교할 수 있다.That is, it is possible to compare whether the second region corresponding to B1 of the previous frame 610 has changed in the current frame 620 .

이 때, 이전 프레임(610)의 B1이 현재 프레임(620)에서는 B2로 변하였다고 가정한다면, 현재 프레임(620)의 제2 영역에서는 B2에 해당하는 영역을 제2 영역의 캡처 이미지로 캡처할 수 있다.At this time, assuming that B1 of the previous frame 610 is changed to B2 in the current frame 620, the area corresponding to B2 in the second area of the current frame 620 can be captured as the capture image of the second area. have.

또한, 제2 영역에서 변화된 영역의 이미지를 캡처한 뒤에는 제3 영역에서 캡처될 부분이 없는지 비교할 수도 있다.Also, after capturing the image of the changed area in the second area, it may be compared whether there is a portion to be captured in the third area.

이와 같이 각 분할 영역에 따라서 이미지를 캡처하여 분할 영역별 캡처 이미지를 생성함으로써, 스틸 이미지 인코딩을 수행할 때 분할 영역별 캡처 이미지에 각각 적합한 스틸 이미지 인코딩 기법을 선택하여 스틸 이미지 인코딩을 수행할 수 있다. 또한, 분할 영역별 캡처 이미지에 적합한 스틸 이미지 인코딩 기법으로 스틸 이미지 인코딩을 수행함으로써, 인코딩 효율을 향상시킬 수도 있다.In this way, by capturing an image according to each divided region and generating a captured image for each divided region, still image encoding can be performed by selecting a still image encoding technique suitable for each captured image for each divided region when performing still image encoding. . In addition, encoding efficiency may be improved by performing still image encoding using a still image encoding technique suitable for captured images for each divided region.

도 7은 본 발명의 일실시예에 따른 알파 레벨을 이용한 이미지 클라우드 스트리밍 서비스 방법을 나타낸 동작 흐름도이다.7 is an operation flowchart illustrating an image cloud streaming service method using an alpha level according to an embodiment of the present invention.

도 7을 참조하면, 본 발명의 일실시예에 따른 알파 레벨을 이용한 이미지 클라우드 스트리밍 서비스 방법은 어플리케이션 실행화면을 렌더링하고, 알파 레벨을 기반으로 어플리케이션 실행화면에 상응하는 프레임 화면을 적어도 하나의 분할 영역으로 분할한다(S710).Referring to FIG. 7 , the image cloud streaming service method using an alpha level according to an embodiment of the present invention renders an application execution screen, and based on the alpha level, a frame screen corresponding to the application execution screen is displayed in at least one divided area. is divided into (S710).

이 때, 웹 어플리케이션 서버가 사용자의 요청에 상응하게 어플리케이션을 실행시키고, 어플리케이션을 실행한 결과에 상응하는 어플리케이션 실행화면을 클라우드 스트리밍 서버로 전송할 수 있다. 즉, 클라우드 스트리밍 서버에서는 어플리케이션을 실행한 결과 화면만을 이용하여 사용자에게 이미지 기반의 클라우드 스트리밍 서비스를 제공할 수 있다.At this time, the web application server may execute the application according to the user's request, and transmit the application execution screen corresponding to the result of executing the application to the cloud streaming server. That is, the cloud streaming server may provide an image-based cloud streaming service to the user using only the result screen of executing the application.

이 때, 클라우드 스트리밍 서비스를 위해 이용하는 스틸 이미지 인코더는 투명도를 나타내는 알파 채널을 포함할 수 있는 PNG와 같은 인코더가 있을 수 있고, JPEG와 같이 알파 채널이 없는 인코더가 있을 수 있다. In this case, the still image encoder used for the cloud streaming service may include an encoder such as PNG that may include an alpha channel indicating transparency, or an encoder without an alpha channel such as JPEG.

또한, 화면 구성 상 알파 레벨 별로 해당 부분의 특성이 다를 가능성이 높기 때문에, 알파 레벨 별로 인코딩 시 물체의 구분도 자연스러우며 인코딩 성능이 향상될 가능성이 높을 수 있다.In addition, since there is a high possibility that the characteristics of the corresponding part are different for each alpha level in the screen configuration, the classification of objects during encoding for each alpha level is natural and the encoding performance may be improved.

따라서, 이미지 기반의 클라우드 스트리밍 서비스에서 알파 레벨 별로 캡처 및 스틸 이미지 인코딩을 수행하기 위해서, 렌더링된 어플리케이션 실행화면에 상응하는 프레임 화면을 알파 레벨에 기반하여 분할할 수 있다. 이는, 스틸 이미지 인코딩을 수행할 때 각 이미지 영역의 특성을 확인하여 알파 레벨 별로 영역을 분리하여 인코딩하는 것보다 효율적일 수 있다.Accordingly, in order to perform capture and still image encoding for each alpha level in the image-based cloud streaming service, a frame screen corresponding to the rendered application execution screen may be divided based on the alpha level. This may be more efficient than encoding by separating the regions for each alpha level by checking the characteristics of each image region when performing still image encoding.

이 때, 적어도 하나의 분할 영역은 알파 레벨이 제1 레벨에 상응하는 제1 영역, 알파 레벨이 제2 레벨에 상응하는 제2 영역 및 알파 레벨이 제3 레벨에 상응하는 제3 영역 중 적어도 하나에 상응할 수 있다.In this case, the at least one divided region is at least one of a first region having an alpha level corresponding to a first level, a second region having an alpha level corresponding to a second level, and a third region having an alpha level corresponding to a third level. can correspond to

이 때, 프레임 화면을 구성하는 픽셀마다 알파 레벨을 체크하여 제1 영역, 제2 영역 및 제3 영역 중 어느 하나로 결정함으로써 적어도 하나의 분할 영역을 생성할 수 있다. 이 때, 렌더링하는 과정에서 프레임 화면을 구성하는 각각의 픽셀마다 컬러를 체크하면서 알파 레벨을 체크할 수 있다. In this case, at least one divided area may be generated by checking the alpha level for each pixel constituting the frame screen and determining one of the first area, the second area, and the third area. In this case, during the rendering process, the alpha level may be checked while checking the color for each pixel constituting the frame screen.

이 때, 알파 레벨은 알파 값이 255에 상응하는 제1 레벨, 알파 값이 128을 기준으로 기설정된 범위 내에 포함되는 제2 레벨 및 알파 값이 0에 상응하는 제3 레벨 중 적어도 하나에 상응할 수 있다.In this case, the alpha level may correspond to at least one of a first level having an alpha value of 255, a second level having an alpha value within a preset range based on 128, and a third level having an alpha value of 0. can

또한, 클라우드 스트리밍 서비스 시스템의 설정을 통해 알파 값이 128에 상응하는 경우에 알파 레벨을 제2 레벨에 상응하는 것으로 판단할 수도 있다.In addition, when the alpha value corresponds to 128 through the setting of the cloud streaming service system, it may be determined that the alpha level corresponds to the second level.

이 때, 제1 영역은 프레임 화면 중 불투명 영역에 상응하고, 제2 영역은 프레임 화면 중 반투명 영역에 상응하고, 제3영역은 프레임 화면 중 투명 영역에 상응할 수 있다. 예를 들어, 어플리케이션 실행화면에서 포스터나 그림과 같은 주요 이미지들은 불투명 영역에 상응할 수 있고, 포스터나 그림에 대한 설명을 포함하는 텍스트 부분은 반투명 영역에 상응할 수 있고, 뒷 배경의 라이브 채널이 항상 보여야 하기 때문에 배경이 투명 영역에 상응할 수 있다.In this case, the first area may correspond to an opaque area of the frame screen, the second area may correspond to a translucent area of the frame screen, and the third area may correspond to a transparent area of the frame screen. For example, in the application execution screen, main images such as a poster or picture may correspond to an opaque area, a text part including a description of the poster or picture may correspond to a translucent area, and a live channel in the background may correspond to an opaque area. Since it should always be visible, the background can correspond to a transparent area.

또한, 적어도 하나의 분할 영역은 알파 레벨에 따른 영역이기 때문에 위치상 서로 떨어져 있는 경우에도 동일한 영역으로 인식될 수 있다. 예를 들어, 알파 레벨이 제1 레벨에 상응하는 A, B 및 C 영역이 존재한다고 가정한다면, A, B 및 C에 상응하는 모든 영역을 포함하여 제1 영역으로 인식할 수 있다.In addition, since at least one divided area is an area according to the alpha level, even if they are spaced apart from each other in location, they may be recognized as the same area. For example, if it is assumed that regions A, B, and C corresponding to the first alpha level exist, all regions corresponding to A, B, and C may be recognized as the first region.

또한, 본 발명의 일실시예에 따른 알파 레벨을 이용한 이미지 클라우드 스트리밍 서비스 방법은 적어도 하나의 분할 영역에서 각각 사용자의 단말로 제공할 적어도 하나의 이미지를 캡처한다(S720). 즉, 제1 영역, 제2 영역 및 제3 영역에서 각각 이미지를 캡처할 수 있다.In addition, the image cloud streaming service method using an alpha level according to an embodiment of the present invention captures at least one image to be provided to each user's terminal in at least one divided area (S720). That is, images may be captured in each of the first region, the second region, and the third region.

클라우드 스트리밍 서비스는 기본적으로 비디오 코덱 기반의 클라우드 스트리밍 기법을 적용하기 때문에 메뉴 디스플레이와 같은 정적인 화면에 대해서 클라우드 스트리밍 기법을 적용하는 경우에도 불필요하게 화면 전체를 캡처하여 비디오 코덱으로 인코딩하는 비효율적인 방법으로 클라우드 스트리밍 서비스를 수행하였다. 이러한 문제점을 해결하기 위해 본 발명은 메뉴 디스플레이 화면과 같이 프레임간 변화가 크지 않은 경우에는 클라우드 스트리밍 서버가 프레임간 변화를 검출하고, 변화된 영역을 이미지로 캡처한 뒤 스틸 이미지 압축 기법으로 인코딩하는 클라우드 스트리밍 서버를 제공한다.Since the cloud streaming service basically applies the video codec-based cloud streaming technique, even when the cloud streaming technique is applied to a static screen such as a menu display, it is an inefficient way to unnecessarily capture the entire screen and encode it with a video codec. A cloud streaming service was performed. In order to solve this problem, in the present invention, when the change between frames is not large, such as a menu display screen, the cloud streaming server detects the change between frames, captures the changed area as an image, and then encodes it with a still image compression technique. server is provided.

또한, 비디오 코덱 기반의 클라우드 스트리밍 기법은 어플리케이션이 동작하는 화면에 상응하는 모든 프레임을 캡처하여 인코딩을 수행할 수 있다. 그러나 어플리케이션이 동작하는 화면 상에서 프레임간 변화가 크지 않은 경우에는 이전 프레임과 비교하여 변화된 프레임의 변화 영역만을 캡처하여 스틸 이미지 인코딩을 수행하고, 사용자의 단말 장치에 디스플레이 할 때 변화 영역을 제외한 부분은 동일하게 보여주고 변화 영역만 변화를 주는 방식으로 디스플레이 할 수 있다.In addition, the video codec-based cloud streaming technique can perform encoding by capturing all frames corresponding to the screen on which the application operates. However, if the frame-to-frame change is not significant on the screen on which the application is running, the still image encoding is performed by capturing only the change area of the frame that has changed compared to the previous frame, and the portion except the change area is the same when displayed on the user's terminal device. It can be displayed in such a way that only the change area changes.

이 때, 프레임 화면의 이전 프레임 화면과 적어도 하나의 분할 영역을 비교하여 적어도 하나의 분할 영역 별로 변화된 부분을 적어도 하나의 이미지로 캡처할 수 있다. In this case, by comparing the previous frame screen of the frame screen with at least one divided area, the changed portion for each at least one divided area may be captured as at least one image.

예를 들어, 프레임 화면을 알파 레벨에 따라 제1 영역과 제2 영역으로 분할하였다고 가정할 수 있다. 이 때, 제1 영역을 이전 프레임 화면과 비교하였을 때 제1 영역에서 변화된 부분이 있다면, 해당 부분을 제1 영역의 이미지로 캡처할 수 있다. 또한, 제2 영역을 이전 프레임 화면과 비교하였을 때 제2 영역에서 변화된 부분이 있다면, 해당 부분을 제2 영역의 이미지로 캡처할 수 있다.For example, it may be assumed that the frame screen is divided into a first area and a second area according to the alpha level. In this case, if there is a changed part in the first region when the first region is compared with the previous frame screen, the corresponding part may be captured as an image of the first region. Also, if there is a changed part in the second region when the second region is compared with the previous frame screen, the corresponding part may be captured as an image of the second region.

또한, 사용자의 단말로 전송될 프레임 전체 구간 중 프레임 변화가 적은 구간을 검출하고, 프레임 변화가 적은 구간에서 프레임들을 비교하여 이미지를 캡처할 수 있다.Also, it is possible to detect a section in which the frame change is small among the entire frame to be transmitted to the user's terminal, and compare the frames in the section in which the frame change is small to capture an image.

이 때, 사용자의 단말에서 발생하는 어플리케이션의 이벤트 유형을 감지하여 프레임 변화가 적은 구간을 검출할 수 있다. 예를 들어, 사용자의 단말에서 발생하는 입력신호에 따라 어플리케이션의 이벤트 유형이 결정될 수 있다. 입력신호에 따라 메뉴, 옵션, 안내 창과 같이 어플리케이션을 실행하였을 때 프레임의 변화가 적은 정적인 이벤트 또는 동영상 재생 및 게임 플레이와 같이 프레임이 자주 변하는 동적인 이벤트가 발생할 수 있다. 따라서, 사용자가 단말을 통해 발생시키는 입력신호로 이벤트 유형을 감지하고, 이벤트 유형이 정적인 이벤트라면, 해당 이벤트에 상응하는 프레임 전체 구간 중 프레임 변화가 적은 구간을 검출할 수 있다.In this case, it is possible to detect a section in which the frame change is small by detecting the event type of the application that occurs in the user's terminal. For example, an event type of an application may be determined according to an input signal generated from a user's terminal. Depending on the input signal, when an application is executed, such as a menu, an option, or a guide window, a static event with a small frame change or a dynamic event with a frequent frame change such as video playback and game play may occur. Accordingly, if the user detects an event type with an input signal generated through the terminal and the event type is a static event, it is possible to detect a section in which the frame change is small among the entire frame section corresponding to the event.

또한, 본 발명의 일실시예에 따른 알파 레벨을 이용한 이미지 클라우드 스트리밍 서비스 방법은 알파 레벨에 기반하여 스틸 이미지 인코딩 기법을 선택하고, 선택된 스틸 이미지 인코딩 기법으로 적어도 하나의 이미지를 스틸 이미지 인코딩한다(S730).In addition, the image cloud streaming service method using an alpha level according to an embodiment of the present invention selects a still image encoding method based on the alpha level and encodes at least one image using the selected still image encoding method (S730). ).

이 때, 적어도 하나의 이미지가 제1 영역에서 캡처된 경우에 JPEG 스틸 이미지 인코딩 기법으로 스틸 이미지 인코딩을 수행하고, 적어도 하나의 이미지가 제2 영역에서 캡처된 경우에 PNG 스틸 이미지 인코딩 기법으로 스틸 이미지 인코딩을 수행할 수 있다. At this time, still image encoding is performed using the JPEG still image encoding technique when at least one image is captured in the first area, and still image encoding is performed using the PNG still image encoding technique when at least one image is captured in the second area. encoding can be performed.

즉, 이미지의 알파 레벨이 제1 레벨로, 알파 값이 255에 상응하는 경우에는 자연스러운 이미지 특성을 살릴 수 있도록 JPEG 스틸 이미지 인코딩 기법으로 이미지를 스틸 이미지 인코딩 할 수 있다.That is, when the alpha level of the image corresponds to the first level and the alpha value corresponds to 255, the image may be encoded as a still image using the JPEG still image encoding technique to preserve natural image characteristics.

이 때, JPEG 스틸 이미지 인코딩 기법은 압축 효율이 좋아서 인코딩 시 전송 데이터 량을 대폭 줄일 수 있으나, 압축 효율이 큰 만큼 인코딩 및 디코딩을 수행할 때 시스템 부하를 많이 발생시킬 수 있다.In this case, since the JPEG still image encoding technique has good compression efficiency, it is possible to significantly reduce the amount of transmitted data during encoding.

또한, 이미지의 알파 레벨이 제2 레벨로, 알파 값이 128을 기준으로 기설정된 범위 내에 포함되는 경우에는 PNG 스틸 이미지 인코딩 기법으로 이미지를 스틸 이미지 인코딩 할 수 있다.Also, when the alpha level of the image is the second level and the alpha value is within a preset range based on 128, the still image may be encoded using the PNG still image encoding technique.

이 때, PNG 스틸 이미지 인코딩 기법은 인코딩 시 이미지의 화질은 좋으나 데이터의 크기가 커져서 전송망의 대역폭이 낮은 경우에는 전송 속도가 저하될 수 있다.In this case, the PNG still image encoding technique has good image quality during encoding, but the transmission speed may be lowered when the bandwidth of the transmission network is low due to the large data size.

이 때, 적어도 하나의 이미지가 제3 영역에서 캡처된 경우에 스틸 이미지 인코딩을 수행하지 않을 수 있다. 즉, 이미지의 알파 레벨이 제3 레벨로, 알파 값이 0에 상응하는 투명한 영역인 경우에는 별도로 스틸 이미지 인코딩을 수행하지 않고 개별적으로 처리할 수 있다.In this case, when at least one image is captured in the third area, still image encoding may not be performed. That is, when the alpha level of the image is the third level and the alpha value is a transparent area corresponding to 0, it is possible to individually process the still image without separately encoding the still image.

또한, 본 발명의 일실시예에 따른 알파 레벨을 이용한 이미지 클라우드 스트리밍 서비스 방법은 스틸 이미지 인코딩된 적어도 하나의 이미지를 단말로 전송한다(S740).In addition, the image cloud streaming service method using the alpha level according to an embodiment of the present invention transmits at least one still image-encoded image to the terminal (S740).

이 때, 스틸 이미지 인코딩을 완료하고, 스틸 이미지 인코딩된 이미지를 사용자의 단말로 전송함으로써, 사용자가 단말에서 어플리케이션을 실행되는 느낌을 받을 수 있도록 이미지 기반의 클라우드 스트리밍 서비스를 제공할 수 있다.In this case, by completing still image encoding and transmitting the still image encoded image to the user's terminal, an image-based cloud streaming service can be provided so that the user can feel that the application is running on the terminal.

또한, 도 7에는 도시하지 아니하였으나, 본 발명의 일실시예에 따른 알파 레벨을 이용한 이미지 클라우드 스트리밍 서비스 방법은 도 1에 도시된 네트워크와 같은 통신망을 통해 다수의 단말들과 관련된 정보를 송수신 한다. 특히, 클라우드 스트리밍 서비스에 대한 요청을 단말로부터 수신하고, 단말이 요청한 클라우드 스트리밍 서비스에 상응하는 어플리케이션의 실행화면을 단말로 제공할 수 있다.In addition, although not shown in FIG. 7 , the image cloud streaming service method using the alpha level according to an embodiment of the present invention transmits and receives information related to a plurality of terminals through a communication network such as the network shown in FIG. 1 . In particular, it is possible to receive a request for a cloud streaming service from the terminal, and provide an execution screen of an application corresponding to the cloud streaming service requested by the terminal to the terminal.

이 때, 단말이 요청한 클라우드 스트리밍 서비스에 대해서 클라우드 스트리밍 서버로부터 어플리케이션 실행화면을 수신할 수 있다.At this time, it is possible to receive the application execution screen from the cloud streaming server for the cloud streaming service requested by the terminal.

또한, 도 7에는 도시하지 아니하였으나, 본 발명의 일실시예에 따른 알파 레벨을 이용한 이미지 클라우드 스트리밍 서비스 방법은 상술한 바와 같이 본 발명의 실시예에 따른 클라우드 스트리밍 서비스 과정에서 발생되는 다양한 정보를 저장한다.In addition, although not shown in FIG. 7, the image cloud streaming service method using the alpha level according to an embodiment of the present invention stores various information generated in the process of the cloud streaming service according to the embodiment of the present invention as described above. do.

실시예에 따라, 저장 모듈은 클라우드 스트리밍 서버와 독립적으로 구성되어 클라우드 스트리밍 서비스를 위한 기능을 지원할 수 있다. 이 때, 저장 모듈은 별도의 대용량 스토리지로 동작할 수 있고, 동작 수행을 위한 제어 기능을 포함할 수 있다.According to an embodiment, the storage module may be configured independently of a cloud streaming server to support a function for a cloud streaming service. In this case, the storage module may operate as a separate mass storage and may include a control function for performing the operation.

또한, 상술한 이미지 클라우드 스트리밍 서비스 방법을 수행하는 클라우드 스트리밍 서버는 하나 이상의 서버로 구현될 수 있다.In addition, the cloud streaming server performing the above-described image cloud streaming service method may be implemented as one or more servers.

한편, 클라우드 스트리밍 서버는 메모리가 탑재되어 그 장치 내에서 정보를 저장할 수 있다. 일 구현예의 경우, 메모리는 컴퓨터로 판독 가능한 매체이다. 일 구현 예에서, 메모리는 휘발성 메모리 유닛일 수 있으며, 다른 구현예의 경우, 메모리는 비휘발성 메모리 유닛일 수도 있다. 일 구현예의 경우, 저장장치는 컴퓨터로 판독 가능한 매체이다. 다양한 서로 다른 구현 예에서, 저장장치는 예컨대 하드디스크 장치, 광학디스크 장치, 혹은 어떤 다른 대용량 저장장치를 포함할 수도 있다.On the other hand, the cloud streaming server is equipped with a memory can store information in the device. In one implementation, the memory is a computer-readable medium. In one implementation, the memory may be a volatile memory unit, and in another implementation, the memory may be a non-volatile memory unit. In one embodiment, the storage device is a computer-readable medium. In various different implementations, the storage device may include, for example, a hard disk device, an optical disk device, or some other mass storage device.

이와 같은 이미지 기반의 클라우드 스트리밍 서비스 방법을 통해 클라우드 스트리밍 서비스를 제공함으로써, 이미지 기반의 클라우드 스트리밍 서비스 시 알파 레벨 별로 캡처된 이미지를 적합한 스틸 이미지 인코딩 기법으로 자연스럽고 효율적이게 처리할 수 있다.By providing a cloud streaming service through such an image-based cloud streaming service method, images captured for each alpha level in an image-based cloud streaming service can be naturally and efficiently processed with an appropriate still image encoding technique.

또한, 본 발명의 목적은 캡처 단계에서 인코딩 방식에 따라 이미지가 분할됨으로써 인코딩 시 해당 이미지의 속성을 파악하기 위해 컬러 수를 카운트 하는 등의 부가처리를 생략하도록 할 수 있다.In addition, it is an object of the present invention to omit additional processing such as counting the number of colors in order to understand the properties of the image during encoding by dividing the image according to the encoding method in the capture step.

또한, 본 발명의 목적은 사용자 단말에서 프레임의 변화된 이미지만을 렌더링하여 디스플레이 하도록 함으로써 사용자 단말의 성능이 낮더라도 클라우드 스트리밍 서비스를 원활하게 제공할 수 있다.In addition, an object of the present invention is to render and display only the changed image of the frame in the user terminal, so that the cloud streaming service can be smoothly provided even if the performance of the user terminal is low.

도 8은 본 발명의 일실시예에 따른 알파 레벨을 이용한 이미지 클라우드 스트리밍 서비스 방법에서 프레임 화면을 분할하는 방법을 상세하게 나타낸 동작 흐름도이다.8 is a detailed operation flowchart illustrating a method of dividing a frame screen in an image cloud streaming service method using an alpha level according to an embodiment of the present invention.

도 8을 참조하면, 본 발명의 일실시예에 따른 알파 레벨을 이용한 이미지 클라우드 스트리밍 서비스 방법에서 프레임 화면을 분할하는 방법은 먼저 프레임 화면에 상응하는 영역의 알파 레벨을 체크한다(S810).Referring to FIG. 8 , in the method of dividing a frame screen in the image cloud streaming service method using an alpha level according to an embodiment of the present invention, first, an alpha level of a region corresponding to the frame screen is checked ( S810 ).

이 때, 알파 레벨은 해당 영역, 이미지 또는 픽셀의 투명도를 나타내는 레벨에 상응할 수 있다. 예를 들어, 알파 값이 0부터 255까지 나타낸다고 하면, 알파 값이 0인 영역은 투명 영역, 알파 값이 255인 영역은 불투명 영역에 해당할 수 있다. 또한, 알파 값이 0과 255이 사이에 상응하는 경우에는 투명 영역과 불투명 영역의 사이에 해당하며, 알파 값이 128에 근접한 경우 반투명 영역으로 볼 수 있다.In this case, the alpha level may correspond to a level indicating transparency of a corresponding region, image, or pixel. For example, if an alpha value is 0 to 255, an area having an alpha value of 0 may correspond to a transparent area, and an area having an alpha value of 255 may correspond to an opaque area. Also, when the alpha value is between 0 and 255, it corresponds to between the transparent area and the opaque area, and when the alpha value is close to 128, it can be viewed as a semi-transparent area.

이 때, 알파 레벨은 알파 값이 255에 상응하는 제1 레벨, 알파 값이 128을 기준으로 기설정된 범위 내에 포함되는 제2 레벨 및 알파 값이 0에 상응하는 제3 레벨 중 적어도 하나에 상응할 수 있다. In this case, the alpha level may correspond to at least one of a first level having an alpha value of 255, a second level having an alpha value within a preset range based on 128, and a third level having an alpha value of 0. can

이 후, 체크한 영역의 알파 레벨이 제1 레벨에 상응하는지 여부를 판단한다(S815).Thereafter, it is determined whether the alpha level of the checked area corresponds to the first level (S815).

이 때, 각 영역의 픽셀 단위로 알파 레벨을 체크할 수도 있다.In this case, the alpha level may be checked in units of pixels of each area.

단계(S815)의 판단결과 알파 레벨이 제1 레벨에 상응하면, 해당 영역을 제1 영역으로 분할한다(S820).If it is determined in step S815 that the alpha level corresponds to the first level, the corresponding area is divided into the first area (S820).

이 때, 제1 영역으로 분할된 모든 영역을 합쳐서 제1 영역으로 인식할 수 있다.In this case, all regions divided into the first region may be combined and recognized as the first region.

또한, 단계(S815)의 판단결과 알파 레벨이 제1 레벨에 상응하지 않으면, 체크한 영역의 알파 레벨이 제2 레벨에 상응하는지 여부를 판단한다(S825).Also, if it is determined in step S815 that the alpha level does not correspond to the first level, it is determined whether the alpha level of the checked area corresponds to the second level (S825).

단계(S825)의 판단결과 알파 레벨이 제2 레벨에 상응하면, 해당 영역을 제2 영역으로 분할한다(S830).If it is determined in step S825 that the alpha level corresponds to the second level, the corresponding area is divided into a second area (S830).

또한, 단계(S825)의 판단결과 알파 레벨이 제2 레벨에 상응하지 않으면, 해당 영역을 제3 영역으로 분할한다(S840).Also, if it is determined in step S825 that the alpha level does not correspond to the second level, the corresponding area is divided into a third area (S840).

이 때, 적어도 하나의 분할 영역은 알파 레벨이 제1 레벨에 상응하는 제1 영역, 알파 레벨이 제2 레벨에 상응하는 제2 영역 및 알파 레벨이 제3 레벨에 상응하는 제3 영역 중 적어도 하나에 상응할 수 있다.In this case, the at least one divided region is at least one of a first region having an alpha level corresponding to a first level, a second region having an alpha level corresponding to a second level, and a third region having an alpha level corresponding to a third level. can correspond to

이 때, 프레임 화면을 구성하는 픽셀마다 알파 레벨을 체크하여 제1 영역, 제2 영역 및 제3 영역 중 어느 하나로 결정함으로써 적어도 하나의 분할 영역을 생성할 수 있다. 이 때, 렌더링하는 과정에서 프레임 화면을 구성하는 각각의 픽셀마다 컬러를 체크하면서 알파 레벨을 체크할 수 있다.In this case, at least one divided area may be generated by checking the alpha level for each pixel constituting the frame screen and determining one of the first area, the second area, and the third area. In this case, during the rendering process, the alpha level may be checked while checking the color for each pixel constituting the frame screen.

이 때, 제1 영역은 프레임 화면 중 불투명 영역에 상응하고, 제2 영역은 프레임 화면 중 반투명 영역에 상응하고, 제3영역은 프레임 화면 중 투명 영역에 상응할 수 있다. 예를 들어, 어플리케이션 실행화면에서 포스터나 그림과 같은 주요 이미지들은 불투명 영역에 상응할 수 있고, 포스터나 그림에 대한 설명을 포함하는 텍스트 부분은 반투명 영역에 상응할 수 있고, 뒷 배경의 라이브 채널이 항상 보여야 하기 때문에 배경이 투명 영역에 상응할 수 있다.In this case, the first area may correspond to an opaque area of the frame screen, the second area may correspond to a translucent area of the frame screen, and the third area may correspond to a transparent area of the frame screen. For example, in the application execution screen, main images such as a poster or picture may correspond to an opaque area, a text part including a description of the poster or picture may correspond to a translucent area, and a live channel in the background may correspond to an opaque area. Since it should always be visible, the background can correspond to a transparent area.

도 9는 본 발명의 일실시예에 따른 알파 레벨을 이용한 이미지 클라우드 스트리밍 서비스 방법에서 스틸 이미지 인코딩을 수행하는 방법을 상세하게 나타낸 동작 흐름도이다.9 is an operation flowchart illustrating in detail a method of performing still image encoding in an image cloud streaming service method using an alpha level according to an embodiment of the present invention.

도 9를 참조하면, 본 발명의 일실시예에 따른 알파 레벨을 이용한 이미지 클라우드 스트리밍 서비스 방법에서 스틸 이미지 인코딩을 수행하는 방법은 먼저 적어도 하나의 이미지의 알파 레벨을 체크한다(S910).Referring to FIG. 9 , in the method of performing still image encoding in the image cloud streaming service method using the alpha level according to an embodiment of the present invention, first, the alpha level of at least one image is checked ( S910 ).

이 때, 알파 레벨에 따라서 적어도 하나의 이미지를 스틸 이미지 인코딩하기 위한 스틸 이미지 인코딩 기법을 선택할 수 있다.In this case, a still image encoding technique for encoding at least one image as a still image may be selected according to the alpha level.

이 때, 알파 레벨에 따른 스틸 이미지 인코딩 기법을 이용하여 스틸 이미지 인코딩을 수행함으로써 이미지를 보다 효율적이고 자연스럽게 스틸 이미지 인코딩하는 것이 가능할 수 있다.In this case, it may be possible to encode the still image more efficiently and naturally by performing still image encoding using the still image encoding technique according to the alpha level.

이 후, 적어도 하나의 이미지의 알파 레벨이 제1 레벨에 상응하는지 여부를 판단한다(S915).Thereafter, it is determined whether the alpha level of the at least one image corresponds to the first level (S915).

이 때, 제1 레벨은 알파 값이 255에 상응할 수 있다.In this case, the first level may have an alpha value of 255.

단계(S915)의 판단결과 적어도 하나의 이미지의 알파 레벨이 제1 레벨이면, JPEG 스틸 이미지 인코딩 기법으로 적어도 하나의 이미지를 스틸 이미지 인코딩한다(S920).If it is determined in step S915 that the alpha level of the at least one image is the first level, the at least one image is still image-encoded using the JPEG still image encoding technique (S920).

이 때, JPEG 스틸 이미지 인코딩 기법은 압축 효율이 좋아서 인코딩 시 전송 데이터 량을 대폭 줄일 수 있으나, 압축 효율이 큰 만큼 인코딩 및 디코딩을 수행할 때 시스템 부하를 많이 발생시킬 수 있다.In this case, since the JPEG still image encoding technique has good compression efficiency, it is possible to significantly reduce the amount of transmitted data during encoding.

또한, 단계(S915)의 판단결과 적어도 하나의 이미지의 알파 레벨이 제1 레벨이 아니면, 적어도 하나의 이미지의 알파 레벨이 제2 레벨에 상응하는지 여부를 판단한다(S925).Also, if it is determined in step S915 that the alpha level of the at least one image is not the first level, it is determined whether the alpha level of the at least one image corresponds to the second level (S925).

이 때, 제2 레벨은 알파 값이 128을 기준으로 기설정된 범위 내에 포함될 수 있다.In this case, the second level may include an alpha value within a preset range based on 128.

단계(S925)의 판단결과 적어도 하나의 이미지의 알파 레벨이 제2 레벨이면, PNG 스틸 이미지 인코딩 기법으로 적어도 하나의 이미지를 스틸 이미지 인코딩한다(S930).If it is determined in step S925 that the alpha level of the at least one image is the second level, the still image is encoded using the PNG still image encoding technique (S930).

이 때, PNG 스틸 이미지 인코딩 기법은 인코딩 시 이미지의 화질은 좋으나 데이터의 크기가 커져서 전송망의 대역폭이 낮은 경우에는 전송 속도가 저하될 수 있다.In this case, the PNG still image encoding technique has good image quality during encoding, but the transmission speed may be lowered when the bandwidth of the transmission network is low due to the large data size.

또한, 단계(S925)의 판단결과 적어도 하나의 이미지의 알파 레벨이 제2 레벨이 아니면, 적어도 하나의 이미지의 알파 레벨이 제3 레벨에 상응하는 것으로 판단하고 적어도 하나의 이미지를 개별처리 한다(S940).In addition, if it is determined in step S925 that the alpha level of at least one image is not the second level, it is determined that the alpha level of at least one image corresponds to the third level and the at least one image is individually processed (S940). ).

이 때, 제3 레벨은 알파 값이 0에 상응할 수 있다. 즉, 투명 영역에 해당하는 배경 이미지로 스틸 이미지 인코딩 기법을 사용하지 않고 별도로 개별 처리하여 서비스할 수 있다.In this case, the third level may have an alpha value of 0. That is, the background image corresponding to the transparent area can be individually processed and serviced without using a still image encoding technique.

도 10은 본 발명의 다른 실시예에 따른 알파 레벨을 이용한 이미지 클라우드 스트리밍 서비스 방법에서 스틸 이미지 인코딩을 수행하는 방법을 상세하게 나타낸 동작 흐름도이다.10 is a detailed operation flowchart illustrating a method of performing still image encoding in an image cloud streaming service method using an alpha level according to another embodiment of the present invention.

도 10을 참조하면, 본 발명의 다른 실시예에 따른 알파 레벨을 이용한 이미지 클라우드 스트리밍 서비스 방법에서 스틸 이미지 인코딩을 수행하는 방법은 먼저 적어도 하나의 이미지를 캡처한 분할 영역을 체크한다(S1010).Referring to FIG. 10 , in the method of performing still image encoding in the image cloud streaming service method using the alpha level according to another embodiment of the present invention, first, a divided region in which at least one image is captured is checked ( S1010 ).

이 때, 분할 영역을 체크함으로써 자연스럽게 알파 레벨을 확인할 수 있기 때문에, 분할 영역만으로도 적어도 하나의 이미지를 스틸 이미지 인코딩하기 위한 스틸 이미지 인코딩 기법을 선택할 수 있다.In this case, since the alpha level can be naturally checked by checking the divided region, a still image encoding technique for encoding at least one image as a still image can be selected using only the divided region.

따라서, 분할 영역에 따른 스틸 이미지 인코딩 기법을 이용하여 스틸 이미지 인코딩을 수행함으로써 이미지를 보다 효율적이고 자연스럽게 스틸 이미지 인코딩하는 것이 가능할 수 있다.Accordingly, it may be possible to more efficiently and naturally encode an image by performing still image encoding using a still image encoding technique according to a divided region.

이 후, 적어도 하나의 이미지를 캡처한 분할 영역이 제1 영역에 상응하는지 여부를 판단한다(S1015).Thereafter, it is determined whether the divided area in which at least one image is captured corresponds to the first area (S1015).

이 때, 제1 영역의 알파 레벨은 제1 레벨에 상응할 수 있다.In this case, the alpha level of the first region may correspond to the first level.

단계(S1015)의 판단결과 적어도 하나의 이미지를 캡처한 분할 영역이 제1 영역이면, JPEG 스틸 이미지 인코딩 기법으로 적어도 하나의 이미지를 스틸 이미지 인코딩한다(S1020).If it is determined in step S1015 that the divided region in which the at least one image is captured is the first region, the at least one image is still image-encoded using the JPEG still image encoding technique (S1020).

이 때, JPEG 스틸 이미지 인코딩 기법은 압축 효율이 좋아서 인코딩 시 전송 데이터 량을 대폭 줄일 수 있으나, 압축 효율이 큰 만큼 인코딩 및 디코딩을 수행할 때 시스템 부하를 많이 발생시킬 수 있다.In this case, since the JPEG still image encoding technique has good compression efficiency, it is possible to significantly reduce the amount of transmitted data during encoding.

또한, 단계(S1015)의 판단결과 적어도 하나의 이미지를 캡처한 분할 영역이 제1 영역이 아니면, 적어도 하나의 이미지를 캡처한 영역이 제2 영역에 상응하는지 여부를 판단한다(S1025).Also, if it is determined in step S1015 that the divided area in which at least one image is captured is not the first area, it is determined whether the area in which at least one image is captured corresponds to the second area (S1025).

이 때, 제2 영역의 알파 레벨은 제2 레벨에 상응할 수 있다.In this case, the alpha level of the second region may correspond to the second level.

단계(S1025)의 판단결과 적어도 하나의 이미지를 캡처한 분할 영역이 제2 영역이면, PNG 스틸 이미지 인코딩 기법으로 적어도 하나의 이미지를 스틸 이미지 인코딩한다(S1030).If it is determined in step S1025 that the divided region in which the at least one image is captured is the second region, the at least one image is still image-encoded using the PNG still image encoding technique (S1030).

이 때, PNG 스틸 이미지 인코딩 기법은 인코딩 시 이미지의 화질은 좋으나 데이터의 크기가 커져서 전송망의 대역폭이 낮은 경우에는 전송 속도가 저하될 수 있다.In this case, the PNG still image encoding technique has good image quality during encoding, but the transmission speed may be lowered when the bandwidth of the transmission network is low due to the large data size.

또한, 단계(S1025)의 판단결과 적어도 하나의 이미지를 캡처한 분할 영역이 제2 영역이 아니면, 적어도 하나의 이미지를 캡처한 분할 영역이 제3 영역에 상응하는 것으로 판단하고 적어도 하나의 이미지를 개별처리 한다(S1040).In addition, if it is determined in step S1025 that the divided region in which at least one image is captured is not the second region, it is determined that the divided region in which at least one image is captured corresponds to the third region, and the at least one image is individually separated. processing (S1040).

이 때, 제3 영역은 알파 레벨이 제3 레벨에 상응할 수 있다. 즉, 투명 영역에 해당하는 배경 이미지로 스틸 이미지 인코딩 기법을 사용하지 않고 별도로 개별 처리하여 서비스할 수 있다.In this case, the alpha level of the third region may correspond to the third level. That is, the background image corresponding to the transparent area can be individually processed and serviced without using a still image encoding technique.

본 발명에 따른 알파 레벨을 이용한 이미지 클라우드 스트리밍 서비스 방법은 다양한 컴퓨터 수단을 통하여 수행될 수 있는 프로그램 명령 형태로 구현되어 컴퓨터 판독 가능 매체에 기록될 수 있다. 상기 컴퓨터 판독 가능 매체는 프로그램 명령, 데이터 파일, 데이터 구조 등을 단독으로 또는 조합하여 포함할 수 있다. 상기 매체에 기록되는 프로그램 명령은 본 발명을 위하여 특별히 설계되고 구성된 것들이거나 컴퓨터 소프트웨어 당업자에게 공지되어 사용 가능한 것일 수도 있다. 컴퓨터 판독 가능 기록 매체의 예에는 하드 디스크, 플로피 디스크 및 자기 테이프와 같은 자기 매체(magnetic media), CD-ROM, DVD와 같은 광기록 매체(optical media), 플롭티컬 디스크(floptical disk)와 같은 자기-광 매체(magneto-optical media), 및 롬(ROM), 램(RAM), 플래시 메모리 등과 같은 프로그램 명령을 저장하고 수행하도록 특별히 구성된 모든 형태의 하드웨어 장치가 포함된다. 프로그램 명령의 예에는 컴파일러에 의해 만들어지는 것과 같은 기계어 코드뿐만 아니라 인터프리터 등을 사용해서 컴퓨터에 의해서 실행될 수 있는 고급 언어 코드를 포함할 수 있다. 이러한 하드웨어 장치는 본 발명의 동작을 수행하기 위해 하나 이상의 소프트웨어 모듈로서 작동하도록 구성될 수 있으며, 그 역도 마찬가지이다.The image cloud streaming service method using the alpha level according to the present invention may be implemented in the form of a program command that can be executed through various computer means and recorded in a computer readable medium. The computer-readable medium may include program instructions, data files, data structures, etc. alone or in combination. The program instructions recorded on the medium may be specially designed and configured for the present invention, or may be known and available to those skilled in the art of computer software. Examples of the computer-readable recording medium include magnetic media such as hard disks, floppy disks and magnetic tapes, optical media such as CD-ROMs and DVDs, and magnetic such as floppy disks. - Includes magneto-optical media, and any form of hardware device specially configured to store and execute program instructions, such as ROM, RAM, flash memory, and the like. Examples of program instructions may include high-level language codes that can be executed by a computer using an interpreter or the like as well as machine language codes such as those generated by a compiler. Such hardware devices may be configured to operate as one or more software modules to perform the operations of the present invention, and vice versa.

이상에서와 같이 본 발명에 따른 클라우드 스트리밍 서비스 시스템, 알파 레벨을 이용한 이미지 클라우드 스트리밍 서비스 방법 및 이를 위한 장치는 상기한 바와 같이 설명된 실시예들의 구성과 방법이 한정되게 적용될 수 있는 것이 아니라, 상기 실시예들은 다양한 변형이 이루어질 수 있도록 각 실시예들의 전부 또는 일부가 선택적으로 조합되어 구성될 수도 있다.As described above, in the cloud streaming service system according to the present invention, the image cloud streaming service method using the alpha level, and the apparatus for the same, the configuration and method of the embodiments described above are not limitedly applicable, but the above embodiment Examples may be configured by selectively combining all or part of each embodiment so that various modifications can be made.

본 발명에 의하면 어플리케이션 실행화면을 렌더링하고, 알파 레벨을 기반으로 어플리케이션 실행화면에 상응하는 프레임 화면을 적어도 하나의 분할 영역으로 분할하고, 적어도 하나의 분할 영역에서 각각 사용자의 단말로 제공할 적어도 하나의 이미지를 캡처하고, 알파 레벨에 기반하여 스틸 이미지 인코딩 기법을 선택하여 적어도 하나의 이미지를 스틸 이미지 인코딩하고, 스틸 이미지 인코딩된 적어도 하나의 이미지를 사용자의 단말로 전송할 수 있다. 나아가, 이미지 기반의 클라우드 스트리밍 서비스 시 알파 레벨에 따라 스틸 이미지 인코딩을 수행함으로써 보다 효과적이고 자연스러운 이미지를 사용자에게 제공하는 것이 가능하다.According to the present invention, the application execution screen is rendered, the frame screen corresponding to the application execution screen is divided into at least one divided area based on the alpha level, and at least one or more to be provided to the user's terminal in the at least one divided area, respectively. The image may be captured, and at least one still image may be encoded by selecting a still image encoding technique based on the alpha level, and the at least one still image-encoded image may be transmitted to the user's terminal. Furthermore, in the case of an image-based cloud streaming service, it is possible to provide a more effective and natural image to the user by performing still image encoding according to the alpha level.

110: 클라우드 스트리밍 서버 120-1~ 120-N: 단말
130: 네트워크 210: 통신부
220: 프레임 분할부 230: 캡처부
240: 인코딩부 250: 스트리밍부
260: 저장부 310, 620: 현재 프레임
320: 다음 프레임 311, 312, 321, 322: 제1 영역
313. 323: 제2 영역 410, 510: 불투명 영역
420, 520: 반투명 영역 530: 투명 영역
610: 이전 프레임
110: cloud streaming server 120-1~ 120-N: terminal
130: network 210: communication unit
220: frame division unit 230: capture unit
240: encoding unit 250: streaming unit
260: storage unit 310, 620: current frame
320: next frame 311, 312, 321, 322: first area
313. 323: second area 410, 510: opaque area
420, 520: semi-transparent area 530: transparent area
610: previous frame

Claims (10)

어플리케이션 실행화면을 렌더링하고, 알파 레벨을 기반으로 어플리케이션 실행화면에 상응하는 프레임 화면을 적어도 하나의 분할 영역으로 분할하는 프레임 분할부;
상기 적어도 하나의 분할 영역에서 각각 사용자의 단말로 제공할 적어도 하나의 이미지를 캡처하는 캡처부;
상기 알파 레벨에 기반하여 스틸 이미지 인코딩 기법을 선택하고, 선택된 스틸 이미지 인코딩 기법으로 상기 적어도 하나의 이미지를 스틸 이미지 인코딩하는 인코딩부; 및
스틸 이미지 인코딩된 상기 적어도 하나의 이미지를 상기 단말로 전송하는 스트리밍부
를 포함하고,
상기 적어도 하나의 분할 영역은
불투명 영역에 상응하는 제1 영역, 반투명 영역에 상응하는 제2 영역 및 투명 영역에 상응하는 제3 영역 중 적어도 하나에 상응하는 것을 특징으로 하는 클라우드 스트리밍 서버.
a frame divider for rendering the application execution screen and dividing a frame screen corresponding to the application execution screen into at least one divided area based on the alpha level;
a capture unit configured to capture at least one image to be provided to a user's terminal in each of the at least one divided area;
an encoding unit that selects a still image encoding method based on the alpha level and encodes the at least one image using the selected still image encoding method; and
Streaming unit for transmitting the still image-encoded at least one image to the terminal
including,
The at least one partitioned area is
Cloud streaming server, characterized in that it corresponds to at least one of a first region corresponding to an opaque region, a second region corresponding to a translucent region, and a third region corresponding to a transparent region.
청구항 1에 있어서,
상기 적어도 하나의 분할 영역은
상기 알파 레벨이 제1 레벨에 상응하는 제1 영역, 상기 알파 레벨이 제2 레벨에 상응하는 제2 영역 및 상기 알파 레벨이 제3 레벨에 상응하는 제3 영역 중 적어도 하나에 상응하는 것을 특징으로 하는 클라우드 스트리밍 서버.
The method according to claim 1,
The at least one partitioned area is
wherein the alpha level corresponds to at least one of a first region corresponding to a first level, a second region having the alpha level corresponding to a second level, and a third region having the alpha level corresponding to a third level. cloud streaming server.
청구항 2에 있어서,
상기 알파 레벨은
알파 값이 255에 상응하는 상기 제1 레벨, 상기 알파 값이 128을 기준으로 기설정된 범위 내에 포함되는 상기 제2 레벨 및 상기 알파 값이 0에 상응하는 제3 레벨 중 적어도 하나에 상응하는 것을 특징으로 하는 클라우드 스트리밍 서버.
3. The method according to claim 2,
The alpha level is
The alpha value corresponds to at least one of the first level corresponding to 255, the second level including the alpha value within a preset range based on 128, and a third level corresponding to 0 Cloud streaming server with
삭제delete 삭제delete 삭제delete 삭제delete 어플리케이션 실행화면을 렌더링하고, 알파 레벨을 기반으로 어플리케이션 실행화면에 상응하는 프레임 화면을 적어도 하나의 분할 영역으로 분할하는 단계;
상기 적어도 하나의 분할 영역에서 각각 사용자의 단말로 제공할 적어도 하나의 이미지를 캡처하는 단계;
상기 알파 레벨에 기반하여 스틸 이미지 인코딩 기법을 선택하고, 선택된 스틸 이미지 인코딩 기법으로 상기 적어도 하나의 이미지를 스틸 이미지 인코딩하는 단계; 및
스틸 이미지 인코딩된 상기 적어도 하나의 이미지를 상기 단말로 전송하는 단계
를 포함하고,
상기 적어도 하나의 분할 영역은
불투명 영역에 상응하는 제1 영역, 반투명 영역에 상응하는 제2 영역 및 투명 영역에 상응하는 제3 영역 중 적어도 하나에 상응하는 것을 특징으로 하는 알파 레벨을 이용한 클라우드 스트리밍 서비스 방법.
rendering the application execution screen, and dividing a frame screen corresponding to the application execution screen into at least one divided area based on the alpha level;
capturing at least one image to be provided to each user's terminal in the at least one divided area;
selecting a still image encoding technique based on the alpha level, and still image encoding the at least one image using the selected still image encoding technique; and
Transmitting the at least one still image-encoded image to the terminal
including,
The at least one partitioned area is
A cloud streaming service method using an alpha level, characterized in that it corresponds to at least one of a first region corresponding to an opaque region, a second region corresponding to a translucent region, and a third region corresponding to a transparent region.
삭제delete 삭제delete
KR1020150117789A 2015-05-07 2015-08-21 System for cloud streaming service, method of image cloud streaming service using alpha level of color bit and apparatus for the same KR102409033B1 (en)

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
KR1020150063887 2015-05-07
KR20150063887 2015-05-07

Publications (2)

Publication Number Publication Date
KR20160131827A KR20160131827A (en) 2016-11-16
KR102409033B1 true KR102409033B1 (en) 2022-06-16

Family

ID=57540821

Family Applications (1)

Application Number Title Priority Date Filing Date
KR1020150117789A KR102409033B1 (en) 2015-05-07 2015-08-21 System for cloud streaming service, method of image cloud streaming service using alpha level of color bit and apparatus for the same

Country Status (1)

Country Link
KR (1) KR102409033B1 (en)

Families Citing this family (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN111047676B (en) * 2018-10-12 2023-04-25 中国移动通信集团广西有限公司 Image rendering method, device and storage medium
KR102429225B1 (en) * 2020-11-20 2022-08-04 주식회사 이알마인드 Method and device for transmitting remote screens
CN114022590B (en) * 2020-12-30 2023-03-24 万翼科技有限公司 Picture rendering method and related equipment

Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2003087572A (en) * 2001-09-14 2003-03-20 Akuseru:Kk Method and device for compressing image, image compression program and image processor
US20130155075A1 (en) * 2011-12-15 2013-06-20 Fujitsu Limited Information processing device, image transmission method, and recording medium

Family Cites Families (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR20150065069A (en) 2013-12-04 2015-06-12 삼성전자주식회사 Display apparatus, method for displaying image thereof and computer-readable recording medium

Patent Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2003087572A (en) * 2001-09-14 2003-03-20 Akuseru:Kk Method and device for compressing image, image compression program and image processor
US20130155075A1 (en) * 2011-12-15 2013-06-20 Fujitsu Limited Information processing device, image transmission method, and recording medium

Also Published As

Publication number Publication date
KR20160131827A (en) 2016-11-16

Similar Documents

Publication Publication Date Title
CN107209693B (en) Buffer optimization
US10423320B2 (en) Graphical user interface for navigating a video
KR102409033B1 (en) System for cloud streaming service, method of image cloud streaming service using alpha level of color bit and apparatus for the same
KR102398976B1 (en) System for cloud streaming service, method of image cloud streaming service using simultaneous encoding and apparatus for the same
KR101843411B1 (en) System for cloud streaming service, method of image cloud streaming service based on transparency of image and apparatus for the same
KR102346747B1 (en) System for cloud streaming service, method of cloud streaming service of providing multi-view screen based on resize and apparatus for the same
KR102247886B1 (en) System for cloud streaming service, method of cloud streaming service based on type of image and apparatus for the same
KR102407477B1 (en) System for cloud streaming service, method of image cloud streaming service using alpha value of image type and apparatus for the same
JP6420355B2 (en) Cloud streaming-based video data providing method, apparatus and system therefor
KR102177934B1 (en) System for cloud streaming service, method of image cloud streaming service using split of changed image and apparatus for the same
KR102405143B1 (en) System for cloud streaming service, method of image cloud streaming service using reduction of color bit and apparatus for the same
KR102078576B1 (en) Method for cloud streaming service using compression of alpha data and apparatus for the same
KR20210154785A (en) System for cloud streaming service, method of image cloud streaming service using common cache and apparatus for the same
KR102313530B1 (en) System for cloud streaming service, method of image cloud streaming service using split screen and apparatus for the same
KR20220146801A (en) Method, computer device, and computer program for providing high-definition image of region of interest using single stream
RU2690888C2 (en) Method, apparatus and computing device for receiving broadcast content
KR102247887B1 (en) System for cloud streaming service, method of cloud streaming service using source information and apparatus for the same
KR102306889B1 (en) System for cloud streaming service, method of image cloud streaming service using data substitution and apparatus for the same
KR102313531B1 (en) System for cloud streaming service, method of cloud streaming service using single session multi-access and apparatus for the same
KR102442698B1 (en) System for cloud streaming service, method of image cloud streaming service based on detection of change area using operating system massage and apparatus for the same
KR102273145B1 (en) System for cloud streaming service, method of image cloud streaming service using additional encoding and apparatus for the same
KR20160115566A (en) System for cloud streaming service, method of image cloud streaming service using separation of image and text and apparatus for the same
KR102354269B1 (en) System for cloud streaming service, method of image cloud streaming service using property of scene region and method using the same
KR102346748B1 (en) System for cloud streaming service, method of image cloud streaming service using selective server connection and apparatus for the same
US20210377328A1 (en) Method and apparatus for providing cloud streaming service

Legal Events

Date Code Title Description
N231 Notification of change of applicant
E902 Notification of reason for refusal
E701 Decision to grant or registration of patent right