WO2018088592A1 - 클라우드 스트리밍 서비스 시스템, 이미지의 투명도에 기반한 이미지 클라우드 스트리밍 서비스 방법 및 이를 위한 장치 - Google Patents

클라우드 스트리밍 서비스 시스템, 이미지의 투명도에 기반한 이미지 클라우드 스트리밍 서비스 방법 및 이를 위한 장치 Download PDF

Info

Publication number
WO2018088592A1
WO2018088592A1 PCT/KR2016/013018 KR2016013018W WO2018088592A1 WO 2018088592 A1 WO2018088592 A1 WO 2018088592A1 KR 2016013018 W KR2016013018 W KR 2016013018W WO 2018088592 A1 WO2018088592 A1 WO 2018088592A1
Authority
WO
WIPO (PCT)
Prior art keywords
image
transparency
region
still image
cloud streaming
Prior art date
Application number
PCT/KR2016/013018
Other languages
English (en)
French (fr)
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 에스케이테크엑스 주식회사
Priority to PCT/KR2016/013018 priority Critical patent/WO2018088592A1/ko
Publication of WO2018088592A1 publication Critical patent/WO2018088592A1/ko

Links

Images

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N19/00Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
    • 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 or manipulating encoded video stream scene graphs
    • H04N21/2343Processing of video elementary streams, e.g. splicing of video streams or manipulating encoded video stream 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/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

Definitions

  • the present invention relates to an image-based cloud streaming service technology, and in particular, a cloud streaming service system capable of performing an effective encoding by determining a still image encoding technique according to the transparency of an image, an image cloud streaming service method based on the transparency of an image, and It relates to a device for this.
  • the rapid development of the Internet has resulted in a drastic increase in the speed of individual communication, which can be achieved by accessing a remote computer to download or upload large amounts of data, or by using a remote computer control program. It provides an environment where a remote computer can be used as if logged in locally.
  • the application is run on the server, and the running screen is compressed through video encoding and transmitted to the client, and the client plays the transmitted video to produce the effect as if the application is running on its own terminal.
  • Cloud streaming services are in the spotlight.
  • Cloud streaming service is basically applied cloud streaming technique based on video codec.
  • a static screen such as a menu display
  • the entire screen was unnecessarily captured and operated using a video codec. Therefore, there was an inefficient aspect of the system as a whole.
  • Image-based cloud streaming service technology that can perform image encoding is urgent emerging.
  • an object of the present invention is to render and display only the changed image of the frame in the user terminal to smoothly provide a cloud streaming service even if the performance of the user terminal is low.
  • the image dividing unit distinguishes an area corresponding to the image into at least one of an opaque area corresponding to the opacity and a transparent area corresponding to the transparency, and divides the image into a maximum size corresponding to the opaque area.
  • the image may be divided into at least one region corresponding to at least one of an opaque rectangular region and a transparency mixed region except for the opaque rectangular region in the image.
  • the image divider may determine that the transparency is not constant when the alpha values corresponding to each of the plurality of pixels constituting the image are not collective.
  • the transparency checker determines that the transparency corresponds to the opacity when the alpha value corresponds to 255, and determines that the transparency corresponds to the transparency when the alpha value does not correspond to 255. Can be.
  • the streaming unit may encode the opaque rectangular region is a still image encoding using a JPEG still image encoding technique, and the transparency mixed region may be a still image encoding using a PNG still image encoding technique.
  • the streaming unit may encode the opaque region as a still image using the JPEG still image encoding technique, and encode the still region using a palette PNG still image encoding technique.
  • the streaming unit assigns a serial number to each of the at least one region that is still image encoded when the transparency is not constant, and counts the number of images corresponding to the at least one region and the serial number that is still image encoded. At least one area may be transmitted to the terminal.
  • the terminal may perform rendering after receiving all of the at least one region that is still image encoded based on at least one of the number of images and the serial number.
  • the terminal may perform hardware decoding at the chipset level in the still image encoded region of the at least one region by the JPEG still image encoding technique.
  • the image cloud streaming service method based on the transparency of the image comprises the steps of capturing an image corresponding to the changed area by comparing a plurality of frames corresponding to the application execution screen; Checking the transparency of the image based on an alpha value corresponding to the image; Dividing the image into at least one area based on the transparency when the transparency is not constant; And streaming the at least one region by still image encoding by using a still image encoding technique corresponding to each of the at least one regions, to the user terminal.
  • the dividing may include distinguishing the region corresponding to the image into at least one of an opaque region corresponding to the transparency and an opacity region corresponding to the transparency, and the transparent region corresponding to the transparency.
  • the image may be divided into at least one region corresponding to at least one of a opaque rectangular region having a corresponding maximum size and a transparency mixing region excluding the opaque rectangular region in the image.
  • the dividing may determine that the transparency is not constant when the alpha values corresponding to each of the plurality of pixels constituting the image are not collective.
  • the step of checking transparency determines that the transparency corresponds to the opacity when the alpha value corresponds to 255, and the transparency corresponds to the transparency when the alpha value does not correspond to 255. It can be judged that.
  • the streaming may be performed by encoding the opaque rectangular region using a still image encoding technique using the JPEG still image encoding technique, and encoding the still mixed region using the PNG still image encoding technique.
  • the opaque region may be still image encoded using the JPEG still image encoding technique, and the transparent region may be still image encoded using a palette PNG still image encoding technique.
  • the step of transmitting the streaming may include assigning a serial number to each of the at least one region that is still image encoded when the transparency is not constant, and the number of images corresponding to the at least one region and the serial number. A number may be transmitted to the terminal together with the at least one region that is still image encoded.
  • the terminal may perform rendering after receiving all of the at least one region that is still image encoded based on at least one of the number of images and the serial number.
  • the terminal may perform hardware decoding at the chipset level in the still image encoded region of the at least one region by the JPEG still image encoding technique.
  • the cloud streaming service system compares a plurality of frames corresponding to the application execution screen to capture an image corresponding to the changed area, check the transparency of the image based on the alpha value corresponding to the image If the transparency is not constant, the image is divided into at least one area based on the transparency, and the still image is encoded by the still image encoding technique corresponding to each of the at least one area to generate a user.
  • Cloud streaming server for streaming transmission to the terminal of the; And a terminal that receives and renders all of the at least one region that is still image encoded from the cloud streaming server, and displays the rendered at least one region to the user.
  • the image-based cloud streaming service can be processed quickly and without deterioration of image quality by a suitable still image encoding technique according to the transparency of the image.
  • the still image can be efficiently encoded so that the same region is not processed repeatedly.
  • the present invention renders and displays only the changed image of the frame in the user terminal can smoothly provide a cloud streaming service even if the performance of the user terminal is low.
  • FIG. 1 is a block diagram showing a cloud streaming service system according to an embodiment of the present invention.
  • FIG. 2 is a block diagram illustrating an example of a cloud streaming server of FIG. 1.
  • FIG. 3 is a diagram illustrating an example of a process of dividing an image according to the present invention.
  • FIG. 6 is a diagram illustrating an example of a method of including color information in an image according to a PNG still image encoding technique.
  • FIG. 7 is a diagram illustrating an example of a method of including color information in an image according to a palette PNG still image encoding technique.
  • FIG. 8 is a diagram illustrating an example of a color index generated by a palette PNG still image encoding technique.
  • FIG. 9 is a diagram illustrating an example of a process of detecting an image to be captured by comparing frames according to the present invention.
  • FIG. 10 is a flowchart illustrating an image cloud streaming service method based on transparency of an image according to another exemplary embodiment of the present invention.
  • FIG. 11 is a flowchart illustrating a detailed process of selecting a still image encoding scheme in an image cloud streaming service method based on transparency of an image according to another exemplary embodiment of the present invention.
  • FIG. 1 is a block diagram showing a cloud streaming service system according to an embodiment of the present invention.
  • a cloud streaming service system includes a cloud streaming server 110, terminals 120-1 to 120 -N, and a network 130.
  • the cloud streaming server 110 compares a plurality of frames corresponding to the application execution screen to capture an image corresponding to the changed area.
  • an area having a large change among the plurality of frames may be detected, and an image may be captured by comparing the current frame and the previous frame in the large change area.
  • the cloud streaming server 110 checks the transparency of the image based on the alpha value corresponding to the image.
  • the transparency when the alpha value corresponds to 255, the transparency may be determined to correspond to the opacity, and when the alpha value does not correspond to 255, the transparency may be determined to correspond to the transparency.
  • the cloud streaming server 110 divides the image into at least one region based on the transparency.
  • the area corresponding to the image is distinguished into at least one of an opacity area corresponding to transparency and an transparency area corresponding to transparency, and the image is divided into an opaque rectangle of the maximum size corresponding to the opacity area and an opaque rectangle in the image. It may be divided into at least one region corresponding to one or more of the transparency mixed regions except for the region.
  • the cloud streaming server 110 performs a still image encoding of at least one region by using a still image encoding technique corresponding to each of the at least one region, and transmits the stream to the terminals 120-1 to 120 -N of the user.
  • the opaque rectangular region may be still image encoded by the JPEG still image encoding technique
  • the transparency mixed region may be still image encoded by the PNG still image encoding technique
  • the opaque region when the transparency is constant, the opaque region may be still image encoded by the JPEG still image encoding technique, and the transparent region may be still image encoded by the palette PNG still image encoding technique.
  • the serial number is assigned to each of the still image encoded at least one regions, and the number of images corresponding to the at least one region and the serial number are combined with the at least one region still image encoded.
  • the terminals 120-1 to 120 -N may perform rendering after receiving all of at least one region encoded with a still image based on at least one of the number of images and the serial number.
  • the terminals 120-1 to 120 -N may perform hardware decoding at a chipset level on the still image encoded region of the at least one region using the JPEG still image encoding technique.
  • the terminals 120-1 to 120 -N receive an application execution screen corresponding to a cloud streaming service from the cloud streaming server 110 and provide the same to a user.
  • the terminals 120-1 to 120 -N are devices connected to a communication network to execute an application based on a cloud computing system, and are not limited to mobile communication terminals, but all information communication devices, multimedia terminals, wired terminals, It may be various terminals such as a fixed terminal and an IP (Internet Protocol) terminal.
  • the terminals 120-1 to 120 -N are mobile phones, portable multimedia players (PMPs), mobile internet devices (MIDs), smart phones, desktops, tablet computers, and notebook computers, respectively. 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.
  • PDA personal digital assistant
  • the terminals 120-1 to 120-N receive various information such as numbers and text information, set various functions, and receive signals input in connection with the function control of the terminals 120-1 to 120-N. It can be delivered to the controller through the input unit.
  • the input unit of the terminals 120-1 to 120 -N may include at least one of a keypad and a touch pad that generate an input signal according to a user's touch or manipulation.
  • the input unit of the terminals 120-1 to 120 -N is configured in the form of one touch panel (or touch screen) together with the display unit of the terminals 120-1 to 120 -N.
  • the display function can be performed at the same time.
  • the input unit of the terminals 120-1 to 120 -N may use any type of input means that may be developed in the future.
  • the input unit of the terminal (120-1 ⁇ 120-N) according to the present invention may transmit an input signal for uploading or downloading the content to the control unit of the terminal (120-1 ⁇ 120-N) based on cloud computing.
  • the display unit of the terminals 120-1 to 120 -N may display information on a series of operation states and operation results generated while performing the functions of the terminals 120-1 to 120 -N.
  • the display unit of the terminals 120-1 to 120 -N may display menus of the terminals 120-1 to 120 -N, user data input by the user, and the like.
  • 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).
  • OLED Organic light emitting diode
  • AMOLED Active Matrix OLED
  • Retina display flexible display and flexible display (3 Dimension)
  • the display unit of the terminals 120-1 to 120 -N when 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. Some or all of these may be performed.
  • the display unit of the terminals (120-1 ⁇ 120-N) according to the present invention may display the information related to the execution of the content provided on the cloud computing screen.
  • the storage unit of the terminals (120-1 ⁇ 120-N) is a device for storing data, including a main storage device and an auxiliary storage device, the application required for the functional operation of the terminals (120-1 ⁇ 120-N) You can save the program.
  • the storage unit of the terminals 120-1 to 120 -N may largely include a program area and a data area.
  • the terminals 120-1 to 120 -N activate each function in response to a user's request, the terminals 120-1 to 120 -N execute respective application programs under the control of the controller to provide the respective functions.
  • the storage unit of the terminal (120-1 ⁇ 120-N) can store the operating system for booting the terminal (120-1 ⁇ 120-N), a program for uploading or downloading content based on cloud computing, etc. have.
  • the storage unit of the terminals 120-1 to 120-N may store a content DB storing a plurality of contents and information of the terminals 120-1 to 120-N.
  • the content DB may include execution data for executing the content and attribute information on the content, and content usage information according to the content execution may be stored.
  • the information of the terminals 120-1 to 120 -N may include terminal specification information.
  • the communication unit of the terminal may perform a function for transmitting and receiving data through the cloud streaming server 110 and the network 130.
  • the communication unit of the terminals 120-1 to 120-N may include RF transmission means for up-converting and amplifying the frequency of the transmitted signal, and RF reception means for low-noise-amplifying and down-converting the received signal.
  • 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.
  • 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.
  • the data may be transmitted and received to the cloud streaming server 110 using any one of them.
  • 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 and receive data to and from the cloud streaming server 110. That is, the terminals 120-1 to 120 -N connect to the network 130 by using a wireless communication module or a wired communication module, and transmit and receive data to and from the cloud streaming server 110 through the network 130.
  • 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 necessary for uploading or downloading content on a cloud computing basis.
  • control unit of the terminals 120-1 to 120 -N may be a process unit that drives an operating system (OS) and each component, for example, the control unit may be connected to the cloud streaming server 110.
  • OS operating system
  • the entire process of executing the service application can be controlled according to a user's request, and the cloud streaming is executed at the same time.
  • the server 110 may be controlled to transmit a service use request, and at this time, the terminal 120-1 to 120 -N necessary for user authentication may be transmitted together.
  • the controller of the terminals 120-1 to 120 -N may execute specific content stored in a storage unit of the terminals 120-1 to 120 -N according to a user's request.
  • the controller may store a content usage history according to content execution as content usage information.
  • control unit of the terminal 120-1 ⁇ 120-N
  • the control unit of the terminal is cloud streaming together the execution data for executing the content, the content information including the attribute information for the content, and the content usage information that is information according to the content usage history Transfer to server 110 can be uploaded. Thereafter, the control unit may delete the uploaded content from the storage unit of the terminals 120-1 to 120 -N according to a user's request, and transmit the uploaded content to the cloud streaming server 110, and access the cloud streaming server 110.
  • the content may be executed by using the cloud streaming server 110.
  • control unit of the terminals may be connected to the cloud streaming server 110 to download the content from the other terminal (120-1 ⁇ 120-N) and may be controlled to be stored in the storage unit.
  • the content is executed through the cloud streaming server 110, only the data necessary for execution may be received and then the content may be controlled to be executed.
  • the network 130 provides a passage for transferring data between the cloud streaming server 110 and the terminals 120-1 to 120 -N, and is a concept encompassing both an existing network and a future network.
  • the network 130 is a wired or wireless local area network that provides communication of various information devices within a limited area, a mobile communication network that provides communication between each other and between the mobile and the outside of the mobile, and the communication between the earth station and the earth station using satellites. It may be made of a satellite communication network or a wired or wireless communication network providing a combination of two or more.
  • the transmission 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.
  • the network used between the cloud streaming server 110 and the terminal (120-1 ⁇ 120-N) in Figure 1 may be different from the network used between the terminals (120-1 ⁇ 120-N), It may be the same.
  • FIG. 2 is a block diagram illustrating an example of a cloud streaming server of FIG. 1.
  • the cloud streaming server 110 illustrated in FIG. 1 may include a communication unit 210, a capture unit 220, a transparency checker 230, an image divider 240, a streaming unit 250, and storage.
  • the unit 260 is included.
  • 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.
  • the communication unit 210 may 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.
  • the application execution screen may be received from the cloud streaming server for the cloud streaming service requested by the terminal.
  • the web application server may execute the application in response 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.
  • the capturer 220 compares a plurality of frames corresponding to the application execution screen to capture an image corresponding to the changed area.
  • Cloud streaming service basically uses cloud codec based on video codec. Therefore, even if cloud streaming is applied to static screen such as menu display, it is an inefficient way to capture the entire screen and encode to video codec.
  • the present invention provides a cloud streaming method in which a cloud streaming server detects a change between frames and captures the changed area as an image and then encodes it using a still image compression technique when the change between frames is not large, such as a menu display screen.
  • Provide server 110 provides a cloud streaming method in which a cloud streaming server detects a change between frames and captures the changed area as an image and then encodes it using a still image compression technique when the change between frames is not large, such as a menu display screen.
  • the video codec-based cloud streaming technique may perform encoding by capturing all frames corresponding to a screen on which an application operates. However, if the change between frames is not large on the screen on which the application is running, the still image encoding is performed by capturing only the change area of the changed frame compared to the previous frame, and the parts except for the change area when displaying on the user's terminal device are the same. It can be displayed in such a way that it is displayed in a simple manner and only the change area is changed.
  • the changed image may be captured by comparing the current frame and the previous frame among the frames. For example, when the current frame is compared with the previous frame when the current frame is compared with the previous frame, the changed area of the screen area of the current frame may be captured as an image.
  • the captured image may vary in size or properties depending on an input signal input from the user's terminal.
  • an image having a small frame change may be detected among the entire frame sections to be transmitted to the user terminal, and the image may be captured by comparing the frames in the small frame change section.
  • an event type of an application occurring in the user terminal may be detected to detect a section in which the frame change is small.
  • an event type of an application may be determined according to an input signal generated from a user terminal.
  • an application is executed such as a menu, an option, or a guide window according to an input signal, a static event having a small change in a frame or a dynamic event in which a frame frequently changes such as a video play and a game play may occur. Therefore, when the user detects an event type with an input signal generated through the terminal, and if the event type is a static event, a section having a small frame change can be detected among the entire frame sections corresponding to the corresponding event.
  • the transparency checker 230 checks the transparency of the image based on an alpha value corresponding to the image.
  • an alpha value may be obtained by examining pixel values of a plurality of pixels constituting an image in the process of rendering an application execution screen.
  • the transparency when the alpha value corresponds to 255, the transparency may be determined to correspond to the opacity, and when the alpha value does not correspond to 255, the transparency may be determined to correspond to the transparency. That is, an alpha value may be obtained by checking pixel values of a plurality of pixels constituting a frame of an application execution screen, and transparency may be determined according to the alpha value.
  • the image dividing unit 240 divides the image into at least one area based on the transparency when the transparency is not constant.
  • the image may be divided into at least one region based on the top and bottom of the image, that is, the region having an alpha value of 255 and the region having an alpha value of 100.
  • the area corresponding to the image is distinguished into at least one of an opacity area corresponding to transparency and an transparency area corresponding to transparency, and the image is divided into an opaque rectangle of the maximum size corresponding to the opacity area and an opaque rectangle in the image.
  • One or more of the transparency blending regions excluding the region may be divided into at least one corresponding region.
  • the transparent regions other than the opaque rectangular region and the transparency mixing region may be separately divided among the regions corresponding to the image.
  • the image is first divided into an opaque region and a transparent region, and then divided again from the opaque region to the opaque rectangular region makes it easier for the encoder to perform still image encoding when the shape of the opaque region is polygonal. It may be to figure out. For example, when an image to be still image encoded is a shape corresponding to a rectangle and an irregular shape not corresponding to a specific shape, the encoder may recognize a processing area more quickly when the shape corresponds to a rectangle.
  • the opaque rectangular region may be divided according to the rectangular shape that can be generated at the maximum size in the opaque region, and the remaining opaque regions and the transparent region which are not included in the opaque square region may be recognized together as the transparency mixed region. That is, the opaque rectangular region may be divided such that the opaque region is minimally included in the transparent mixed region.
  • main images such as a poster or a picture on the application execution screen may correspond to an opaque area
  • text portions and a background including a description of the poster or the picture may correspond to a transparent area.
  • the streaming unit 250 performs a still image encoding on at least one region by using a still image encoding technique corresponding to each of the at least one region, and transmits the stream to the user's terminal.
  • the still image encoder according to the still image encoding technique may include an encoder such as PNG that may include an alpha channel indicating transparency, and an encoder without an alpha channel such as JPEG.
  • the opaque rectangular region may be still image encoded by the JPEG still image encoding technique
  • the transparency mixed region may be still image encoded by the PNG still image encoding technique
  • the opaque rectangular area is an image whose alpha value corresponds to 255, it may correspond to most posters or photographs. Accordingly, when the still image is encoded by the JPEG still image encoding technique, a good image quality can be obtained without a larger data size, and the hardware can be decoded at the terminal to increase the response speed.
  • the still image may be encoded using the PNG still image encoding technique so as not to severely degrade the image quality.
  • the JPEG still image encoding technique has a high compression efficiency and can greatly reduce the amount of data transmitted during encoding.
  • the compression efficiency is large, a system load can be generated when encoding and decoding is performed.
  • the image quality is good at the time of encoding, but when the bandwidth of the transmission network is low due to the large data size, the transmission speed may be reduced.
  • the opaque region when the transparency is constant, the opaque region may be still image encoded by the JPEG still image encoding technique, and the transparent region may be still image encoded by the palette PNG still image encoding technique.
  • the transparent area is most likely a combination of text or background, the number of colors in the image may not be many. Therefore, even if the palette PNG still image encoding technique that reduces the data size to one third than the PNG still image encoding technique can be serviced with high compression efficiency without significant deterioration of image quality.
  • the serial number is assigned to each of the still image encoded at least one regions, and the number of images corresponding to the at least one region and the serial number are combined with the at least one region still image encoded. Can be sent to.
  • a serial number may be assigned to the opaque rectangular region as IMG1 and the transparency mixed region as IMG2.
  • the still image-encoded opaque rectangular region and the still image-encoded transparency mixed region are transmitted one by one to the user's terminal, but the number of images may be first transmitted to the terminal to inform that the image is divided into two.
  • the number of images may be first transmitted to the terminal to inform that the image is divided into two.
  • the terminal may perform rendering after receiving all of at least one region encoded with a still image based on at least one of the number of images and the serial number.
  • the divided and empty screens may be processed when the screen changes.
  • the terminal may perform hardware decoding at the chipset level in the still image encoded region of the at least one region using the JPEG still image encoding technique.
  • the decoding response speed may be faster than that of software decoding through a central processing unit of the computer.
  • the storage unit 260 stores various information generated in the cloud streaming service process according to the embodiment of the present invention as described above.
  • the storage unit 260 may be configured independently of the cloud streaming server 110 to support a function for a cloud streaming service. At this time, the storage unit 260 may operate as a separate mass storage, and may include a control function for performing the operation.
  • cloud streaming server 110 configured as described above may be implemented as one or more servers.
  • the cloud streaming server 110 may be equipped with a memory to store information in the device.
  • the memory is a computer readable medium.
  • the memory may be a volatile memory unit, and for other implementations, the memory may be a nonvolatile memory unit.
  • the storage device is a computer readable medium.
  • the storage device may include, for example, a hard disk device, an optical disk device, or some other mass storage device.
  • the cloud streaming service based on the image using the cloud streaming server 110, it may be possible to process quickly and without deterioration of image quality by using a suitable still image encoding technique according to the transparency of the image.
  • the user terminal since the user terminal renders and displays only the changed image of the frame, it is possible to smoothly provide a cloud streaming service even if the performance of the user terminal is low.
  • FIG. 3 is a diagram illustrating an example of a process of dividing an image according to the present invention.
  • an image 310 captured on an application execution screen may be classified into an opaque region 302 and a transparent region 304.
  • the opaque rectangular region 320 is divided according to the rectangular shape that can be generated at the maximum size in the opaque region 302, and the transparent opaque region and the transparent region, which are not included in the opaque rectangular region, are combined with each other. 330). That is, the opaque rectangular region may be divided such that the opaque region 302 is minimally included in the transparent mixed region 330.
  • the image is first divided into an opaque region and a transparent region, and then divided again from the opaque region to the opaque rectangular region makes it easier for the encoder to perform still image encoding when the shape of the opaque region is polygonal. It may be to figure out. For example, when an image to be still image encoded is a shape corresponding to a rectangle and an irregular shape not corresponding to a specific shape, the encoder may recognize a processing area more quickly when the shape corresponds to a rectangle.
  • the transparent regions other than the opaque rectangular region and the transparency mixing region may be separately divided among the regions corresponding to the image.
  • an image 410 captured from an application execution screen includes an area 402 in which an opaque area is emptied together with a transparent area 404, and FIG. 5 is an image of FIG. 4. It can be seen that corresponds to the opaque region 502 divided at 410.
  • the area corresponding to the image 410 of FIG. 4 should be provided to the user terminal after being encoded with a still image.
  • the original image 410 is an efficient still because the opaque area 502 and the transparent area 404 are mixed. There was a difficulty performing the image encoding.
  • the image 410 is divided into an opaque region 502 and a transparent region 404 based on the alpha value of the image 410, and the region corresponding to the largest size square in the opaque region 502. Can be divided.
  • the divided opaque rectangular region may correspond to the opaque region 502 of FIG. 5.
  • the transparent region 404 except for the region 402 in which the opaque region is empty in the image 410 in FIG. 4 performs still image encoding using the palette PNG still image encoding technique
  • the opacity of FIG. Region 502 may perform still image encoding with a JPEG still image encoding technique.
  • serial numbers may be assigned to the still image encoded transparent region 404 and the still image encoded opaque region 502, respectively.
  • the terminal when performing streaming transmission to the terminal, by transmitting the serial number and each serial number of the at least one region generated by dividing the image 410, the terminal can perform rendering after receiving all the images Can be.
  • FIG. 6 is a diagram illustrating an example of a method of including color information in an image according to a PNG still image encoding technique.
  • a color corresponding to R (Red), G (Green), and B (Blue) of the pixel 610 is set by 1 byte, respectively.
  • one pixel 610 may have a data size of 3 bytes, and the entire image may have a data size as long as the number of pixels included in the image is multiplied by a value of 3 bytes.
  • the PNG still image encoding technique may have a data size of 32 bits per pixel, that is, a 4 byte data size.
  • 3 bytes of the 4 bytes may be data of the same RGB color as described above, and the remaining 1 byte may be data for indicating transparency.
  • FIG. 7 is a diagram illustrating an example of a method of including color information in an image according to a palette PNG still image encoding technique.
  • the method of including color information in an image according to a palette PNG still image encoding technique may include corresponding information of a color index in the pixel 710 as 1 byte data. Accordingly, one pixel 710 may have a data size of 1 byte, and the entire image may have a data size as much as the number of pixels included in the image is multiplied by a value of 1 byte.
  • the palette PNG still image encoding technique is called PNG8bit still image encoding technique or indexed PNG still image encoding technique because the data size of one pixel 710 is 1 byte corresponding to 8 bits and the color value is represented through color index. Can be.
  • the cloud streaming server when performing a cloud streaming service, when the cloud streaming server encodes an image by using the pallet PNG still image encoding technique, the data size is one quarter of that of encoding by the PNG still image encoding technique illustrated in FIG. 6. Can be reduced. However, since the number of colors that can be represented by the pixel 710 of the palette PNG still image encoding technique is limited to 1 byte, the image quality of the image may be degraded.
  • FIG. 8 is a diagram illustrating an example of a color index generated by a palette PNG still image encoding technique.
  • the color index 810 generated by the palette PNG still image encoding scheme is 256 bits, which is 8 bits, that is, 8 squared values of 2 since the pixels of the palette PNG still image encoding technique have a data size of 1 byte. It may include color information.
  • the color corresponding to palette number 0 may be a color having a value of Red '0', Green '0', and Blue'0 'in the RGB color code.
  • the color corresponding to palette number 1 and the color corresponding to palette number 2 are the colors of Red '127', Green '127', Blue'127 ', Red' 255 ', It may be a color having values of Green '255' and Blue'255 '.
  • the color index 810 composed of a total of 256 colors using the RGB color code value may be configured based on the colors constituting the captured image by comparing the frames of the application execution screen. For example, if the color constituting the image is a blue series, the color index 810 may include a lot of blue based colors.
  • FIG. 9 is a diagram illustrating an example of a process of detecting an image to be captured by comparing frames according to the present invention.
  • frames of a portion having a small change in a screen may be obtained on an application execution screen according to a user request.
  • the current frame 920 and the previous frame 910 may be compared among the frames of the small change. For example, if the current frame 920 and the previous frame 910 shown in FIG. 9 are compared, there is no change in the A region of the two frames, but the B region of the previous frame 910 is B ′ in the current frame 920. You can see that changed to.
  • the cloud streaming server may check such a change and capture the changed B ′ region as the captured image 930.
  • the captured image 930 includes one area including all the changed areas. Can be recognized and captured. In addition, all of the various changed regions may be recognized as each captured image 930, and a plurality of captured images 930 may be generated to perform an image-based cloud streaming service.
  • FIG. 10 is a flowchart illustrating an image cloud streaming service method based on transparency of an image according to an exemplary embodiment of the present invention.
  • the image cloud streaming service method based on the transparency of an image compares a plurality of frames corresponding to an application execution screen to capture an image corresponding to the changed region (S1010).
  • Cloud streaming service basically uses cloud codec based on video codec. Therefore, even if cloud streaming is applied to static screen such as menu display, it is an inefficient way to capture the entire screen and encode to video codec.
  • the present invention provides a cloud streaming method in which a cloud streaming server detects a change between frames and captures the changed area as an image and then encodes it using a still image compression technique when the change between frames is not large, such as a menu display screen. Provide a server.
  • the video codec-based cloud streaming technique may perform encoding by capturing all frames corresponding to a screen on which an application operates. However, if the change between frames is not large on the screen on which the application is running, the still image encoding is performed by capturing only the change area of the changed frame compared to the previous frame, and the parts except for the change area when displaying on the user's terminal device are the same. It can be displayed in such a way that it is displayed in a simple manner and only the change area is changed.
  • the changed image may be captured by comparing the current frame and the previous frame among the frames. For example, when the current frame is compared with the previous frame when the current frame is compared with the previous frame, the changed area of the screen area of the current frame may be captured as an image.
  • the captured image may vary in size or properties depending on an input signal input from the user's terminal.
  • an image having a small frame change may be detected among the entire frame sections to be transmitted to the user terminal, and the image may be captured by comparing the frames in the small frame change section.
  • an event type of an application occurring in the user terminal may be detected to detect a section in which the frame change is small.
  • an event type of an application may be determined according to an input signal generated from a user terminal.
  • an application is executed such as a menu, an option, or a guide window according to an input signal, a static event having a small change in a frame or a dynamic event in which a frame frequently changes such as a video play and a game play may occur. Therefore, when the user detects an event type with an input signal generated through the terminal, and if the event type is a static event, a section having a small frame change can be detected among the entire frame sections corresponding to the corresponding event.
  • the image cloud streaming service method based on the transparency of the image checks the transparency of the image based on the alpha value corresponding to the image (S1020).
  • an alpha value may be obtained by examining pixel values of a plurality of pixels constituting an image in the process of rendering an application execution screen.
  • the transparency when the alpha value corresponds to 255, the transparency may be determined to correspond to the opacity, and when the alpha value does not correspond to 255, the transparency may be determined to correspond to the transparency. That is, an alpha value may be obtained by checking pixel values of a plurality of pixels constituting a frame of an application execution screen, and transparency may be determined according to the alpha value.
  • the image cloud streaming service method based on the transparency of the image divides the image into at least one area based on the transparency when the transparency is not constant (S1030).
  • the image may be divided into at least one region based on the top and bottom of the image, that is, the region having an alpha value of 255 and the region having an alpha value of 100.
  • the area corresponding to the image is distinguished into at least one of an opacity area corresponding to transparency and an transparency area corresponding to transparency, and the image is divided into an opaque rectangle of the maximum size corresponding to the opacity area and an opaque rectangle in the image.
  • One or more of the transparency blending regions excluding the region may be divided into at least one corresponding region.
  • the transparent regions other than the opaque rectangular region and the transparency mixing region may be separately divided among the regions corresponding to the image.
  • the image is first divided into an opaque region and a transparent region, and then divided again from the opaque region to the opaque rectangular region makes it easier for the encoder to perform still image encoding when the shape of the opaque region is polygonal. It may be to figure out. For example, when an image to be still image encoded is a shape corresponding to a rectangle and an irregular shape not corresponding to a specific shape, the encoder may recognize a processing area more quickly when the shape corresponds to a rectangle.
  • the opaque rectangular region may be divided according to the rectangular shape that can be generated at the maximum size in the opaque region, and the remaining opaque regions and the transparent region which are not included in the opaque square region may be recognized together as the transparency mixed region. That is, the opaque rectangular region may be divided such that the opaque region is minimally included in the transparent mixed region.
  • main images such as a poster or a picture on the application execution screen may correspond to an opaque area
  • text portions and a background including a description of the poster or the picture may correspond to a transparent area.
  • the image cloud streaming service method based on the transparency of the image according to an embodiment of the present invention by using a still image encoding technique corresponding to each of the at least one region to encode the at least one region still streams the transmission to the user terminal (S1040).
  • the still image encoder according to the still image encoding technique may include an encoder such as PNG that may include an alpha channel indicating transparency, and an encoder without an alpha channel such as JPEG.
  • the opaque rectangular region may be still image encoded by the JPEG still image encoding technique
  • the transparency mixed region may be still image encoded by the PNG still image encoding technique
  • the opaque rectangular area is an image whose alpha value corresponds to 255, it may correspond to most posters or photographs. Accordingly, when the still image is encoded by the JPEG still image encoding technique, a good image quality can be obtained without a larger data size, and the hardware can be decoded at the terminal to increase the response speed.
  • the still image may be encoded using the PNG still image encoding technique so as not to severely degrade the image quality.
  • the JPEG still image encoding technique has a high compression efficiency and can greatly reduce the amount of data transmitted during encoding.
  • the compression efficiency is large, a system load can be generated when encoding and decoding is performed.
  • the image quality is good at the time of encoding, but when the bandwidth of the transmission network is low due to the large data size, the transmission speed may be reduced.
  • the opaque region when the transparency is constant, the opaque region may be still image encoded by the JPEG still image encoding technique, and the transparent region may be still image encoded by the palette PNG still image encoding technique.
  • the transparent area is most likely a combination of text or background, the number of colors in the image may not be many. Therefore, even if the palette PNG still image encoding technique that reduces the data size to one third than the PNG still image encoding technique can be serviced with high compression efficiency without significant deterioration of image quality.
  • the serial number is assigned to each of the still image encoded at least one regions, and the number of images corresponding to the at least one region and the serial number are combined with the at least one region still image encoded. Can be sent to.
  • a serial number may be assigned to the opaque rectangular region as IMG1 and the transparency mixed region as IMG2.
  • the still image-encoded opaque rectangular region and the still image-encoded transparency mixed region are transmitted one by one to the user's terminal, but the number of images may be first transmitted to the terminal to inform that the image is divided into two.
  • the number of images may be first transmitted to the terminal to inform that the image is divided into two.
  • the terminal may perform rendering after receiving all of at least one region encoded with a still image based on at least one of the number of images and the serial number.
  • the divided and empty screens may be processed when the screen changes.
  • the terminal may perform hardware decoding at the chipset level in the still image encoded region of the at least one region using the JPEG still image encoding technique.
  • the decoding response speed may be faster than that of software decoding through a central processing unit of the computer.
  • the image cloud streaming service method based on the transparency of an image transmits and receives information related to a plurality of terminals through a communication network such as the network shown in FIG. 1. .
  • the mobile terminal may 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.
  • the application execution screen may be received from the cloud streaming server for the cloud streaming service requested by the terminal.
  • the web application server executes the application in response to the user's request, and transmits 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.
  • the storage module for storing information may be configured independently of the cloud streaming server to support a function for a cloud streaming service.
  • the storage module may operate as a separate mass storage and may include a control function for performing an operation.
  • the user terminal since the user terminal renders and displays only the changed image of the frame, it is possible to smoothly provide a cloud streaming service even if the performance of the user terminal is low.
  • FIG. 11 is a flowchart illustrating a detailed process of selecting a still image encoding scheme in an image cloud streaming service method based on transparency of an image according to an embodiment of the present invention.
  • the process of selecting a still image encoding scheme in the image cloud streaming service method based on the transparency of an image first checks the transparency of the image based on an alpha value of the captured image. (S1110).
  • an alpha value may be obtained by examining pixel values of a plurality of pixels constituting an image in the process of rendering an application execution screen.
  • the image is divided into at least one area including at least one of an opaque rectangular area and a mixed transparency area based on the transparency (S1120).
  • the area corresponding to the image is distinguished into at least one of an opacity area corresponding to transparency and an transparency area corresponding to transparency, and the image is divided into an opaque rectangle of the maximum size corresponding to the opacity area and an opaque rectangle in the image.
  • One or more of the transparency blending regions excluding the region may be divided into at least one corresponding region.
  • the transparent regions other than the opaque rectangular region and the transparency mixing region may be separately divided among the regions corresponding to the image.
  • the image is first divided into an opaque region and a transparent region, and then divided again from the opaque region to the opaque rectangular region makes it easier for the encoder to perform still image encoding when the shape of the opaque region is polygonal. It may be to figure out.
  • the opaque rectangular region may be divided according to the rectangular shape that can be generated at the maximum size in the opaque region, and the remaining opaque regions and the transparent region which are not included in the opaque square region may be recognized together as the transparency mixed region.
  • the opaque rectangular areas are JPEG still image encoding techniques
  • the transparency mixed region is still image encoding using PNG still image encoding techniques (S1130).
  • the opaque rectangular area is an image whose alpha value corresponds to 255, it may correspond to most posters or photographs. Accordingly, when the still image is encoded by the JPEG still image encoding technique, a good image quality can be obtained without a larger data size, and the hardware can be decoded at the terminal to increase the response speed.
  • the still image may be encoded using the PNG still image encoding technique so as not to severely degrade the image quality.
  • step S1115 determines whether the transparency corresponds to the opacity (S1125).
  • the transparency when the alpha value corresponds to 255, the transparency may be determined to correspond to the opacity, and when the alpha value does not correspond to 255, the transparency may be determined to correspond to the transparency.
  • the still image is encoded using the JPEG still image encoding technique (S1140).
  • step S1125 determines whether the transparency is transparent, and the image is still image encoded by the palette PNG still image encoding technique (S1150).
  • the transparent area is most likely a combination of text or background, the number of colors in the image may not be many. Therefore, even if the palette PNG still image encoding technique that reduces the data size to one third than the PNG still image encoding technique can be serviced with high compression efficiency without significant deterioration of image quality.
  • Image cloud streaming service method based on the transparency of the image according to the present invention can be implemented in the form of program instructions that can be executed by various computer means can be recorded on a computer readable medium.
  • the computer readable medium may include program instructions, data files, data structures, etc. alone or in combination.
  • Program instructions recorded on the media may be those specially designed and constructed for the purposes of the present invention, or they may be of the kind well-known and available to those having skill in the computer software arts.
  • Examples of computer-readable recording media include magnetic media such as hard disks, floppy disks, and magnetic tape, optical media such as CD-ROMs, DVDs, and magnetic disks, such as floppy disks.
  • Magneto-optical media and any type of hardware device specifically 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 code that can be executed by a computer using an interpreter as well as machine code such as produced 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.
  • the cloud streaming service system according to the present invention, the image cloud streaming service method based on the transparency of an image, and an apparatus therefor are not limited to the configuration and method of the embodiments described as described above.
  • the embodiments may be configured by selectively combining all or part of the embodiments so that various modifications can be made.
  • a plurality of frames corresponding to an application execution screen are compared to capture an image corresponding to the changed area, the transparency of the image is checked based on an alpha value corresponding to the image, and the transparency when the transparency is not constant.
  • the image may be divided into at least one area, and the still image may be encoded by the still image encoding technique corresponding to each of the at least one area, and may be transmitted to the terminal of the user for streaming. Furthermore, by performing still image encoding according to transparency in the image-based cloud streaming service, it is possible to quickly provide a more effective and high quality image to the user.

Landscapes

  • Engineering & Computer Science (AREA)
  • Multimedia (AREA)
  • Signal Processing (AREA)
  • Compression Or Coding Systems Of Tv Signals (AREA)

Abstract

클라우드 스트리밍 서비스 시스템, 이미지의 투명도에 기반한 이미지 클라우드 스트리밍 서비스 방법 및 이를 위한 장치가 개시된다. 어플리케이션 실행화면에 상응하는 복수개의 프레임들을 비교하여 이미지를 캡처하고, 이미지에 상응하는 알파 값을 기반으로 이미지의 투명도를 체크하고, 투명도가 일정하지 않은 경우에 투명도를 기준으로 이미지를 적어도 하나의 영역으로 분할하고, 적어도 하나의 영역 각각에 상응하는 스틸 이미지 인코딩 기법으로 적어도 하나의 영역을 스틸 이미지 인코딩하여 사용자의 단말로 스트리밍 전송할 수 있다. 이에 따라 이미지 기반의 클라우드 스트리밍 서비스 시 캡처된 이미지를 보다 자연스럽고 효과적으로 인코딩하는 것이 가능하다.

Description

클라우드 스트리밍 서비스 시스템, 이미지의 투명도에 기반한 이미지 클라우드 스트리밍 서비스 방법 및 이를 위한 장치
본 발명은 이미지 기반의 클라우드 스트리밍 서비스 기술에 관한 것으로, 특히 이미지의 투명도에 따라 스틸 이미지 인코딩 기법을 결정하여 효과적인 인코딩을 수행할 수 있는 클라우드 스트리밍 서비스 시스템, 이미지의 투명도에 기반한 이미지 클라우드 스트리밍 서비스 방법 및 이를 위한 장치에 관한 것이다.
인터넷의 급속한 발달은 개인의 통신 속도를 급격히 향상시키는 결과를 가져왔으며, 이러한 통신 속도의 향상은 원격지에 위치한 컴퓨터에 접속하여 대용량의 데이터를 다운로드 또는 업로드 하거나, 원격지 컴퓨터 제어 프로그램을 사용하여 마치 원격지 컴퓨터에 로컬 로그인한 것과 같이 원격지 컴퓨터를 이용할 수 있는 환경을 제공하고 있다.
또한, 스마트폰과 같은 이동통신 단말에서 구동되는 어플리케이션이 다양하게 개발되면서, 비교적 낮은 성능의 사용자 단말에서 높은 성능을 필요로 하는 어플리케이션을 구동하기 위한 가상화 기술들이 많이 제안되고 있다.
그 중에서 어플리케이션을 서버에서 구동시키고 구동화면은 비디오 인코딩(Encoding)을 통해 압축하여 클라이언트로 전송하고, 클라이언트는 전송된 비디오를 재생하여 마치 자신의 단말에서 어플리케이션이 구동되는 것과 같은 효과를 내는 화면 가상화 기반의 클라우드 스트리밍 서비스가 각광받고 있는 추세이다.
클라우드 스트리밍 서비스는 기본적으로 비디오 코덱 기반의 클라우드 스트리밍 기법이 적용되었다. 그러나 메뉴 디스플레이와 같이 정적인 화면을 서비스 하는 경우에도 불필요하게 화면 전체를 캡처하고 비디오 코덱을 이용하여 동작하게 되어 시스템 전체적으로 비효율적인 측면이 존재하였다.
따라서, 사용자 요청에 따라 실행된 어플리케이션의 실행화면에서 정적인 부분의 변화된 이미지만을 캡처하여 사용자의 단말로 제공하되, 이미지의 투명도에 따라서 이미지를 스틸 이미지 인코딩 할 기법을 선택하여 인코딩함으로써 투명도 별로 효율적인 스틸 이미지 인코딩을 수행할 수 있는 이미지 기반의 클라우드 스트리밍 서비스 기술이 절실하게 대두된다.
본 발명의 목적은, 이미지 기반의 클라우드 스트리밍 서비스 시 이미지의 투명도에 따라 적합한 스틸 이미지 인코딩 기법으로 빠르고 화질 열화 없이 처리하는 것이다.
또한, 본 발명의 목적은 이미지의 투명도에 따라 이미지를 분할하여 각각 스틸 이미지 인코딩함으로써, 동일한 영역이 중복적으로 처리되지 않도록 효율적으로 스틸 이미지 인코딩하는 것이다.
또한, 본 발명의 목적은 사용자 단말에서 프레임의 변화된 이미지만을 렌더링하여 디스플레이 하도록 함으로써 사용자 단말의 성능이 낮더라도 클라우드 스트리밍 서비스를 원활하게 제공하는 것이다.
상기한 목적을 달성하기 위한 본 발명에 따른 클라우드 스트리밍 서버는 어플리케이션 실행화면에 상응하는 복수개의 프레임들을 비교하여 변화된 영역에 상응하는 이미지를 캡처하는 캡처부; 상기 이미지에 상응하는 알파 값을 기반으로 상기 이미지의 투명도를 체크하는 투명도 체크부; 상기 투명도가 일정하지 않은 경우에 상기 투명도를 기준으로 상기 이미지를 적어도 하나의 영역으로 분할하는 이미지 분할부; 및 상기 적어도 하나의 영역 각각에 상응하는 스틸 이미지 인코딩 기법으로 상기 적어도 하나의 영역을 스틸 이미지 인코딩하여 사용자의 단말로 스트리밍 전송하는 스트리밍부를 포함한다.
이 때, 이미지 분할부는 상기 이미지에 상응하는 영역을 상기 투명도가 불투명에 상응하는 불투명 영역 및 상기 투명도가 투명에 상응하는 투명 영역 중 적어도 하나로 구별하고, 상기 이미지를 상기 불투명 영역에 상응하는 최대 크기의 불투명 사각 영역 및 상기 이미지에서 상기 불투명 사각 영역을 제외한 투명도 혼합 영역 중 하나 이상에 상응하는 상기 적어도 하나의 영역으로 분할할 수 있다.
이 때, 이미지 분할부는 상기 이미지를 구성하는 복수개의 픽셀들 각각에 상응하는 상기 알파 값이 일괄적이지 않은 경우에 상기 투명도가 일정하지 않은 것으로 판단할 수 있다.
이 때, 투명도 체크부는 상기 알파 값이 255에 상응하는 경우에 상기 투명도가 상기 불투명에 상응하는 것으로 판단하고, 상기 알파 값이 255에 상응하지 않는 경우에 상기 투명도가 상기 투명에 상응하는 것으로 판단할 수 있다.
이 때, 스트리밍부는 상기 불투명 사각 영역은 JPEG 스틸 이미지 인코딩 기법으로 스틸 이미지 인코딩하고, 상기 투명도 혼합 영역은 PNG 스틸 이미지 인코딩 기법으로 스틸 이미지 인코딩할 수 있다.
이 때, 스트리밍부는 상기 투명도가 일정한 경우에, 상기 불투명 영역은 상기 JPEG 스틸 이미지 인코딩 기법으로 스틸 이미지 인코딩하고 상기 투명 영역은 팔렛트 PNG 스틸 이미지 인코딩 기법으로 스틸 이미지 인코딩할 수 있다.
이 때, 스트리밍부는 상기 투명도가 일정하지 않은 경우에 스틸 이미지 인코딩된 상기 적어도 하나의 영역 각각에 일련 번호를 부여하고, 상기 적어도 하나의 영역에 상응하는 이미지 개수와 상기 일련 번호를 스틸 이미지 인코딩된 상기 적어도 하나의 영역과 함께 상기 단말로 전송할 수 있다.
이 때, 단말은 상기 이미지 개수 및 상기 일련 번호 중 적어도 하나를 기반으로 스틸 이미지 인코딩된 상기 적어도 하나의 영역을 모두 수신한 뒤 렌더링을 수행할 수 있다.
이 때, 단말은 상기 적어도 하나의 영역 중 상기 JPEG 스틸 이미지 인코딩 기법으로 스틸 이미지 인코딩된 영역은 칩셋 레벨에서 하드웨어 디코딩을 수행할 수 있다.
또한, 본 발명에 따른 이미지의 투명도에 기반한 이미지 클라우드 스트리밍 서비스 방법은 어플리케이션 실행화면에 상응하는 복수개의 프레임들을 비교하여 변화된 영역에 상응하는 이미지를 캡처하는 단계; 상기 이미지에 상응하는 알파 값을 기반으로 상기 이미지의 투명도를 체크하는 단계; 상기 투명도가 일정하지 않은 경우에 상기 투명도를 기준으로 상기 이미지를 적어도 하나의 영역으로 분할하는 단계; 및 상기 적어도 하나의 영역 각각에 상응하는 스틸 이미지 인코딩 기법으로 상기 적어도 하나의 영역을 스틸 이미지 인코딩하여 사용자의 단말로 스트리밍 전송하는 단계를 포함한다.
이 때, 분할하는 단계는 상기 이미지에 상응하는 영역을 상기 투명도가 불투명에 상응하는 불투명 영역 및 상기 투명도가 투명에 상응하는 투명 영역 중 적어도 하나로 구별하는 단계를 포함하고, 상기 이미지를 상기 불투명 영역에 상응하는 최대 크기의 불투명 사각 영역 및 상기 이미지에서 상기 불투명 사각 영역을 제외한 투명도 혼합 영역 중 하나 이상에 상응하는 상기 적어도 하나의 영역으로 분할할 수 있다.
이 때, 분할하는 단계는 상기 이미지를 구성하는 복수개의 픽셀들 각각에 상응하는 상기 알파 값이 일괄적이지 않은 경우에 상기 투명도가 일정하지 않은 것으로 판단할 수 있다.
이 때, 투명도를 체크하는 단계는 상기 알파 값이 255에 상응하는 경우에 상기 투명도가 상기 불투명에 상응하는 것으로 판단하고, 상기 알파 값이 255에 상응하지 않는 경우에 상기 투명도가 상기 투명에 상응하는 것으로 판단할 수 있다.
이 때, 스트리밍 전송하는 단계는 상기 불투명 사각 영역은 JPEG 스틸 이미지 인코딩 기법으로 스틸 이미지 인코딩하고, 상기 투명도 혼합 영역은 PNG 스틸 이미지 인코딩 기법으로 스틸 이미지 인코딩할 수 있다.
이 때, 스트리밍 전송하는 단계는 상기 투명도가 일정한 경우에, 상기 불투명 영역은 상기 JPEG 스틸 이미지 인코딩 기법으로 스틸 이미지 인코딩하고 상기 투명 영역은 팔렛트 PNG 스틸 이미지 인코딩 기법으로 스틸 이미지 인코딩할 수 있다.
이 때, 스트리밍 전송하는 단계는 상기 투명도가 일정하지 않은 경우에 스틸 이미지 인코딩된 상기 적어도 하나의 영역 각각에 일련 번호를 부여하는 단계를 포함하고, 상기 적어도 하나의 영역에 상응하는 이미지 개수와 상기 일련 번호를 스틸 이미지 인코딩된 상기 적어도 하나의 영역과 함께 상기 단말로 전송할 수 있다.
이 때, 단말은 상기 이미지 개수 및 상기 일련 번호 중 적어도 하나를 기반으로 스틸 이미지 인코딩된 상기 적어도 하나의 영역을 모두 수신한 뒤 렌더링을 수행할 수 있다.
이 때, 단말은 상기 적어도 하나의 영역 중 상기 JPEG 스틸 이미지 인코딩 기법으로 스틸 이미지 인코딩된 영역은 칩셋 레벨에서 하드웨어 디코딩을 수행할 수 있다.
또한, 본 발명의 과제 해결을 위한 또 다른 수단으로써, 상술한 방법을 실행시키기 위하여 매체에 저장된 컴퓨터 프로그램을 제공한다.
또한, 본 발명에 따른 클라우드 스트리밍 서비스 시스템은 어플리케이션 실행화면에 상응하는 복수개의 프레임들을 비교하여 변화된 영역에 상응하는 이미지를 캡처하고, 상기 이미지에 상응하는 알파 값을 기반으로 상기 이미지의 투명도를 체크하고, 상기 투명도가 일정하지 않은 경우에 상기 투명도를 기준으로 상기 이미지를 적어도 하나의 영역으로 분할하고, 상기 적어도 하나의 영역 각각에 상응하는 스틸 이미지 인코딩 기법으로 상기 적어도 하나의 영역을 스틸 이미지 인코딩하여 사용자의 단말로 스트리밍 전송하는 클라우드 스트리밍 서버; 및 상기 클라우드 스트리밍 서버로부터 스틸 이미지 인코딩된 상기 적어도 하나의 영역을 모두 수신하여 렌더링하고, 렌더링된 상기 적어도 하나의 영역을 상기 사용자에게 디스플레이 하는 단말을 포함한다.
본 발명에 따르면, 이미지 기반의 클라우드 스트리밍 서비스 시 이미지의 투명도에 따라 적합한 스틸 이미지 인코딩 기법으로 빠르고 화질 열화 없이 처리할 수 있다.
또한, 본 발명은 이미지의 투명도에 따라 이미지를 분할하여 각각 스틸 이미지 인코딩함으로써, 동일한 영역이 중복적으로 처리되지 않도록 효율적으로 스틸 이미지 인코딩할 수 있다.
또한, 본 발명은 사용자 단말에서 프레임의 변화된 이미지만을 렌더링하여 디스플레이 하도록 함으로써 사용자 단말의 성능이 낮더라도 클라우드 스트리밍 서비스를 원활하게 제공할 수 있다.
도 1은 본 발명의 일실시예에 따른 클라우드 스트리밍 서비스 시스템을 나타낸 블록도이다.
도 2는 도 1에 도시된 클라우드 스트리밍 서버의 일 예를 나타낸 블록도이다.
도 3은 본 발명에 따라 이미지를 분할하는 과정의 일 예를 나타낸 도면이다.
도 4 및 도 5는 본 발명에 따라 투명도를 기준으로 분할된 이미지의 일 예를 나타낸 도면이다.
도 6은 PNG 스틸 이미지 인코딩 기법에 따라 이미지에서 컬러 정보를 포함하는 방식의 일 예를 나타낸 도면이다.
도 7은 팔렛트 PNG 스틸 이미지 인코딩 기법에 따라 이미지에서 컬러 정보를 포함하는 방식의 일 예를 나타낸 도면이다.
도 8은 팔렛트 PNG 스틸 이미지 인코딩 기법에서 생성하는 컬러 인덱스의 일 예를 나타낸 도면이다.
도 9는 본 발명에 따라 프레임을 비교하여 캡처될 이미지를 검출하는 과정의 일 예를 나타낸 도면이다.
도 10은 본 발명의 다른 실시예에 따른 이미지의 투명도에 기반한 이미지 클라우드 스트리밍 서비스 방법을 나타낸 동작 흐름도이다.
도 11은 본 발명의 다른 실시예에 따른 이미지의 투명도에 기반한 이미지 클라우드 스트리밍 서비스 방법에서 스틸 이미지 인코딩 기법을 선택하는 과정을 상세하게 나타낸 동작 흐름도이다.
이하 본 발명의 바람직한 실시예를 첨부한 도면을 참조하여 상세히 설명한다. 다만, 하기의 설명 및 첨부된 도면에서 본 발명의 요지를 흐릴 수 있는 공지 기능 또는 구성에 대한 상세한 설명은 생략한다. 또한, 도면 전체에 걸쳐 동일한 구성 요소들은 가능한 한 동일한 도면 부호로 나타내고 있음에 유의하여야 한다. 본 발명의 실시형태는 당 업계에서 평균적인 지식을 가진 자에게 본 발명을 보다 완전하게 설명하기 위해서 제공되는 것이다. 따라서, 도면에서의 요소들의 형상 및 크기 등은 보다 명확한 설명을 위해 과장될 수 있다.
이하에서 설명되는 본 명세서 및 청구범위에 사용된 용어나 단어는 통상적이거나 사전적인 의미로 한정해서 해석되어서는 아니 되며, 발명자는 그 자신의 발명을 가장 최선의 방법으로 설명하기 위한 용어의 개념으로 적절하게 정의할 수 있다는 원칙에 입각하여 본 발명의 기술적 사상에 부합하는 의미와 개념으로 해석되어야만 한다. 따라서 본 명세서에 기재된 실시예와 도면에 도시된 구성은 본 발명의 가장 바람직한 일 실시예에 불과할 뿐이고, 본 발명의 기술적 사상을 모두 대변하는 것은 아니므로, 본 출원시점에 있어서 이들을 대체할 수 있는 다양한 균등물과 변형 예들이 있을 수 있음을 이해하여야 한다. 또한 제 1, 제 2 등의 용어는 다양한 구성요소들을 설명하기 위해 사용하는 것으로, 하나의 구성요소를 다른 구성요소로부터 구별하는 목적으로만 사용될 뿐, 상기 구성요소들을 한정하기 위해 사용되지 않는다.
도 1은 본 발명의 일실시예에 따른 클라우드 스트리밍 서비스 시스템을 나타낸 블록도이다.
도 1을 참조하면, 본 바렴의 일실시예에 따른 클라우드 스트리밍 서비스 시스템은 클라우드 스트리밍 서버(110), 단말(120-1~ 120-N) 및 네트워크(130)를 포함한다.
클라우드 스트리밍 서버(110)는 어플리케이션 실행화면에 상응하는 복수개의 프레임들을 비교하여 변화된 영역에 상응하는 이미지를 캡처한다.
이 때, 복수개의 프레임들 중 변화가 큰 영역을 검출하고, 변화가 큰 영역에서 현재 프레임과 이전 프레임을 비교하여 이미지를 캡처할 수 있다.
또한, 클라우드 스트리밍 서버(110)는 이미지에 상응하는 알파 값을 기반으로 이미지의 투명도를 체크한다.
이 때, 알파 값이 255에 상응하는 경우에 투명도가 불투명에 상응하는 것으로 판단하고, 알파 값이 255에 상응하지 않는 경우에 투명도가 투명에 상응하는 것으로 판단할 수 있다.
또한, 클라우드 스트리밍 서버(110)는 투명도가 일정하지 않은 경우에 투명도를 기준으로 이미지를 적어도 하나의 영역으로 분할한다.
이 때, 이미지에 상응하는 영역을 투명도가 불투명에 상응하는 불투명 영역 및 투명도가 투명에 상응하는 투명 영역 중 적어도 하나로 구별하고, 이미지를 불투명 영역에 상응하는 최대 크기의 불투명 사각 영역 및 이미지에서 불투명 사각 영역을 제외한 투명도 혼합 영역 중 하나 이상에 상응하는 적어도 하나의 영역으로 분할할 수 있다.
이 때, 이미지를 구성하는 복수개의 픽셀들 각각에 상응하는 알파 값이 일괄적이지 않은 경우에 투명도가 일정하지 않은 것으로 판단할 수 있다.
또한, 클라우드 스트리밍 서버(110)는 적어도 하나의 영역 각각에 상응하는 스틸 이미지 인코딩 기법으로 적어도 하나의 영역을 스틸 이미지 인코딩하여 사용자의 단말(120-1~ 120-N)로 스트리밍 전송한다.
이 때, 불투명 사각 영역은 JPEG 스틸 이미지 인코딩 기법으로 스틸 이미지 인코딩하고, 투명도 혼합 영역은 PNG 스틸 이미지 인코딩 기법으로 스틸 이미지 인코딩할 수 있다.
이 때, 투명도가 일정한 경우에, 불투명 영역은 JPEG 스틸 이미지 인코딩 기법으로 스틸 이미지 인코딩하고 투명 영역은 팔렛트 PNG 스틸 이미지 인코딩 기법으로 스틸 이미지 인코딩할 수 있다.
이 때, 투명도가 일정하지 않은 경우에 스틸 이미지 인코딩된 적어도 하나의 영역 각각에 일련 번호를 부여하고, 적어도 하나의 영역에 상응하는 이미지 개수와 일련 번호를 스틸 이미지 인코딩된 적어도 하나의 영역과 함께 단말(120-1~ 120-N)로 전송할 수 있다.
이 때, 단말(120-1~ 120-N)은 이미지 개수 및 일련 번호 중 적어도 하나를 기반으로 스틸 이미지 인코딩된 적어도 하나의 영역을 모두 수신한 뒤 렌더링을 수행할 수 있다.
이 때, 단말(120-1~ 120-N)은 적어도 하나의 영역 중 JPEG 스틸 이미지 인코딩 기법으로 스틸 이미지 인코딩된 영역은 칩셋 레벨에서 하드웨어 디코딩을 수행할 수 있다.
단말(120-1~ 120-N)은 클라우드 스트리밍 서버(110)로부터 클라우드 스트리밍 서비스에 상응하는 어플리케이션 실행화면을 수신하여 사용자에게 제공한다.
또한, 단말(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) 단말일 수 있다.
또한, 단말(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)의 제어부로 전달할 수 있다.
또한, 단말(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)의 표시부는 클라우드 컴퓨팅 기반으로 제공되는 컨텐츠의 실행과 관련된 정보를 화면으로 표시할 수 있다.
또한, 단말(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)의 정보는 단말 사양 정보를 포함할 수 있다.
또한, 단말(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)과 통신하여 클라우드 컴퓨팅 기반으로 컨텐츠를 업로드 또는 다운로드 하는데 필요한 데이터를 송수신할 수 있다.
또한, 단말(120-1~ 120-N)의 제어부는 운영 체제((OS, Operation System) 및 각 구성을 구동시키는 프로세스 장치가 될 수 있다. 예를 들어, 제어부는 클라우드 스트리밍 서버(110)에 접속하는 과정 전반을 제어할 수 있다. 별도의 서비스 어플리케이션을 통해 클라우드 스트리밍 서버(110)에 접속하는 경우, 사용자의 요청에 따라 서비스 어플리케이션을 실행되는 과정 전반을 제어할 수 있으며, 실행과 동시에 클라우드 스트리밍 서버(110)로 서비스 이용 요청이 전송되도록 제어할 수 있으며, 이때 사용자 인증에 필요한 단말(120-1~ 120-N)의 정보가 함께 전송되도록 제어할 수 있다.
또한, 단말(120-1~ 120-N)의 제어부는 사용자의 요청에 따라 단말(120-1~ 120-N)의 저장부에 저장된 특정 컨텐츠를 실행할 수 있다. 이때, 제어부는 컨텐츠 실행에 따른 컨텐츠 사용 이력을 컨텐츠 사용 정보로 저장할 수 있다.
또한, 단말(120-1~ 120-N)의 제어부는 컨텐츠를 실행하기 위한 실행 데이터와, 컨텐츠에 대한 속성 정보를 포함하는 컨텐츠 정보와, 컨텐츠 사용 이력에 따른 정보인 컨텐츠 사용 정보를 함께 클라우드 스트리밍 서버(110)로 전송하여 업로드 할 수 있다. 이후, 제어부는 클라우드 스트리밍 서버(110)에 전송하여 업로드된 컨텐츠에 대해서는 사용자의 요청에 따라 단말(120-1~ 120-N)의 저장부에서 삭제할 수 있으며, 클라우드 스트리밍 서버(110)에 접속하여 클라우드 스트리밍 서버(110)를 통해 컨텐츠를 실행하여 이용할 수도 있다.
또한, 단말(120-1~ 120-N)의 제어부는 클라우드 스트리밍 서버(110)에 접속하여 다른 단말(120-1~ 120-N)로부터 컨텐츠를 다운로드한 후 저장부에 저장되도록 제어할 수도 있으며, 클라우드 스트리밍 서버(110)를 통해 컨텐츠 실행 시, 실행에 필요한 데이터만을 수신한 후 컨텐츠가 실행되도록 제어할 수도 있다.
네트워크(130)는 클라우드 스트리밍 서버(110)및 단말(120-1~ 120-N) 사이에 데이터를 전달하는 통로를 제공하는 것으로서, 기존에 이용되는 네트워크 및 향후 개발 가능한 네트워크를 모두 포괄하는 개념이다. 예를 들어, 네트워크(130)는 한정된 지역 내에서 각종 정보장치들의 통신을 제공하는 유무선근거리 통신망, 이동체 상호 간 및 이동체와 이동체 외부와의 통신을 제공하는 이동통신망, 위성을 이용해 지구국과 지구국간 통신을 제공하는 위성통신망이거나 유무선 통신망 중에서 어느 하나이거나, 둘 이상의 결합으로 이루어질 수 있다. 한편, 네트워크(130)의 전송 방식 표준은, 기존의 전송 방식 표준에 한정되는 것은 아니며, 향후 개발될 모든 전송 방식 표준을 포함할 수 있다. 또한, 도 1에서 클라우드 스트리밍 서버(110)와 단말(120-1~ 120-N) 사이에 사용되는 네트워크는 단말(120-1~ 120-N)들 상호간에 사용되는 네트워크와 상이한 것일 수도 있고, 동일한 것일 수도 있다.
도 2는 도 1에 도시된 클라우드 스트리밍 서버의 일 예를 나타낸 블록도이다.
도 2를 참조하면, 도 1에 도시된 클라우드 스트리밍 서버(110)는 통신부(210), 캡처부(220), 투명도 체크부(230), 이미지 분할부(240), 스트리밍부(250) 및 저장부(260)를 포함한다.
통신부(210)는 도 1에 도시된 네트워크와 같은 통신망을 통해 다수의 단말들과 관련된 정보를 송수신하는 역할을 한다. 특히, 본 발명의 일실시예에 따른 통신부(210)는 클라우드 스트리밍 서비스에 대한 요청을 단말로부터 수신하고, 단말이 요청한 클라우드 스트리밍 서비스에 상응하는 어플리케이션의 실행화면을 단말로 제공할 수 있다.
이 때, 단말이 요청한 클라우드 스트리밍 서비스에 대해서 클라우드 스트리밍 서버로부터 어플리케이션 실행화면을 수신할 수 있다.
이 때, 웹 어플리케이션 서버가 사용자의 요청에 상응하게 어플리케이션을 실행시키고, 어플리케이션을 실행한 결과에 상응하는 어플리케이션 실행화면을 클라우드 스트리밍 서버(110)로 전송할 수 있다. 즉, 클라우드 스트리밍 서버(110)에서는 어플리케이션을 실행한 결과 화면만을 이용하여 사용자에게 이미지 기반의 클라우드 스트리밍 서비스를 제공할 수 있다.
캡처부(220)는 어플리케이션 실행화면에 상응하는 복수개의 프레임들을 비교하여 변화된 영역에 상응하는 이미지를 캡처한다.
클라우드 스트리밍 서비스는 기본적으로 비디오 코덱 기반의 클라우드 스트리밍 기법을 적용하기 때문에 메뉴 디스플레이와 같은 정적인 화면에 대해서 클라우드 스트리밍 기법을 적용하는 경우에도 불필요하게 화면 전체를 캡처하여 비디오 코덱으로 인코딩하는 비효율적인 방법으로 클라우드 스트리밍 서비스를 수행하였다. 이러한 문제점을 해결하기 위해 본 발명은 메뉴 디스플레이 화면과 같이 프레임간 변화가 크지 않은 경우에는 클라우드 스트리밍 서버가 프레임간 변화를 검출하고, 변화된 영역을 이미지로 캡처한 뒤 스틸 이미지 압축 기법으로 인코딩하는 클라우드 스트리밍 서버(110)를 제공한다.
또한, 비디오 코덱 기반의 클라우드 스트리밍 기법은 어플리케이션이 동작하는 화면에 상응하는 모든 프레임을 캡처하여 인코딩을 수행할 수 있다. 그러나 어플리케이션이 동작하는 화면 상에서 프레임간 변화가 크지 않은 경우에는 이전 프레임과 비교하여 변화된 프레임의 변화 영역만을 캡처하여 스틸 이미지 인코딩을 수행하고, 사용자의 단말 장치에 디스플레이 할 때 변화 영역을 제외한 부분은 동일하게 보여주고 변화 영역만 변화를 주는 방식으로 디스플레이 할 수 있다.
이 때, 프레임들 중 현재 프레임과 이전 프레임을 비교하여 변화된 이미지를 캡쳐할 수 있다. 예를 들어, 현재 프레임과 이전 프레임을 비교하였을 때 현재 프레임이 이전 프레임과 비교하여 변화가 있다면, 현재 프레임의 화면 영역 중 변화된 영역을 이미지로 캡쳐할 수 있다. 또한, 캡쳐된 이미지는 사용자의 단말에서 입력되는 입력신호에 따라 그 사이즈나 성질이 다양할 수 있다.
이 때, 사용자의 단말로 전송될 프레임 전체 구간 중 프레임 변화가 적은 구간을 검출하고, 프레임 변화가 적은 구간에서 프레임들을 비교하여 이미지를 캡처할 수 있다.
이 때, 사용자의 단말에서 발생하는 어플리케이션의 이벤트 유형을 감지하여 프레임 변화가 적은 구간을 검출할 수 있다. 예를 들어, 사용자의 단말에서 발생하는 입력신호에 따라 어플리케이션의 이벤트 유형이 결정될 수 있다. 입력신호에 따라 메뉴, 옵션, 안내 창과 같이 어플리케이션을 실행하였을 때 프레임의 변화가 적은 정적인 이벤트 또는 동영상 재생 및 게임 플레이와 같이 프레임이 자주 변하는 동적인 이벤트가 발생할 수 있다. 따라서, 사용자가 단말을 통해 발생시키는 입력신호로 이벤트 유형을 감지하고, 이벤트 유형이 정적인 이벤트라면, 해당 이벤트에 상응하는 프레임 전체 구간 중 프레임 변화가 적은 구간을 검출할 수 있다.
투명도 체크부(230)는 이미지에 상응하는 알파 값을 기반으로 이미지의 투명도를 체크한다.
이 때, 어플리케이션 실행화면을 렌더링하는 과정에서 이미지를 구성하는 복수개의 픽셀에 대한 픽셀 값을 조사하여 알파 값을 획득할 수 있다.
이 때, 알파 값이 255에 상응하는 경우에 투명도가 불투명에 상응하는 것으로 판단하고, 알파 값이 255에 상응하지 않는 경우에 투명도가 투명에 상응하는 것으로 판단할 수 있다. 즉, 어플리케이션 실행화면의 프레임을 구성하는 복수개의 픽셀들의 픽셀 값을 체크하여 알파 값을 획득하고, 알파 값에 따라 투명도를 판단할 수 있다.
이미지 분할부(240)는 투명도가 일정하지 않은 경우에 투명도를 기준으로 이미지를 적어도 하나의 영역으로 분할한다.
이 때, 이미지를 구성하는 복수개의 픽셀들 각각에 상응하는 알파 값이 일괄적이지 않은 경우에 투명도가 일정하지 않은 것으로 판단할 수 있다. 예를 들어, 이미지의 상단을 구성하는 픽셀들의 알파 값은 255에 상응하지만 이미지의 하단을 구성하는 픽셀들의 알파 값은 100에 상응하는 경우에는 해당 이미지의 투명도가 일정하지 않은 것으로 판단할 수 있다. 따라서, 이와 같은 경우에는 이미지의 상단과 하단, 즉 알파 값이 255에 상응하는 영역과 알파 값이 100에 상응하는 영역에 기반하여 이미지를 적어도 하나의 영역으로 분할할 수 있다.
이 때, 이미지에 상응하는 영역을 투명도가 불투명에 상응하는 불투명 영역 및 투명도가 투명에 상응하는 투명 영역 중 적어도 하나로 구별하고, 이미지를 불투명 영역에 상응하는 최대 크기의 불투명 사각 영역 및 이미지에서 불투명 사각 영역을 제외한 투명도 혼합 영역 중 하나 이상을 상응하는 적어도 하나의 영역으로 분할할 수 있다.
이 때, 이미지에 상응하는 영역 중 불투명 사각 영역과 투명도 혼합 영역을 제외한 나머지 투명 영역도 따로 분할할 수 있다.
이 때, 이미지를 먼저 불투명 영역과 투명 영역으로 구별한 뒤, 다시 불투명 영역에서 불투명 사각 영역으로 분할하는 것은 불투명 영역의 모양이 다각형일 경우에 스틸 이미지 인코딩을 수행할 인코더에서 처리 영역을 보다 수월하게 파악하기 위함일 수 있다. 예를 들어, 스틸 이미지 인코딩될 이미지가 사각형에 상응하는 모양일 때와 특정한 도형에 해당하지 않는 불규칙한 모양일 경우, 사각형에 상응하는 모양일 경우에 인코더에서 보다 신속하게 처리 영역을 파악할 수 있다.
따라서, 먼저 불투명 영역에서 최대 크기로 생성할 수 있는 사각형 모양에 상응하게 불투명 사각 영역을 분할하고, 불투명 사각 영역에 포함되지 못한 나머지 불투명 영역과 투명 영역을 함께 투명도 혼합 영역으로 인식할 수 있다. 즉, 투명도 혼합 영역에 불투명 영역이 최소한으로 포함되도록 불투명 사각 영역을 분할할 수 있다.
이 때, 어플리케이션 실행화면에서 포스터나 그림과 같은 주요 이미지들은 불투명 영역에 상응할 수 있고, 포스터나 그림에 대한 설명을 포함하는 텍스트 부분과 배경 등이 투명 영역에 상응할 수 있다.
스트리밍부(250)는 적어도 하나의 영역 각각에 상응하는 스틸 이미지 인코딩 기법으로 적어도 하나의 영역을 스틸 이미지 인코딩하여 사용자의 단말로 스트리밍 전송한다.
이 때, 스틸 이미지 인코딩 기법에 따른 스틸 이미지 인코더는 투명도를 나타내는 알파 채널을 포함할 수 있는 PNG와 같은 인코더가 있을 수 있고, JPEG와 같이 알파 채널이 없는 인코더가 있을 수 있다.
이 때, 불투명 사각 영역은 JPEG 스틸 이미지 인코딩 기법으로 스틸 이미지 인코딩하고, 투명도 혼합 영역은 PNG 스틸 이미지 인코딩 기법으로 스틸 이미지 인코딩할 수 있다.
즉, 불투명 사각 영역은 알파 값이 255에 상응하는 이미지이기 때문에 대부분 포스터나 사진에 해당할 수 있다. 따라서, JPEG 스틸 이미지 인코딩 기법으로 스틸 이미지 인코딩하면 데이터 사이즈가 더 커지지 않으면서도 좋은 화질을 얻을 수 있으며, 단말에서 하드웨어 디코딩되어 반응 속도도 빨라질 수 있다.
또한, 투명도 혼합 영역은 알파 값이 255에 상응하는 이미지와 알파 값이 255에 상응하지 않는 이미지가 혼합되어 있기 때문에, 화질을 심하게 열화시키지 않도록 PNG 스틸 이미지 인코딩 기법으로 스틸 이미지 인코딩할 수 있다.
이 때, JPEG 스틸 이미지 인코딩 기법은 압축 효율이 좋아서 인코딩 시 전송 데이터 량을 대폭 줄일 수 있으나, 압축 효율이 큰 만큼 인코딩 및 디코딩을 수행할 때 시스템 부하를 많이 발생시킬 수 있다.
또한, PNG 스틸 이미지 인코딩 기법은 인코딩 시 이미지의 화질은 좋으나 데이터의 크기가 커져서 전송망의 대역폭이 낮은 경우에는 전송 속도가 저하될 수 있다.
이 때, 투명도가 일정한 경우에, 불투명 영역은 JPEG 스틸 이미지 인코딩 기법으로 스틸 이미지 인코딩하고 투명 영역은 팔렛트 PNG 스틸 이미지 인코딩 기법으로 스틸 이미지 인코딩할 수 있다.
이 때, 투명 영역은 대부분 텍스트나 배경의 조합일 가능성이 높으므로 이미지의 컬러 수가 많지 않을 수 있다. 따라서, PNG 스틸 이미지 인코딩 기법보다 데이터 크기를 3분의 1로 줄이는 팔렛트 PNG 스틸 이미지 인코딩 기법을 사용하여도 큰 화질 열화 없이 높은 압축 효율로 서비스가 가능할 수 있다.
이 때, 투명도가 일정하지 않은 경우에 스틸 이미지 인코딩된 적어도 하나의 영역 각각에 일련 번호를 부여하고, 적어도 하나의 영역에 상응하는 이미지 개수와 일련 번호를 스틸 이미지 인코딩된 적어도 하나의 영역과 함께 단말로 전송할 수 있다.
예를 들어, 이미지가 하나의 불투명 사각 영역과 하나의 투명도 혼합 영역을 포함하는 총 2개의 영역으로 분할된다고 가정한다면, 불투명 사각 영역에는 IMG1, 투명도 혼합 영역에는 IMG2라고 일련 번호를 부여할 수 있다. 이 후, 사용자의 단말로 스틸 이미지 인코딩된 불투명 사각 영역과 스틸 이미지 인코딩된 투명도 혼합 영역을 하나씩 전송하되, 이미지가 총 2개로 분할되었음을 알리기 위해 단말로 먼저 이미지 개수를 전송할 수 있다. 이 후, 각각의 일련 번호를 포함하는 스틸 이미지 인코딩된 불투명 사각 영역과 스틸 이미지 인코딩된 투명도 혼합 영역을 전송함으로써, 단말에서 모든 이미지가 수신되었음을 확인할 수 있도록 할 수 있다.
이 때, 단말은 이미지 개수 및 일련 번호 중 적어도 하나를 기반으로 스틸 이미지 인코딩된 적어도 하나의 영역을 모두 수신한 뒤 렌더링을 수행할 수 있다.
이 때, 분할된 모든 영역을 수신하여 렌더링하고, 렌더링된 화면을 사용자에게 디스플레이함으로써 화면 변화시 분할되어 비워져 있는 화면이 보이지 않도록 처리할 수 있다.
이 때, 단말은 적어도 하나의 영역 중 JPEG 스틸 이미지 인코딩 기법으로 스틸 이미지 인코딩된 영역은 칩셋 레벨에서 하드웨어 디코딩을 수행할 수 있다.
이 때, 컴퓨터에 내장된 비디오 재생 기능을 이용하여 하드웨어 디코딩을 수행하면, 컴퓨터의 중앙처리장치를 통해 소프트웨어 디코딩을 수행하는 것보다 디코딩 반응 속도가 빠를 수 있다.
저장부(260)는 상술한 바와 같이 본 발명의 실시예에 따른 클라우드 스트리밍 서비스 과정에서 발생되는 다양한 정보를 저장한다.
실시예에 따라, 저장부(260)는 클라우드 스트리밍 서버(110)와 독립적으로 구성되어 클라우드 스트리밍 서비스를 위한 기능을 지원할 수 있다. 이 때, 저장부(260)는 별도의 대용량 스토리지로 동작할 수 있고, 동작 수행을 위한 제어 기능을 포함할 수 있다.
또한, 상술한 바와 같이 구성되는 클라우드 스트리밍 서버(110)는 하나 이상의 서버로 구현될 수 있다.
한편, 클라우드 스트리밍 서버(110)는 메모리가 탑재되어 그 장치 내에서 정보를 저장할 수 있다. 일 구현예의 경우, 메모리는 컴퓨터로 판독 가능한 매체이다. 일 구현 예에서, 메모리는 휘발성 메모리 유닛일 수 있으며, 다른 구현예의 경우, 메모리는 비휘발성 메모리 유닛일 수도 있다. 일 구현예의 경우, 저장장치는 컴퓨터로 판독 가능한 매체이다. 다양한 서로 다른 구현 예에서, 저장장치는 예컨대 하드디스크 장치, 광학디스크 장치, 혹은 어떤 다른 대용량 저장장치를 포함할 수도 있다.
이와 같이, 클라우드 스트리밍 서버(110)를 이용하여 이미지 기반의 클라우드 스트리밍 서비스를 제공함으로써, 이미지의 투명도에 따라 적합한 스틸 이미지 인코딩 기법으로 빠르고 화질 열화 없이 처리하는 것이 가능할 수 있다.
또한, 이미지의 투명도에 따라 이미지를 분할하여 각각 스틸 이미지 인코딩함으로써, 동일한 영역이 중복적으로 처리되지 않도록 효율적으로 스틸 이미지 인코딩할 수 있다.
또한, 사용자 단말에서 프레임의 변화된 이미지만을 렌더링하여 디스플레이 하도록 함으로써 사용자 단말의 성능이 낮더라도 클라우드 스트리밍 서비스를 원활하게 제공할 수 있다.
도 3은 본 발명에 따라 이미지를 분할하는 과정의 일 예를 나타낸 도면이다.
도 3을 참조하면, 본 발명에 따라 이미지를 분할하는 과정은 먼저 어플리케이션 실행화면에서 캡처된 이미지(310)를 불투명 영역(302)과 투명 영역(304)으로 구별할 수 있다.
이 후, 불투명 영역(302)에서 최대 크기로 생성할 수 있는 사각형 모양에 상응하게 불투명 사각 영역(320)을 분할하고, 불투명 사각 영역에 포함되지 못한 나머지 불투명 영역과 투명 영역을 함께 투명도 혼합 영역(330)으로 인식할 수 있다. 즉, 투명도 혼합 영역(330)에 불투명 영역(302)이 최소한으로 포함되도록 불투명 사각 영역을 분할할 수 있다.
이 때, 이미지를 먼저 불투명 영역과 투명 영역으로 구별한 뒤, 다시 불투명 영역에서 불투명 사각 영역으로 분할하는 것은 불투명 영역의 모양이 다각형일 경우에 스틸 이미지 인코딩을 수행할 인코더에서 처리 영역을 보다 수월하게 파악하기 위함일 수 있다. 예를 들어, 스틸 이미지 인코딩될 이미지가 사각형에 상응하는 모양일 때와 특정한 도형에 해당하지 않는 불규칙한 모양일 경우, 사각형에 상응하는 모양일 경우에 인코더에서 보다 신속하게 처리 영역을 파악할 수 있다.
이 때, 이미지에 상응하는 영역 중 불투명 사각 영역과 투명도 혼합 영역을 제외한 나머지 투명 영역도 따로 분할할 수 있다.
도 4 및 도 5는 본 발명에 따라 투명도를 기준으로 분할된 이미지의 일 예를 나타낸 도면이다.
도 4 및 도 5를 참조하면, 도 4에는 어플리케이션 실행화면에서 캡처된 이미지(410)에는 투명 영역(404)과 함께 불투명 영역이 비워진 영역(402)이 존재하고, 도 5는 도 4의 이미지(410)에서 분할된 불투명 영역(502)에 상응하는 것을 알 수 있다.
즉, 도 4의 이미지(410)에 해당하는 영역이 스틸 이미지 인코딩되어 사용자의 단말로 제공되어야 하는데, 원래의 이미지(410)는 불투명 영역(502)과 투명 영역(404)이 혼합되어 있어 효율적인 스틸 이미지 인코딩을 수행하는데 어려움이 있었다.
따라서, 본 발명에 따라 이미지(410)의 알파 값을 기반으로 이미지(410)를 불투명 영역(502)과 투명 영역(404)으로 구별하고, 불투명 영역(502)에서 최대 크기의 사각형에 상응하는 영역을 분할할 수 있다. 이 때, 분할된 불투명 사각 영역이 도 5의 불투명 영역(502)에 상응할 수 있다.
따라서, 스틸 이미지 인코딩 시, 도 4에 이미지(410)에서 불투명 영역이 비워진 영역(402)응ㄹ 제외한 투명 영역(404)은 팔렛트 PNG 스틸 이미지 인코딩 기법으로 스틸 이미지 인코딩을 수행하고, 도 5의 불투명 영역(502)은 JPEG 스틸 이미지 인코딩 기법으로 스틸 이미지 인코딩을 수행할 수 있다.
또한, 단말로 스트리밍 전송을 수행할 때에는, 스틸 이미지 인코딩된 투명 영역(404)과 스틸 이미지 인코딩된 불투명 영역(502)에 각각 일련 번호를 부여할 수 있다.
또한, 단말로 스트리밍 전송을 수행할 때, 이미지(410)가 분할되어 생성된 적어도 하나의 영역의 개수와 각 일련 번호를 함께 전송함으로써, 단말에서 모든 이미지를 수신한 뒤에 렌더링을 수행할 수 있도록 할 수 있다.
도 6은 PNG 스틸 이미지 인코딩 기법에 따라 이미지에서 컬러 정보를 포함하는 방식의 일 예를 나타낸 도면이다.
도 6을 참조하면, PNG 스틸 이미지 인코딩 기법에 따라 이미지에서 컬러 정보를 포함하는 방식은 픽셀(610)에 각각 R(Red), G(Green), B(Blue)에 해당하는 컬러를 1Byte씩의 데이터로 포함할 수 있다. 따라서, 하나의 픽셀(610)은 3Byte의 데이터 크기를 갖고, 전체 이미지는 이미지가 포함하는 픽셀의 수에 3Byte의 값을 곱한 만큼의 데이터 크기를 가질 수 있다.
이 때, PNG 스틸 이미지 인코딩 기법의 경우에는 하나의 픽셀당 32bit의 데이터 크기, 즉 4Byte의 데이터 크기를 가질 수 있다. 이 때, 4Byte 중 3Byte는 상기에서 설명한 것과 같은 RGB 컬러의 데이터이고, 나머지 1Byte는 투명도를 나타내기 위한 데이터일 수 있다.
도 7은 팔렛트 PNG 스틸 이미지 인코딩 기법에 따라 이미지에서 컬러 정보를 포함하는 방식의 일 예를 나타낸 도면이다.
도 7을 참조하면, 팔렛트 PNG 스틸 이미지 인코딩 기법에 따라 이미지에서 컬러 정보를 포함하는 방식은 픽셀(710)에 각각 컬러 인덱스의 해당하는 정보를 1Byte씩의 데이터로 포함할 수 있다. 따라서, 하나의 픽셀(710)은 1Byte의 데이터 크기를 갖고, 전체 이미지는 이미지가 포함하는 픽셀의 수에 1Byte의 값을 곱한 만큼의 데이터 크기를 가질 수 있다.
팔렛트 PNG 스틸 이미지 인코딩 기법이 PNG8bit 스틸 이미지 인코딩 기법이나 Indexed PNG 스틸 이미지 인코딩 기법으로 불리는 이유도 하나의 픽셀(710)의 데이터 크기가 8bit에 해당하는 1Byte이면서, 컬러 인덱스를 통해 컬러 값을 나타내기 때문일 수 있다.
따라서, 클라우드 스트리밍 서비스를 수행할 때, 클라우드 스트리밍 서버에서 이미지를 팔렛트 PNG 스틸 이미지 인코딩 기법으로 인코딩하는 경우, 도 6에 나타낸 PNG 스틸 이미지 인코딩 기법으로 인코딩하는 것보다 데이터의 크기를 4분의 1로 감소시킬 수 있다. 그러나, 팔렛트 PNG 스틸 이미지 인코딩 기법의 픽셀(710)이 나타낼 수 있는 컬러의 개수가 1Byte로 한정되기 때문에 이미지의 화질은 저하될 수 있다.
도 8은 팔렛트 PNG 스틸 이미지 인코딩 기법에서 생성하는 컬러 인덱스의 일 예를 나타낸 도면이다.
도 8을 참조하면, 팔렛트 PNG 스틸 이미지 인코딩 기법에서 생성하는 컬러 인덱스(810)는 팔렛트 PNG 스틸 이미지 인코딩 기법의 픽셀이 1Byte의 데이터 크기를 갖기 때문에 8bit, 즉 2의 8제곱에 해당하는 값인 256개의 컬러 정보를 포함할 수 있다.
도 8을 예로 들면, 팔레트 번호 0번에 해당하는 컬러는 RGB 색상코드에서 Red '0', Green '0', Blue'0'의 값을 갖는 컬러일 수 있다. 또한, 팔레트 번호 1번에 해당하는 컬러와 팔레트 번호 2번에 해당하는 컬러는 각각 RGB 색상코드에서 Red '127', Green '127', Blue'127'의 값을 갖는 컬러와 Red '255', Green '255', Blue'255'의 값을 갖는 컬러일 수 있다.
이와 같이 RGB 색상코드의 값을 이용하여 총 256개의 컬러로 구성되는 컬러 인덱스(810)는 어플리케이션 실행화면의 프레임들을 비교하여 캡쳐된 이미지를 구성하는 컬러들을 기반으로 구성될 수 있다. 예를 들어, 이미지를 구성하는 컬러가 파란색 계열이라면, 컬러 인덱스(810)에도 파란색 계열의 컬러가 많이 포함될 수 있다.
이와 같이 이미지를 구성하는 컬러를 고려하여 컬러 인덱스(810)를 구성함으로써 이미지의 화질 저하가 최소가 되도록 할 수 있다.
도 9는 본 발명에 따라 프레임을 비교하여 캡처될 이미지를 검출하는 과정의 일 예를 나타낸 도면이다.
도 9를 참조하면, 본 발명에 따라 프레임을 비교하여 캡처될 이미지를 검출하는 과정은 먼저 사용자 요청에 따른 어플리케이션 실행화면에서 화면의 변화가 적은 부분의 프레임들을 획득할 수 있다.
이 때, 화면의 변화가 많은 부분에 대해서는 비디오 코덱 기반의 클라우드 스트리밍 서비스를 통해 사용자에게 어플리케이션 실행화면을 제공하는 것이 더 효율적일 수 있다.
이 후, 변화가 적은 부분의 프레임들 중 현재 프레임(920)과 이전 프레임(910)을 비교할 수 있다. 예를 들어, 도 9에 나타낸 현재 프레임(920)과 이전 프레임(910)을 비교하면 두 프레임의 A 영역에 대해서는 변화가 없으나, 이전 프레임(910)의 B 영역이 현재 프레임(920)에서는 B`로 변한 것을 확인할 수 있다.
따라서, 클라우드 스트리밍 서버에서는 이와 같은 변화를 확인하고, 변화된 B` 영역을 캡처 이미지(930)로 캡쳐할 수 있다.
또한, 현재 프레임(920)과 이전 프레임(910)을 비교하였을 때, 캡처 이미지(930)와 같이 변화된 부분이 여러 영역 확인되는 경우에는, 변화된 여러 영역을 모두 포함하는 하나의 영역을 캡처 이미지(930)로 인식하고 캡쳐할 수 있다. 또한, 변화된 여러 영역을 모두 각각의 캡처 이미지(930)로 인식하고 복수 개의 캡처 이미지(930)를 생성하여 이미지 기반의 클라우드 스트리밍 서비스를 수행할 수도 있다.
도 10은 본 발명의 일실시예에 따른 이미지의 투명도에 기반한 이미지 클라우드 스트리밍 서비스 방법을 나타낸 동작 흐름도이다.
도 10을 참조하면, 본 발명의 일실시예에 따른 이미지의 투명도에 기반한 이미지 클라우드 스트리밍 서비스 방법은 어플리케이션 실행화면에 상응하는 복수개의 프레임들을 비교하여 변화된 영역에 상응하는 이미지를 캡처한다(S1010).
클라우드 스트리밍 서비스는 기본적으로 비디오 코덱 기반의 클라우드 스트리밍 기법을 적용하기 때문에 메뉴 디스플레이와 같은 정적인 화면에 대해서 클라우드 스트리밍 기법을 적용하는 경우에도 불필요하게 화면 전체를 캡처하여 비디오 코덱으로 인코딩하는 비효율적인 방법으로 클라우드 스트리밍 서비스를 수행하였다. 이러한 문제점을 해결하기 위해 본 발명은 메뉴 디스플레이 화면과 같이 프레임간 변화가 크지 않은 경우에는 클라우드 스트리밍 서버가 프레임간 변화를 검출하고, 변화된 영역을 이미지로 캡처한 뒤 스틸 이미지 압축 기법으로 인코딩하는 클라우드 스트리밍 서버를 제공한다.
또한, 비디오 코덱 기반의 클라우드 스트리밍 기법은 어플리케이션이 동작하는 화면에 상응하는 모든 프레임을 캡처하여 인코딩을 수행할 수 있다. 그러나 어플리케이션이 동작하는 화면 상에서 프레임간 변화가 크지 않은 경우에는 이전 프레임과 비교하여 변화된 프레임의 변화 영역만을 캡처하여 스틸 이미지 인코딩을 수행하고, 사용자의 단말 장치에 디스플레이 할 때 변화 영역을 제외한 부분은 동일하게 보여주고 변화 영역만 변화를 주는 방식으로 디스플레이 할 수 있다.
이 때, 프레임들 중 현재 프레임과 이전 프레임을 비교하여 변화된 이미지를 캡쳐할 수 있다. 예를 들어, 현재 프레임과 이전 프레임을 비교하였을 때 현재 프레임이 이전 프레임과 비교하여 변화가 있다면, 현재 프레임의 화면 영역 중 변화된 영역을 이미지로 캡쳐할 수 있다. 또한, 캡쳐된 이미지는 사용자의 단말에서 입력되는 입력신호에 따라 그 사이즈나 성질이 다양할 수 있다.
이 때, 사용자의 단말로 전송될 프레임 전체 구간 중 프레임 변화가 적은 구간을 검출하고, 프레임 변화가 적은 구간에서 프레임들을 비교하여 이미지를 캡처할 수 있다.
이 때, 사용자의 단말에서 발생하는 어플리케이션의 이벤트 유형을 감지하여 프레임 변화가 적은 구간을 검출할 수 있다. 예를 들어, 사용자의 단말에서 발생하는 입력신호에 따라 어플리케이션의 이벤트 유형이 결정될 수 있다. 입력신호에 따라 메뉴, 옵션, 안내 창과 같이 어플리케이션을 실행하였을 때 프레임의 변화가 적은 정적인 이벤트 또는 동영상 재생 및 게임 플레이와 같이 프레임이 자주 변하는 동적인 이벤트가 발생할 수 있다. 따라서, 사용자가 단말을 통해 발생시키는 입력신호로 이벤트 유형을 감지하고, 이벤트 유형이 정적인 이벤트라면, 해당 이벤트에 상응하는 프레임 전체 구간 중 프레임 변화가 적은 구간을 검출할 수 있다.
또한, 본 발명의 일실시예에 따른 이미지의 투명도에 기반한 이미지 클라우드 스트리밍 서비스 방법은 이미지에 상응하는 알파 값을 기반으로 이미지의 투명도를 체크한다(S1020).
이 때, 어플리케이션 실행화면을 렌더링하는 과정에서 이미지를 구성하는 복수개의 픽셀에 대한 픽셀 값을 조사하여 알파 값을 획득할 수 있다.
이 때, 알파 값이 255에 상응하는 경우에 투명도가 불투명에 상응하는 것으로 판단하고, 알파 값이 255에 상응하지 않는 경우에 투명도가 투명에 상응하는 것으로 판단할 수 있다. 즉, 어플리케이션 실행화면의 프레임을 구성하는 복수개의 픽셀들의 픽셀 값을 체크하여 알파 값을 획득하고, 알파 값에 따라 투명도를 판단할 수 있다.
또한, 본 발명의 일실시예에 따른 이미지의 투명도에 기반한 이미지 클라우드 스트리밍 서비스 방법은 투명도가 일정하지 않은 경우에 투명도를 기준으로 이미지를 적어도 하나의 영역으로 분할한다(S1030).
이 때, 이미지를 구성하는 복수개의 픽셀들 각각에 상응하는 알파 값이 일괄적이지 않은 경우에 투명도가 일정하지 않은 것으로 판단할 수 있다. 예를 들어, 이미지의 상단을 구성하는 픽셀들의 알파 값은 255에 상응하지만 이미지의 하단을 구성하는 픽셀들의 알파 값은 100에 상응하는 경우에는 해당 이미지의 투명도가 일정하지 않은 것으로 판단할 수 있다. 따라서, 이와 같은 경우에는 이미지의 상단과 하단, 즉 알파 값이 255에 상응하는 영역과 알파 값이 100에 상응하는 영역에 기반하여 이미지를 적어도 하나의 영역으로 분할할 수 있다.
이 때, 이미지에 상응하는 영역을 투명도가 불투명에 상응하는 불투명 영역 및 투명도가 투명에 상응하는 투명 영역 중 적어도 하나로 구별하고, 이미지를 불투명 영역에 상응하는 최대 크기의 불투명 사각 영역 및 이미지에서 불투명 사각 영역을 제외한 투명도 혼합 영역 중 하나 이상을 상응하는 적어도 하나의 영역으로 분할할 수 있다.
이 때, 이미지에 상응하는 영역 중 불투명 사각 영역과 투명도 혼합 영역을 제외한 나머지 투명 영역도 따로 분할할 수 있다.
이 때, 이미지를 먼저 불투명 영역과 투명 영역으로 구별한 뒤, 다시 불투명 영역에서 불투명 사각 영역으로 분할하는 것은 불투명 영역의 모양이 다각형일 경우에 스틸 이미지 인코딩을 수행할 인코더에서 처리 영역을 보다 수월하게 파악하기 위함일 수 있다. 예를 들어, 스틸 이미지 인코딩될 이미지가 사각형에 상응하는 모양일 때와 특정한 도형에 해당하지 않는 불규칙한 모양일 경우, 사각형에 상응하는 모양일 경우에 인코더에서 보다 신속하게 처리 영역을 파악할 수 있다.
따라서, 먼저 불투명 영역에서 최대 크기로 생성할 수 있는 사각형 모양에 상응하게 불투명 사각 영역을 분할하고, 불투명 사각 영역에 포함되지 못한 나머지 불투명 영역과 투명 영역을 함께 투명도 혼합 영역으로 인식할 수 있다. 즉, 투명도 혼합 영역에 불투명 영역이 최소한으로 포함되도록 불투명 사각 영역을 분할할 수 있다.
이 때, 어플리케이션 실행화면에서 포스터나 그림과 같은 주요 이미지들은 불투명 영역에 상응할 수 있고, 포스터나 그림에 대한 설명을 포함하는 텍스트 부분과 배경 등이 투명 영역에 상응할 수 있다.
또한, 본 발명의 일실시예에 따른 이미지의 투명도에 기반한 이미지 클라우드 스트리밍 서비스 방법은 적어도 하나의 영역 각각에 상응하는 스틸 이미지 인코딩 기법으로 적어도 하나의 영역을 스틸 이미지 인코딩하여 사용자의 단말로 스트리밍 전송한다(S1040).
이 때, 스틸 이미지 인코딩 기법에 따른 스틸 이미지 인코더는 투명도를 나타내는 알파 채널을 포함할 수 있는 PNG와 같은 인코더가 있을 수 있고, JPEG와 같이 알파 채널이 없는 인코더가 있을 수 있다.
이 때, 불투명 사각 영역은 JPEG 스틸 이미지 인코딩 기법으로 스틸 이미지 인코딩하고, 투명도 혼합 영역은 PNG 스틸 이미지 인코딩 기법으로 스틸 이미지 인코딩할 수 있다.
즉, 불투명 사각 영역은 알파 값이 255에 상응하는 이미지이기 때문에 대부분 포스터나 사진에 해당할 수 있다. 따라서, JPEG 스틸 이미지 인코딩 기법으로 스틸 이미지 인코딩하면 데이터 사이즈가 더 커지지 않으면서도 좋은 화질을 얻을 수 있으며, 단말에서 하드웨어 디코딩되어 반응 속도도 빨라질 수 있다.
또한, 투명도 혼합 영역은 알파 값이 255에 상응하는 이미지와 알파 값이 255에 상응하지 않는 이미지가 혼합되어 있기 때문에, 화질을 심하게 열화시키지 않도록 PNG 스틸 이미지 인코딩 기법으로 스틸 이미지 인코딩할 수 있다.
이 때, JPEG 스틸 이미지 인코딩 기법은 압축 효율이 좋아서 인코딩 시 전송 데이터 량을 대폭 줄일 수 있으나, 압축 효율이 큰 만큼 인코딩 및 디코딩을 수행할 때 시스템 부하를 많이 발생시킬 수 있다.
또한, PNG 스틸 이미지 인코딩 기법은 인코딩 시 이미지의 화질은 좋으나 데이터의 크기가 커져서 전송망의 대역폭이 낮은 경우에는 전송 속도가 저하될 수 있다.
이 때, 투명도가 일정한 경우에, 불투명 영역은 JPEG 스틸 이미지 인코딩 기법으로 스틸 이미지 인코딩하고 투명 영역은 팔렛트 PNG 스틸 이미지 인코딩 기법으로 스틸 이미지 인코딩할 수 있다.
이 때, 투명 영역은 대부분 텍스트나 배경의 조합일 가능성이 높으므로 이미지의 컬러 수가 많지 않을 수 있다. 따라서, PNG 스틸 이미지 인코딩 기법보다 데이터 크기를 3분의 1로 줄이는 팔렛트 PNG 스틸 이미지 인코딩 기법을 사용하여도 큰 화질 열화 없이 높은 압축 효율로 서비스가 가능할 수 있다.
이 때, 투명도가 일정하지 않은 경우에 스틸 이미지 인코딩된 적어도 하나의 영역 각각에 일련 번호를 부여하고, 적어도 하나의 영역에 상응하는 이미지 개수와 일련 번호를 스틸 이미지 인코딩된 적어도 하나의 영역과 함께 단말로 전송할 수 있다.
예를 들어, 이미지가 하나의 불투명 사각 영역과 하나의 투명도 혼합 영역을 포함하는 총 2개의 영역으로 분할된다고 가정한다면, 불투명 사각 영역에는 IMG1, 투명도 혼합 영역에는 IMG2라고 일련 번호를 부여할 수 있다. 이 후, 사용자의 단말로 스틸 이미지 인코딩된 불투명 사각 영역과 스틸 이미지 인코딩된 투명도 혼합 영역을 하나씩 전송하되, 이미지가 총 2개로 분할되었음을 알리기 위해 단말로 먼저 이미지 개수를 전송할 수 있다. 이 후, 각각의 일련 번호를 포함하는 스틸 이미지 인코딩된 불투명 사각 영역과 스틸 이미지 인코딩된 투명도 혼합 영역을 전송함으로써, 단말에서 모든 이미지가 수신되었음을 확인할 수 있도록 할 수 있다.
이 때, 단말은 이미지 개수 및 일련 번호 중 적어도 하나를 기반으로 스틸 이미지 인코딩된 적어도 하나의 영역을 모두 수신한 뒤 렌더링을 수행할 수 있다.
이 때, 분할된 모든 영역을 수신하여 렌더링하고, 렌더링된 화면을 사용자에게 디스플레이함으로써 화면 변화시 분할되어 비워져 있는 화면이 보이지 않도록 처리할 수 있다.
이 때, 단말은 적어도 하나의 영역 중 JPEG 스틸 이미지 인코딩 기법으로 스틸 이미지 인코딩된 영역은 칩셋 레벨에서 하드웨어 디코딩을 수행할 수 있다.
이 때, 컴퓨터에 내장된 비디오 재생 기능을 이용하여 하드웨어 디코딩을 수행하면, 컴퓨터의 중앙처리장치를 통해 소프트웨어 디코딩을 수행하는 것보다 디코딩 반응 속도가 빠를 수 있다.
또한, 도 10에는 도시하지 아니하였으나, 본 발명의 일실시예에 따른 이미지의 투명도에 기반한 이미지 클라우드 스트리밍 서비스 방법은 도 1에 도시된 네트워크와 같은 통신망을 통해 다수의 단말들과 관련된 정보를 송수신 한다. 특히, 클라우드 스트리밍 서비스에 대한 요청을 단말로부터 수신하고, 단말이 요청한 클라우드 스트리밍 서비스에 상응하는 어플리케이션의 실행화면을 단말로 제공할 수 있다.
이 때, 단말이 요청한 클라우드 스트리밍 서비스에 대해서 클라우드 스트리밍 서버로부터 어플리케이션 실행화면을 수신할 수 있다.
이 때, 웹 어플리케이션 서버가 사용자의 요청에 상응하게 어플리케이션을 실행시키고, 어플리케이션을 실행한 결과에 상응하는 어플리케이션 실행화면을 클라우드 스트리밍 서버로 전송할 수 있다. 즉, 클라우드 스트리밍 서버에서는 어플리케이션을 실행한 결과 화면만을 이용하여 사용자에게 이미지 기반의 클라우드 스트리밍 서비스를 제공할 수 있다.
또한, 도 10에는 도시하지 아니하였으나, 본 발명의 일실시예에 따른 이미지의 투명도에 기반한 이미지 클라우드 스트리밍 서비스 방법은 상술한 바와 같이 본 발명의 실시예에 따른 클라우드 스트리밍 서비스 과정에서 발생되는 다양한 정보를 저장한다.
실시예에 따라, 정보를 저장하는 저장모듈은 클라우드 스트리밍 서버와 독립적으로 구성되어 클라우드 스트리밍 서비스를 위한 기능을 지원할 수 있다. 이 때, 저장모듈은 별도의 대용량 스토리지로 동작할 수 있고, 동작 수행을 위한 제어 기능을 포함할 수 있다.
이와 같은 이미지의 투명도에 기반한 클라우드 스트리밍 이미지 클라우드 스트리밍 서비스 방법을 통해 이미지 기반의 클라우드 스트리밍 서비스를 제공함으로써, 이미지의 투명도에 따라 적합한 스틸 이미지 인코딩 기법으로 빠르고 화질 열화 없이 처리하는 것이 가능할 수 있다.
또한, 이미지의 투명도에 따라 이미지를 분할하여 각각 스틸 이미지 인코딩함으로써, 동일한 영역이 중복적으로 처리되지 않도록 효율적으로 스틸 이미지 인코딩할 수 있다.
또한, 사용자 단말에서 프레임의 변화된 이미지만을 렌더링하여 디스플레이 하도록 함으로써 사용자 단말의 성능이 낮더라도 클라우드 스트리밍 서비스를 원활하게 제공할 수 있다.
도 11은 본 발명의 일실시예에 따른 이미지의 투명도에 기반한 이미지 클라우드 스트리밍 서비스 방법에서 스틸 이미지 인코딩 기법을 선택하는 과정을 상세하게 나타낸 동작 흐름도이다.
도 11을 참조하면, 본 발명의 일실시예에 따른 이미지의 투명도에 기반한 이미지 클라우드 스트리밍 서비스 방법에서 스틸 이미지 인코딩 기법을 선택하는 과정은 먼저 캡처된 이미지의 알파 값을 기반으로 이미지의 투명도를 체크한다(S1110).
이 때, 어플리케이션 실행화면을 렌더링하는 과정에서 이미지를 구성하는 복수개의 픽셀에 대한 픽셀 값을 조사하여 알파 값을 획득할 수 있다.
이 후, 이미지의 투명도가 일정한지 여부를 판단한다(S1115).
이 때, 이미지를 구성하는 복수개의 픽셀들 각각에 상응하는 알파 값이 일괄적이지 않은 경우에 투명도가 일정하지 않은 것으로 판단할 수 있다. 예를 들어, 이미지의 상단을 구성하는 픽셀들의 알파 값은 255에 상응하지만 이미지의 하단을 구성하는 픽셀들의 알파 값은 100에 상응하는 경우에는 해당 이미지의 투명도가 일정하지 않은 것으로 판단할 수 있다.
단계(S1115)의 판단결과 투명도가 일정하지 않으면, 투명도를 기반으로 이미지를 불투명 사각 영역과 투명도 혼합 영역 중 적어도 하나를 포함하는 적어도 하나의 영역으로 분할한다(S1120).
이 때, 이미지에 상응하는 영역을 투명도가 불투명에 상응하는 불투명 영역 및 투명도가 투명에 상응하는 투명 영역 중 적어도 하나로 구별하고, 이미지를 불투명 영역에 상응하는 최대 크기의 불투명 사각 영역 및 이미지에서 불투명 사각 영역을 제외한 투명도 혼합 영역 중 하나 이상을 상응하는 적어도 하나의 영역으로 분할할 수 있다.
이 때, 이미지에 상응하는 영역 중 불투명 사각 영역과 투명도 혼합 영역을 제외한 나머지 투명 영역도 따로 분할할 수 있다.
이 때, 이미지를 먼저 불투명 영역과 투명 영역으로 구별한 뒤, 다시 불투명 영역에서 불투명 사각 영역으로 분할하는 것은 불투명 영역의 모양이 다각형일 경우에 스틸 이미지 인코딩을 수행할 인코더에서 처리 영역을 보다 수월하게 파악하기 위함일 수 있다.
따라서, 먼저 불투명 영역에서 최대 크기로 생성할 수 있는 사각형 모양에 상응하게 불투명 사각 영역을 분할하고, 불투명 사각 영역에 포함되지 못한 나머지 불투명 영역과 투명 영역을 함께 투명도 혼합 영역으로 인식할 수 있다.
이 후, 불투명 사각 영역은 JPEG 스틸 이미지 인코딩 기법, 투명도 혼합 영역은 PNG 스틸 이미지 인코딩 기법으로 각각 스틸 이미지 인코딩한다(S1130).
즉, 불투명 사각 영역은 알파 값이 255에 상응하는 이미지이기 때문에 대부분 포스터나 사진에 해당할 수 있다. 따라서, JPEG 스틸 이미지 인코딩 기법으로 스틸 이미지 인코딩하면 데이터 사이즈가 더 커지지 않으면서도 좋은 화질을 얻을 수 있으며, 단말에서 하드웨어 디코딩되어 반응 속도도 빨라질 수 있다.
또한, 투명도 혼합 영역은 알파 값이 255에 상응하는 이미지와 알파 값이 255에 상응하지 않는 이미지가 혼합되어 있기 때문에, 화질을 심하게 열화시키지 않도록 PNG 스틸 이미지 인코딩 기법으로 스틸 이미지 인코딩할 수 있다.
또한, 단계(S1115)의 판단결과 투명도가 일정하면, 일정한 투명도가 불투명에 상응하는지 여부를 판단한다(S1125).
이 때, 알파 값이 255에 상응하는 경우에 투명도가 불투명에 상응하는 것으로 판단하고, 알파 값이 255에 상응하지 않는 경우에 투명도가 투명에 상응하는 것으로 판단할 수 있다.
단계(S1125)의 판단결과 투명도가 불투명에 상응하면, 이미지를 JPEG 스틸 이미지 인코딩 기법으로 스틸 이미지 인코딩한다(S1140).
또한, 단계(S1125)의 판단결과 투명도가 불투명에 상응하지 않으면, 투명도가 투명한 것으로 판단하고 이미지를 팔렛트 PNG 스틸 이미지 인코딩 기법으로 스틸 이미지 인코딩한다(S1150).
이 때, 투명 영역은 대부분 텍스트나 배경의 조합일 가능성이 높으므로 이미지의 컬러 수가 많지 않을 수 있다. 따라서, PNG 스틸 이미지 인코딩 기법보다 데이터 크기를 3분의 1로 줄이는 팔렛트 PNG 스틸 이미지 인코딩 기법을 사용하여도 큰 화질 열화 없이 높은 압축 효율로 서비스가 가능할 수 있다.
본 발명에 따른 이미지의 투명도에 기반한 이미지 클라우드 스트리밍 서비스 방법은 다양한 컴퓨터 수단을 통하여 수행될 수 있는 프로그램 명령 형태로 구현되어 컴퓨터 판독 가능 매체에 기록될 수 있다. 상기 컴퓨터 판독 가능 매체는 프로그램 명령, 데이터 파일, 데이터 구조 등을 단독으로 또는 조합하여 포함할 수 있다. 상기 매체에 기록되는 프로그램 명령은 본 발명을 위하여 특별히 설계되고 구성된 것들이거나 컴퓨터 소프트웨어 당업자에게 공지되어 사용 가능한 것일 수도 있다. 컴퓨터 판독 가능 기록 매체의 예에는 하드 디스크, 플로피 디스크 및 자기 테이프와 같은 자기 매체(magnetic media), CD-ROM, DVD와 같은 광기록 매체(optical media), 플롭티컬 디스크(floptical disk)와 같은 자기-광 매체(magneto-optical media), 및 롬(ROM), 램(RAM), 플래시 메모리 등과 같은 프로그램 명령을 저장하고 수행하도록 특별히 구성된 모든 형태의 하드웨어 장치가 포함된다. 프로그램 명령의 예에는 컴파일러에 의해 만들어지는 것과 같은 기계어 코드뿐만 아니라 인터프리터 등을 사용해서 컴퓨터에 의해서 실행될 수 있는 고급 언어 코드를 포함할 수 있다. 이러한 하드웨어 장치는 본 발명의 동작을 수행하기 위해 하나 이상의 소프트웨어 모듈로서 작동하도록 구성될 수 있으며, 그 역도 마찬가지이다.
이상에서와 같이 본 발명에 따른 클라우드 스트리밍 서비스 시스템, 이미지의 투명도에 기반한 이미지 클라우드 스트리밍 서비스 방법 및 이를 위한 장치는 상기한 바와 같이 설명된 실시예들의 구성과 방법이 한정되게 적용될 수 있는 것이 아니라, 상기 실시예들은 다양한 변형이 이루어질 수 있도록 각 실시예들의 전부 또는 일부가 선택적으로 조합되어 구성될 수도 있다.
본 발명에 의하면 어플리케이션 실행화면에 상응하는 복수개의 프레임들을 비교하여 변화된 영역에 상응하는 이미지를 캡처하고, 이미지에 상응하는 알파 값을 기반으로 이미지의 투명도를 체크하고, 투명도가 일정하지 않은 경우에 투명도를 기준으로 이미지를 적어도 하나의 영역으로 분할하고, 적어도 하나의 영역 각각에 상응하는 스틸 이미지 인코딩 기법으로 적어도 하나의 영역을 스틸 이미지 인코딩하여 사용자의 단말로 스트리밍 전송할 수 있다. 나아가, 이미지 기반의 클라우드 스트리밍 서비스 시 투명도에 따라 스틸 이미지 인코딩을 수행함으로써 보다 효과적이고 높은 화질의 이미지를 사용자에게 신속하게 제공하는 것이 가능하다.

Claims (10)

  1. 어플리케이션 실행화면에 상응하는 복수개의 프레임들을 비교하여 변화된 영역에 상응하는 이미지를 캡처하는 캡처부;
    상기 이미지에 상응하는 알파 값을 기반으로 상기 이미지의 투명도를 체크하는 투명도 체크부;
    상기 투명도가 일정하지 않은 경우에 상기 투명도를 기준으로 상기 이미지를 적어도 하나의 영역으로 분할하는 이미지 분할부; 및
    상기 적어도 하나의 영역 각각에 상응하는 스틸 이미지 인코딩 기법으로 상기 적어도 하나의 영역을 스틸 이미지 인코딩하여 사용자의 단말로 스트리밍 전송하는 스트리밍부
    를 포함하는 것을 특징으로 하는 클라우드 스트리밍 서버.
  2. 청구항 1에 있어서,
    상기 이미지 분할부는
    상기 이미지에 상응하는 영역을 상기 투명도가 불투명에 상응하는 불투명 영역 및 상기 투명도가 투명에 상응하는 투명 영역 중 적어도 하나로 구별하고, 상기 이미지를 상기 불투명 영역에 상응하는 최대 크기의 불투명 사각 영역 및 상기 이미지에서 상기 불투명 사각 영역을 제외한 투명도 혼합 영역 중 하나 이상에 상응하는 상기 적어도 하나의 영역으로 분할하는 것을 특징으로 하는 클라우드 스트리밍 서버.
  3. 청구항 2에 있어서,
    상기 이미지 분할부는
    상기 이미지를 구성하는 복수개의 픽셀들 각각에 상응하는 상기 알파 값이 일괄적이지 않은 경우에 상기 투명도가 일정하지 않은 것으로 판단하는 것을 특징으로 하는 클라우드 스트리밍 서버.
  4. 청구항 3에 있어서,
    상기 투명도 체크부는
    상기 알파 값이 255에 상응하는 경우에 상기 투명도가 상기 불투명에 상응하는 것으로 판단하고, 상기 알파 값이 255에 상응하지 않는 경우에 상기 투명도가 상기 투명에 상응하는 것으로 판단하는 것을 특징으로 하는 클라우드 스트리밍 서버.
  5. 청구항 2에 있어서,
    상기 스트리밍부는
    상기 불투명 사각 영역은 JPEG 스틸 이미지 인코딩 기법으로 스틸 이미지 인코딩하고, 상기 투명도 혼합 영역은 PNG 스틸 이미지 인코딩 기법으로 스틸 이미지 인코딩하는 것을 특징으로 하는 클라우드 스트리밍 서버.
  6. 청구항 5에 있어서,
    상기 스트리밍부는
    상기 투명도가 일정한 경우에, 상기 불투명 영역은 상기 JPEG 스틸 이미지 인코딩 기법으로 스틸 이미지 인코딩하고 상기 투명 영역은 팔렛트 PNG 스틸 이미지 인코딩 기법으로 스틸 이미지 인코딩하는 것을 특징으로 하는 클라우드 스트리밍 서버.
  7. 청구항 1에 있어서,
    상기 스트리밍부는
    상기 투명도가 일정하지 않은 경우에 스틸 이미지 인코딩된 상기 적어도 하나의 영역 각각에 일련 번호를 부여하고, 상기 적어도 하나의 영역에 상응하는 이미지 개수와 상기 일련 번호를 스틸 이미지 인코딩된 상기 적어도 하나의 영역과 함께 상기 단말로 전송하는 것을 특징으로 하는 클라우드 스트리밍 서버.
  8. 청구항 7에 있어서,
    상기 단말은
    상기 이미지 개수 및 상기 일련 번호 중 적어도 하나를 기반으로 스틸 이미지 인코딩된 상기 적어도 하나의 영역을 모두 수신한 뒤 렌더링을 수행하는 것을 특징으로 하는 클라우드 스트리밍 서버.
  9. 청구항 6에 있어서,
    상기 단말은
    상기 적어도 하나의 영역 중 상기 JPEG 스틸 이미지 인코딩 기법으로 스틸 이미지 인코딩된 영역은 칩셋 레벨에서 하드웨어 디코딩을 수행하는 것을 특징으로 하는 클라우드 스트리밍 서버.
  10. 어플리케이션 실행화면에 상응하는 복수개의 프레임들을 비교하여 변화된 영역에 상응하는 이미지를 캡처하는 단계;
    상기 이미지에 상응하는 알파 값을 기반으로 상기 이미지의 투명도를 체크하는 단계;
    상기 투명도가 일정하지 않은 경우에 상기 투명도를 기준으로 상기 이미지를 적어도 하나의 영역으로 분할하는 단계; 및
    상기 적어도 하나의 영역 각각에 상응하는 스틸 이미지 인코딩 기법으로 상기 적어도 하나의 영역을 스틸 이미지 인코딩하여 사용자의 단말로 스트리밍 전송하는 단계
    를 포함하는 것을 특징으로 하는 이미지의 투명도에 기반한 이미지 클라우드 스트리밍 서비스 방법.
PCT/KR2016/013018 2016-11-11 2016-11-11 클라우드 스트리밍 서비스 시스템, 이미지의 투명도에 기반한 이미지 클라우드 스트리밍 서비스 방법 및 이를 위한 장치 WO2018088592A1 (ko)

Priority Applications (1)

Application Number Priority Date Filing Date Title
PCT/KR2016/013018 WO2018088592A1 (ko) 2016-11-11 2016-11-11 클라우드 스트리밍 서비스 시스템, 이미지의 투명도에 기반한 이미지 클라우드 스트리밍 서비스 방법 및 이를 위한 장치

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
PCT/KR2016/013018 WO2018088592A1 (ko) 2016-11-11 2016-11-11 클라우드 스트리밍 서비스 시스템, 이미지의 투명도에 기반한 이미지 클라우드 스트리밍 서비스 방법 및 이를 위한 장치

Publications (1)

Publication Number Publication Date
WO2018088592A1 true WO2018088592A1 (ko) 2018-05-17

Family

ID=62109868

Family Applications (1)

Application Number Title Priority Date Filing Date
PCT/KR2016/013018 WO2018088592A1 (ko) 2016-11-11 2016-11-11 클라우드 스트리밍 서비스 시스템, 이미지의 투명도에 기반한 이미지 클라우드 스트리밍 서비스 방법 및 이를 위한 장치

Country Status (1)

Country Link
WO (1) WO2018088592A1 (ko)

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN112533022A (zh) * 2019-08-30 2021-03-19 中兴通讯股份有限公司 云化机顶盒透明度叠加方法、云化机顶盒及存储介质

Citations (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2003087572A (ja) * 2001-09-14 2003-03-20 Akuseru:Kk 画像圧縮方法および装置、画像圧縮プログラムならびに画像処理装置
KR20080043148A (ko) * 2006-11-13 2008-05-16 삼성전자주식회사 영상 처리 방법 및 장치
JP2008306394A (ja) * 2007-06-06 2008-12-18 Canon Inc 画像処理装置およびその方法
JP2011238014A (ja) * 2010-05-10 2011-11-24 Fujitsu Ltd 情報処理装置、画像送信プログラム、画像表示プログラム及び画像表示方法
JP2013074550A (ja) * 2011-09-28 2013-04-22 Axell Corp 画像圧縮方法、画像伸長方法、及び画像処理装置
KR20160131831A (ko) * 2015-05-07 2016-11-16 엔트릭스 주식회사 클라우드 스트리밍 서비스 시스템, 이미지의 투명도에 기반한 이미지 클라우드 스트리밍 서비스 방법 및 이를 위한 장치

Patent Citations (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2003087572A (ja) * 2001-09-14 2003-03-20 Akuseru:Kk 画像圧縮方法および装置、画像圧縮プログラムならびに画像処理装置
KR20080043148A (ko) * 2006-11-13 2008-05-16 삼성전자주식회사 영상 처리 방법 및 장치
JP2008306394A (ja) * 2007-06-06 2008-12-18 Canon Inc 画像処理装置およびその方法
JP2011238014A (ja) * 2010-05-10 2011-11-24 Fujitsu Ltd 情報処理装置、画像送信プログラム、画像表示プログラム及び画像表示方法
JP2013074550A (ja) * 2011-09-28 2013-04-22 Axell Corp 画像圧縮方法、画像伸長方法、及び画像処理装置
KR20160131831A (ko) * 2015-05-07 2016-11-16 엔트릭스 주식회사 클라우드 스트리밍 서비스 시스템, 이미지의 투명도에 기반한 이미지 클라우드 스트리밍 서비스 방법 및 이를 위한 장치

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN112533022A (zh) * 2019-08-30 2021-03-19 中兴通讯股份有限公司 云化机顶盒透明度叠加方法、云化机顶盒及存储介质

Similar Documents

Publication Publication Date Title
WO2017150901A1 (en) Electronic device and method for displaying and transmitting images thereof
WO2018016720A1 (en) Image display device and image display method
WO2013151374A1 (en) Method and system for transfering data between plurality of devices
WO2015026058A1 (en) Method, terminal, and system for reproducing content
WO2014073847A1 (en) User terminal, external apparatus, data transceiving system, and data transceiving method
WO2020055121A1 (en) Display apparatus, method of controlling the same and recording medium thereof
WO2016010319A2 (ko) 클라우드 스트리밍 서비스 시스템, 메모리 병목 현상을 방지하기 위한 데이터 압축 방법 및 이를 위한 장치
WO2021112564A1 (en) Display system, control method of the display system, and display apparatus
WO2014189275A1 (en) Apparatus and method of recognizing external device in a communication system
WO2019098778A1 (en) Display apparatus, method for controlling the same and image providing apparatus
WO2018101655A1 (ko) 디스플레이장치 및 그 제어방법
WO2020241975A1 (en) Electronic device and method for controlling the same
WO2019135553A1 (en) Electronic device, control method thereof, and computer readable recording medium
WO2017135776A1 (en) Display apparatus, user terminal apparatus, system, and controlling method thereof
WO2020055120A1 (en) Display apparatus, method of controlling the same and recording medium thereof
WO2019221423A1 (ko) 전자장치, 그 제어방법 및 기록매체
KR101843411B1 (ko) 클라우드 스트리밍 서비스 시스템, 이미지의 투명도에 기반한 이미지 클라우드 스트리밍 서비스 방법 및 이를 위한 장치
WO2018088592A1 (ko) 클라우드 스트리밍 서비스 시스템, 이미지의 투명도에 기반한 이미지 클라우드 스트리밍 서비스 방법 및 이를 위한 장치
WO2021101275A1 (en) Method, system and device for sharing contents
WO2010036085A2 (en) Method and apparatus for providing rich media service
WO2015012632A1 (ko) 다시점 비디오 스트리밍 시스템 및 그 제공방법
WO2022149659A1 (ko) 디스플레이 장치 및 그 제어 방법
WO2014092289A1 (ko) 클라우드 서비스 제공 방법, 이를 위한 시스템 및 장치
WO2020197281A1 (ko) 클라우드 스트리밍 서비스에서의 사용자 인터페이스 세션 복구 방법 및 이를 위한 장치
WO2021221273A1 (en) Display apparatus and control method thereof

Legal Events

Date Code Title Description
121 Ep: the epo has been informed by wipo that ep was designated in this application

Ref document number: 16921235

Country of ref document: EP

Kind code of ref document: A1

NENP Non-entry into the national phase

Ref country code: DE

32PN Ep: public notification in the ep bulletin as address of the adressee cannot be established

Free format text: NOTING OF LOSS OF RIGHTS PURSUANT TO RULE 112(1) EPC (EPO FORM 1205 DATED 02/09/2019)

122 Ep: pct application non-entry in european phase

Ref document number: 16921235

Country of ref document: EP

Kind code of ref document: A1