KR100888595B1 - Apparatus for providing multiple screens and method for dynamic configuration of the same - Google Patents

Apparatus for providing multiple screens and method for dynamic configuration of the same Download PDF

Info

Publication number
KR100888595B1
KR100888595B1 KR1020060073115A KR20060073115A KR100888595B1 KR 100888595 B1 KR100888595 B1 KR 100888595B1 KR 1020060073115 A KR1020060073115 A KR 1020060073115A KR 20060073115 A KR20060073115 A KR 20060073115A KR 100888595 B1 KR100888595 B1 KR 100888595B1
Authority
KR
South Korea
Prior art keywords
screen
service
delete delete
output
logical
Prior art date
Application number
KR1020060073115A
Other languages
Korean (ko)
Other versions
KR20070017008A (en
Inventor
이종호
이광기
정운교
글렌 에이. 아담스
Original Assignee
삼성전자주식회사
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by 삼성전자주식회사 filed Critical 삼성전자주식회사
Priority to KR1020060073115A priority Critical patent/KR100888595B1/en
Priority to PCT/KR2006/003083 priority patent/WO2007018385A1/en
Priority to EP06823626A priority patent/EP1935174A4/en
Priority to JP2008524905A priority patent/JP2009503605A/en
Priority to CA002616257A priority patent/CA2616257A1/en
Priority to CN2006800286553A priority patent/CN101238717B/en
Priority to MX2008001483A priority patent/MX2008001483A/en
Publication of KR20070017008A publication Critical patent/KR20070017008A/en
Application granted granted Critical
Publication of KR100888595B1 publication Critical patent/KR100888595B1/en

Links

Images

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/40Client devices specifically adapted for the reception of or interaction with content, e.g. set-top-box [STB]; Operations thereof
    • H04N21/43Processing of content or additional data, e.g. demultiplexing additional data from a digital video stream; Elementary client operations, e.g. monitoring of home network or synchronising decoder's clock; Client middleware
    • H04N21/431Generation of visual interfaces for content selection or interaction; Content or additional data rendering
    • H04N21/4312Generation of visual interfaces for content selection or interaction; Content or additional data rendering involving specific graphical features, e.g. screen layout, special fonts or colors, blinking icons, highlights or animations
    • H04N21/4316Generation of visual interfaces for content selection or interaction; Content or additional data rendering involving specific graphical features, e.g. screen layout, special fonts or colors, blinking icons, highlights or animations for displaying supplemental content in a region of the screen, e.g. an advertisement in a separate window
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/40Client devices specifically adapted for the reception of or interaction with content, e.g. set-top-box [STB]; Operations thereof
    • H04N21/47End-user applications
    • H04N21/485End-user interface for client configuration
    • H04N21/4858End-user interface for client configuration for modifying screen layout parameters, e.g. fonts, size of the windows
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/40Client devices specifically adapted for the reception of or interaction with content, e.g. set-top-box [STB]; Operations thereof
    • H04N21/47End-user applications
    • H04N21/488Data services, e.g. news ticker

Abstract

본 발명은 다중 스크린을 제공하는 장치 및 상기 다중 스크린의 동적 구성 방법에 관한 것으로서, 물리적인 디스플레이 화면에 복수 개의 서비스를 표현하는 다수의 스크린을 동적으로 구성하기 위하여 장치에 존재하는 스크린들의 형태 및 연결 관계를 검색(discovery)하는 다중 스크린을 제공하는 장치 및 상기 다중 스크린의 동적 구성 방법에 관한 것이다.The present invention relates to an apparatus for providing multiple screens and a method for dynamically configuring the multiple screens. The present invention relates to a form and connection of screens existing in a device for dynamically configuring a plurality of screens representing a plurality of services on a physical display screen. An apparatus for providing multiple screens for discovering relationships and a method for dynamic configuration of the multiple screens.

본 발명의 실시예에 따른 다중 스크린을 제공하는 장치는 수신된 서비스를 표현하기 위한 적어도 하나 이상의 스크린을 생성하는 동작 모듈 및 상기 스크린 중 상기 서비스에 포함된 소정의 어플리케이션이 실행되는 스크린을 검색하는 검색 모듈을 포함한다.An apparatus for providing multiple screens according to an embodiment of the present invention is an operation module for generating at least one or more screens for representing a received service, and a search for searching for a screen on which a predetermined application included in the service is executed among the screens. Contains modules

다중 스크린, 논리 스크린, 출력 스크린, 어플리케이션, 검색 Multi Screen, Logic Screen, Output Screen, Application, Search

Description

다중 스크린을 제공하는 장치 및 상기 다중 스크린의 동적 구성 방법{Apparatus for providing multiple screens and method for dynamic configuration of the same}Apparatus for providing multiple screens and method for dynamic configuration of the same}

도 1은 종래의 기술에 따라 물리적인 디스플레이 화면에서 주화면과 부화면을 배치하는 형태를 나타내는 예시도이다.1 is an exemplary view illustrating a form of arranging a main screen and a sub screen in a physical display screen according to the related art.

도 2는 본 발명의 일 실시예에 따른 논리 스크린과 출력 스크린과의 관계를 나타내는 예시도이다.2 is an exemplary view showing a relationship between a logic screen and an output screen according to an embodiment of the present invention.

도 3a 내지 도 3e는 본 발명의 일 실시예에 따른 매퍼(mapper)를 포함하는 스크린의 구성을 나타내는 도면이다.3A to 3E are diagrams illustrating the configuration of a screen including a mapper according to an embodiment of the present invention.

도 4는 본 발명의 일 실시예에 따라 서비스를 제공하는 소스의 예를 나타내는 예시도이다.4 is an exemplary diagram illustrating an example of a source for providing a service according to an embodiment of the present invention.

도 5a 및 도 5b는 본 발명의 일 실시예에 따라 추상 서비스와 비추상 서비스의 예를 나타내는 예시도이다.5A and 5B are exemplary diagrams illustrating examples of abstract services and non-abstract services according to an embodiment of the present invention.

도 6은 논리 스크린 및 출력 스크린에서의 속성 정보 및 인터페이스 종류를 나타내는 예시도이다.6 is an exemplary diagram illustrating attribute information and interface types in a logical screen and an output screen.

도 7은 논리 스크린의 'z-order' 속성을 나타내는 예시도이다.7 is an exemplary diagram illustrating a 'z-order' attribute of a logical screen.

도 8a 및 도 8b는 논리 스크린의 'Display_Area' 속성을 나타내는 예시도이 다.8A and 8B are exemplary diagrams illustrating the property 'Display_Area' of a logical screen.

도 9는 두 개의 서비스가 하나의 출력 스크린에 매핑되어 출력되는 과정을 나타내는 예시도이다.9 is an exemplary diagram illustrating a process in which two services are mapped and output on one output screen.

도 10은 본 발명의 일 실시예에 따른 다중 스크린을 제공하는 장치의 구성을 나타내는 블록도이다.10 is a block diagram showing the configuration of an apparatus for providing multiple screens according to an embodiment of the present invention.

도 11은 본 발명의 일 실시예에 따라 다중 스크린을 동적으로 구성하는 방법을 나타내는 플로우 차트이다.11 is a flowchart illustrating a method of dynamically configuring multiple screens according to an embodiment of the present invention.

도 12는 본 발명의 실시에 따라 다중 스크린을 제공하기 위한 소프트웨어 아키텍처를 나타내는 예시도이다.12 is an exemplary diagram illustrating a software architecture for providing multiple screens in accordance with an embodiment of the present invention.

도 13은 본 발명의 실시에 따라 API 레이어를 구성하는 모듈들의 관계를 나타내는 예시도이다.13 is an exemplary view illustrating a relationship between modules configuring an API layer according to an embodiment of the present invention.

도 14는 도 13에서 도시된 각 모듈들에 의하여 복수 개의 서비스를 논리 스크린을 통하여 출력 스크린에 나타내는 과정을 도시한 플로우 차트이다.FIG. 14 is a flowchart illustrating a process of displaying a plurality of services on an output screen through a logical screen by each module illustrated in FIG. 13.

도 15는 본 발명의 실시예에 따른 검색 모듈의 동작을 나타낸 예시도이다.15 is an exemplary view illustrating an operation of a search module according to an embodiment of the present invention.

도 16a 내지 도 16f는 본 발명의 실시예에 따른 스크린 검색을 위한 코드의 예시도이다.16A through 16F are exemplary diagrams of code for screen searching according to an embodiment of the present invention.

도 17은 도 13에서 도시된 각 모듈들에 의하여 논리 스크린에 표현되는 서비스가 교환되는 과정을 도시한 플로우 차트이다.FIG. 17 is a flowchart illustrating a process of exchanging a service represented on a logical screen by each module illustrated in FIG. 13.

<도면의 주요 부분에 관한 부호의 설명><Explanation of symbols on main parts of the drawings>

910 : 방송 신호 수신 모듈910: broadcast signal receiving module

920a, 920b : 저장 매체920a, 920b: storage media

930 : 외부 입력 모듈930: external input module

940 : 디지털 신호 처리 모듈940: Digital Signal Processing Module

950 : 사용자/어플리케이션 인터페이스 모듈950: user / application interface module

960 : 검색 모듈960: Search Module

970 : 동작 모듈970: motion module

980 : 디스플레이 화면980: display screen

990 : 외부 출력 모듈990 external output module

본 발명은 다중 스크린을 제공하는 장치 및 상기 다중 스크린의 동적 구성 방법에 관한 것으로서, 더욱 상세하게는 물리적인 디스플레이 화면에 복수 개의 서비스를 표현하는 다수의 스크린을 동적으로 구성하기 위하여 장치에 존재하는 스크린들의 형태 및 연결 관계를 검색하는 다중 스크린을 제공하는 장치 및 상기 다중 스크린의 동적 구성 방법에 관한 것이다.The present invention relates to an apparatus for providing multiple screens and a method for dynamically configuring the multiple screens. More particularly, the present invention relates to a screen existing in a device for dynamically configuring a plurality of screens representing a plurality of services on a physical display screen. The present invention relates to a device for providing a multi-screen for retrieving the shape and the connection relationship of the two.

종래의 디지털 TV 또는 디지털 셋톱 박스(set-top box)와 같은 방송 수신 장치에서는 하나의 물리적인 디스플레이 화면에 하나의 컨텐츠만 보여주거나, 또는 하나의 물리적인 디스플레이 화면에서 주화면과 부화면의 두 가지 화면을 동시에 보여 주는 경우가 일반적이다.In a conventional broadcast receiver such as a digital TV or a digital set-top box, only one content is displayed on one physical display screen, or two main screens and a sub-screen are displayed on one physical display screen. It is common to show the screen at the same time.

이 때, 주화면과 부화면을 동시에 보여 주는 경우라 하더라도 방송 수신 장치에서 이미 정해진 몇 가지 방식으로만 두 화면을 배치할 수 있을 뿐이다. 그리고, 주화면에 보여지는 컨텐츠의 경우에만 컨텐츠를 구성하는 모든 요소(비디오, 오디오, 데이터 또는 이들의 조합)가 재생되고, 부화면을 통해서는 컨텐츠를 구성하는 일부 요소만 제한적으로 재생된다.In this case, even when the main screen and the sub-screen are simultaneously displayed, the two screens may be arranged only in a predetermined manner by the broadcast receiving apparatus. And only in the case of the content shown on the main screen, all elements constituting the content (video, audio, data, or a combination thereof) are played, and only some elements constituting the content are limitedly played through the sub-screen.

또한, 컨텐츠를 제공하는 소스로서 위성 방송, 지상파 방송, 케이블 방송과 같은 방송 서비스 외에도 DVD와 같은 저장 매체 또는 외부 입력 단자와 연결된 외부 기기 등이 있는데, 이렇게 다양한 소스에서 제공되는 컨텐츠를 어떻게 디스플레이 화면에 나타낼 지에 대해서도 제한적으로 고정되어 있다.In addition to the broadcast services such as satellite broadcasting, terrestrial broadcasting, and cable broadcasting as a source for providing contents, there are a storage medium such as a DVD or an external device connected to an external input terminal, and the like. It is also fixed on a limited basis.

한편, MHP (Multimedia Home Platform), ACAP (Advanced Common Application Platform), OCAP (Open Cable Application Platform) 등과 같은 인터렉티브 TV(Interactive TV)에 대한 어플리케이션 프로그램 환경에서는, 일반적으로 물리적인 디스플레이 화면을 통해 출력되는 스크린은 하나라고 가정한다.On the other hand, in an application program environment for an interactive TV such as a multimedia home platform (MHP), an advanced common application platform (ACAP), an open cable application platform (OCA), and the like, a screen that is generally output through a physical display screen Is assumed to be one.

예를 들어, 인터렉티브 TV에 대한 어플리케이션 프로그램 환경에서는 HAVi(Home Audio/Video Interoperability) 규격에 따른 사용자 인터페이스(user interface; UI)의 구조를 채용하고 있는데, HAVi UI 표준에서 스크린의 개수에 제한을 두지는 않으나, 실제 사용에서는 디스플레이 화면을 통해 출력되는 스크린은 하나인 것으로 가정하는 것이 보통이다.For example, the application program environment for interactive TV employs a user interface (UI) structure according to the HAVi (Home Audio / Video Interoperability) standard. However, the HAVi UI standard does not limit the number of screens. However, in actual use, it is common to assume that there is only one screen output through the display screen.

이러한 환경에서는, 복수의 컨텐츠들을 다수의 독립적인 스크린을 통해 보여 주면서, 동시에 각각의 스크린에 표현된 컨텐츠에 대해 디코딩, 디지털 신호 처리, 사용자 인터랙션(interaction) 처리 등을 수행하거나, 동적으로 어플리케이션 프로그램의 라이프 사이클(life-cycle)과 리소스(resource) 사용을 각각의 스크린 별로 제어하기 어렵다. In such an environment, a plurality of contents are displayed through a plurality of independent screens, and at the same time, decoding, digital signal processing, user interaction processing, and the like on the contents represented on each screen are performed dynamically, It is difficult to control life-cycle and resource usage on each screen.

따라서, 다양한 컨텐츠를 다양한 방식으로 디스플레이 화면에 구성하여 제공할 수 있는 방법이 필요하게 되었다.Accordingly, there is a need for a method for configuring and providing various contents on a display screen in various ways.

본 발명은 물리적인 디스플레이 화면에 복수 개의 서비스를 표현하는 다수의 스크린을 동적으로 구성하기 위하여 시스템에 존재하는 스크린들의 형태 및 연결 관계를 검색하는데 그 목적이 있다.An object of the present invention is to search for a form and a connection relationship of screens existing in a system in order to dynamically construct a plurality of screens representing a plurality of services on a physical display screen.

본 발명의 목적들은 이상에서 언급한 목적으로 제한되지 않으며, 언급되지 않은 또 다른 목적들은 아래의 기재로부터 당업자에게 명확하게 이해되어질 수 있을 것이다.The objects of the present invention are not limited to the above-mentioned objects, and other objects which are not mentioned will be clearly understood by those skilled in the art from the following description.

상기 목적을 달성하기 위하여, 본 발명의 실시예에 따른 다중 스크린을 제공하는 장치는 수신된 서비스를 표현하기 위한 적어도 하나 이상의 스크린을 생성하는 동작 모듈 및 상기 스크린 중 상기 서비스에 포함된 소정의 어플리케이션이 실행되는 스크린을 검색하는 검색 모듈을 포함한다.In order to achieve the above object, an apparatus for providing a multi-screen according to an embodiment of the present invention is an operation module for generating at least one screen for representing a received service and a predetermined application included in the service of the screen It includes a search module for searching the screen to be executed.

본 발명의 실시예에 따른 다중 스크린을 제공하는 장치는 수신된 서비스를 표현하기 위한 논리 스크린과 상기 논리 스크린이 매핑되는 출력 스크린을 생성하는 동작 모듈 및 상기 생성된 모든 논리 스크린과 출력 스크린을 검색하는 검색 모 듈을 포함한다.An apparatus for providing multiple screens according to an embodiment of the present invention is an operation module for generating a logical screen for representing a received service and an output screen to which the logical screen is mapped, and for searching all the generated logical screens and output screens. It includes a search module.

본 발명의 실시예에 따른 다중 스크린을 제공하는 장치는 수신된 서비스를 표현하기 위한 논리 스크린과 상기 논리 스크린이 매핑되는 출력 스크린을 생성하는 동작 모듈 및 상기 논리 스크린과 상기 출력 스크린을 검색하는 검색 모듈을 포함한다.An apparatus for providing multiple screens according to an embodiment of the present invention includes an operation module for generating a logical screen for representing a received service and an output screen to which the logical screen is mapped, and a search module for searching the logical screen and the output screen. It includes.

본 발명의 실시예에 따른 다중 스크린을 제공하는 장치는 서비스를 수신하는 방송 신호 수신 모듈과, 논리 스크린 및 상기 논리 스크린이 매핑되는 출력 스크린을 생성하는 동작 모듈 및 상기 서비스를 표현하는 스크린이 상기 논리 스크린인지 상기 출력 스크린인지 검색하는 검색 모듈을 포함한다.An apparatus for providing a multi-screen according to an embodiment of the present invention includes a broadcast signal receiving module for receiving a service, an operation module for generating a logic screen and an output screen to which the logic screen is mapped, and a screen representing the service. And a search module for searching whether the screen is the output screen.

본 발명의 실시예에 따른 다중 스크린의 동적 구성 방법은 수신된 서비스를 표현하기 위한 적어도 하나 이상의 스크린을 생성하는 단계 및 상기 스크린 중 상기 서비스에 포함된 소정의 어플리케이션이 실행되는 스크린을 검색하는 단계를 포함한다.According to an aspect of the present invention, there is provided a method of dynamically configuring a multi-screen, including generating at least one screen for representing a received service and searching for a screen on which a predetermined application included in the service is executed. Include.

본 발명의 실시예에 따른 다중 스크린의 동적 구성 방법은 수신된 서비스를 표현하기 위한 논리 스크린을 생성하는 단계와, 상기 논리 스크린이 매핑되는 출력 스크린을 생성하는 단계 및 상기 생성된 모든 논리 스크린과 출력 스크린을 검색하는 단계를 포함한다.According to an aspect of the present invention, there is provided a method of dynamically configuring a multi-screen, including generating a logical screen for representing a received service, generating an output screen to which the logical screen is mapped, and generating all the generated logical screens and outputs. Searching for the screen.

본 발명의 실시예에 따른 다중 스크린의 동적 구성 방법은 수신된 서비스를 표현하기 위한 논리 스크린을 생성하는 단계와, 상기 논리 스크린이 매핑되는 출력 스크린을 생성하는 단계 및 상기 논리 스크린과 상기 출력 스크린을 검색하는 단계 를 포함한다.According to an aspect of the present invention, there is provided a method of dynamically configuring a multi-screen, including generating a logical screen for representing a received service, generating an output screen to which the logical screen is mapped, and generating the logical screen and the output screen. Searching.

본 발명의 실시예에 따른 다중 스크린의 동적 구성 방법은 서비스를 수신하는 단계와, 논리 스크린을 생성하는 단계와, 상기 논리 스크린이 매핑되는 출력 스크린을 생성하는 단계 및 상기 서비스를 표현하는 스크린이 상기 논리 스크린인지 상기 출력 스크린인지 검색하는 단계를 포함한다.According to an aspect of the present invention, there is provided a method of dynamically configuring a multi-screen, including receiving a service, generating a logical screen, generating an output screen to which the logical screen is mapped, and displaying a screen. Searching whether it is a logical screen or the output screen.

기타 실시예들의 구체적인 사항들은 상세한 설명 및 도면들에 포함되어 있다.Specific details of other embodiments are included in the detailed description and the drawings.

본 발명의 이점 및 특징, 그리고 그것들을 달성하는 방법은 첨부되는 도면과 함께 상세하게 후술되어 있는 실시예들을 참조하면 명확해질 것이다. 그러나 본 발명은 이하에서 개시되는 실시예들에 한정되는 것이 아니라 서로 다른 다양한 형태로 구현될 수 있으며, 단지 본 실시예들은 본 발명의 개시가 완전하도록 하고, 본 발명이 속하는 기술분야에서 통상의 지식을 가진 자에게 발명의 범주를 완전하게 알려주기 위해 제공되는 것이며, 본 발명은 청구항의 범주에 의해 정의될 뿐이다. 명세서 전체에 걸쳐 동일 참조 부호는 동일 구성 요소를 지칭한다.Advantages and features of the present invention and methods for achieving them will be apparent with reference to the embodiments described below in detail with the accompanying drawings. However, the present invention is not limited to the embodiments disclosed below, but can be implemented in various different forms, and only the embodiments make the disclosure of the present invention complete, and the general knowledge in the art to which the present invention belongs. It is provided to fully inform the person having the scope of the invention, which is defined only by the scope of the claims. Like reference numerals refer to like elements throughout.

이하, 본 발명의 실시예들에 의한 다중 스크린을 제공하는 장치 및 상기 다중 스크린을 동적으로 구성하는 방법을 설명하기 위한 블록도 또는 처리 흐름도에 대한 도면들을 참고하여 본 발명에 대해 설명하도록 한다. 이 때, 처리 흐름도 도면들의 각 블록과 흐름도 도면들의 조합들은 컴퓨터 프로그램 인스트럭션들에 의해 수행될 수 있음을 이해할 수 있을 것이다. 이들 컴퓨터 프로그램 인스트럭션들은 범용 컴퓨터, 특수용 컴퓨터 또는 기타 프로그램 가능한 데이터 프로세싱 장비의 프로세서에 탑재될 수 있으므로, 컴퓨터 또는 기타 프로그램 가능한 데이터 프로세싱 장비의 프로세서를 통해 수행되는 그 인스트럭션들이 흐름도 블록(들)에서 설명된 기능들을 수행하는 수단을 생성하게 된다. 이들 컴퓨터 프로그램 인스트럭션들은 특정 방식으로 기능을 구현하기 위해 컴퓨터 또는 기타 프로그램 가능한 데이터 프로세싱 장비를 지향할 수 있는 컴퓨터 이용 가능 또는 컴퓨터 판독 가능 메모리에 저장되는 것도 가능하므로, 그 컴퓨터 이용가능 또는 컴퓨터 판독 가능 메모리에 저장된 인스트럭션들은 흐름도 블록(들)에서 설명된 기능을 수행하는 인스트럭션 수단을 내포하는 제조 품목을 생산하는 것도 가능하다. 컴퓨터 프로그램 인스트럭션들은 컴퓨터 또는 기타 프로그램 가능한 데이터 프로세싱 장비 상에 탑제되는 것도 가능하므로, 컴퓨터 또는 기타 프로그램 가능한 데이터 프로세싱 장비 상에서 일련의 동작 단계들이 수행되어 컴퓨터로 실행되는 프로세스를 생성해서 컴퓨터 또는 기타 프로그램 가능한 데이터 프로세싱 장비를 수행하는 인스트럭션들은 흐름도 블록(들)에서 설명된 기능들을 실행하기 위한 단계들을 제공하는 것도 가능하다. Hereinafter, an exemplary embodiment of the present invention will be described with reference to a block diagram or a flowchart illustrating a method for dynamically configuring the multi-screen and a method for dynamically configuring the multi-screen according to embodiments of the present invention. At this point, it will be understood that each block of the flowchart illustrations and combinations of flowchart illustrations may be performed by computer program instructions. Since these computer program instructions may be mounted on a processor of a general purpose computer, special purpose computer, or other programmable data processing equipment, those instructions executed through the processor of the computer or other programmable data processing equipment may be described in flow chart block (s). It will create means to perform the functions. These computer program instructions may be stored in a computer usable or computer readable memory that can be directed to a computer or other programmable data processing equipment to implement functionality in a particular manner, and thus the computer usable or computer readable memory. It is also possible for the instructions stored in to produce an article of manufacture containing instruction means for performing the functions described in the flowchart block (s). Computer program instructions It is also possible to mount on a computer or other programmable data processing equipment, so that a series of operating steps are performed on the computer or other programmable data processing equipment to create a computer-implemented process to perform the computer or other programmable data processing equipment. It is also possible for the instructions to provide steps for performing the functions described in the flowchart block (s).

또한, 각 블록은 특정된 논리적 기능(들)을 실행하기 위한 하나 이상의 실행 가능한 인스트럭션들을 포함하는 모듈, 세그먼트 또는 코드의 일부를 나타낼 수 있다. 또, 몇 가지 대체 실행예들에서는 블록들에서 언급된 기능들이 순서를 벗어나서 발생하는 것도 가능함을 주목해야 한다. 예컨대, 잇달아 도시되어 있는 두 개의 블록들은 사실 실질적으로 동시에 수행되는 것도 가능하고 또는 그 블록들이 때때로 해당하는 기능에 따라 역순으로 수행되는 것도 가능하다.In addition, each block may represent a portion of a module, segment, or code that includes one or more executable instructions for executing a specified logical function (s). It should also be noted that in some alternative implementations, the functions noted in the blocks may occur out of order. For example, the two blocks shown in succession may in fact be executed substantially concurrently, or the blocks may sometimes be executed in the reverse order, depending on the corresponding function.

한편, 본 발명에 대한 설명을 용이하게 하기 위하여 본 발명과 관련된 기본 적인 개념을 정의하도록 한다.On the other hand, to facilitate the description of the present invention to define the basic concepts related to the present invention.

'서비스(service)'는 하나의 묶음으로 표현되는 멀티미디어 컨텐츠로서, 다수의 서비스 컴포넌트(service component)들이 하나의 서비스를 이루게 된다.'Service' is a multimedia content represented by a bundle, and a plurality of service components make up a service.

'서비스 컴포넌트(service component)'는 서비스(service)를 구성하는 일 부분으로서, 비디오 컴포넌트(video component), 오디오 컴포넌트(audio component), 데이터 컴포넌트(data component) 등을 포함한다. 이 때, 데이터 컴포넌트(data component)는 서비스(service) 내에 존재하는 어플리케이션을 가리킨다.The 'service component' is a part constituting a service, and includes a video component, an audio component, a data component, and the like. At this time, the data component refers to an application existing in a service.

또한, 어플리케이션은 언바운드 어플리케이션(Unbound Application)과 서비스 바운드 어플리케이션(Service Bound Application)으로 구별될 수 있는데, 언바운드 어플리케이션은 특정 채널과 관련되지 않으므로 어플리케이션의 실행이 채널 전환에 영향을 받지 않는다. 또한, 일반적으로 높은 우선 순위를 가지고 있으므로, 실행을 위한 자원이 원활하게 할당된다. 모니터 어플리케이션은 가장 높은 우선 순위를 가질 수 있는 특수한 언바운드 어플리케이션에 해당된다.In addition, an application may be classified into an unbound application and a service bound application. Since the unbound application is not related to a specific channel, execution of the application is not affected by channel switching. Also, since they generally have a high priority, resources for execution are smoothly allocated. The monitor application is a special unbound application that can have the highest priority.

한편, 서비스 바운드 어플리케이션은 전송 스트림(transport stream)과 관련된 것으로서, 언바운드 어플리케이션에 비하여 일반적으로 낮은 우선 순위가 부여된다. 서비스 바운드 어플리케이션은 결정적인(critical) 시스템 기능은 수행하지 않으며, 자원에 대한 경쟁이 발생하는 경우 언바운드 어플리케이션보다 자원 할당을 포기할 가능성이 더욱 크다. 서비스 바운드 어플리케이션은 현재 전송 중인 스트림과 연동하여 동작하는 연동형과 전송 중인 스트림에 무관하게 동작하는 비연동형이 있다.Service-bound applications, on the other hand, are related to transport streams and are generally given a lower priority than unbound applications. Service bound applications do not perform critical system functions and are more likely to give up resource allocation than unbound applications if contention for resources occurs. There are two types of service-bound applications that operate in conjunction with the current stream and non-interworking that operate independently of the stream being transmitted.

'서비스 컨텍스트(service context)'는 서비스(service)를 실행하는데 관계되는 각종 리소스(resource) 정보, 디바이스(device) 정보 및 실행 상태 정보 등을 포함하고 있으며, 서비스(service) 실행을 제어할 수 있는 객체를 나타낸다.'Service context' includes various resource information, device information, and execution status information related to executing a service, and can control service execution. Represents an object.

'디스플레이 화면(physical display device)'은 서비스(service)의 내용이 실제로 표현되는 물리적인 장치(device), 서비스의 내용이 출력되는 외부 출력 포트(output port) 또는 서비스가 저장되는 저장 장치를 의미한다.'Display screen (physical display device)' refers to the physical device (device) in which the contents of the service is actually expressed, the external output port (output port) in which the contents of the service are output, or the storage device in which the service is stored. .

'출력 스크린(display screen)'은 디스플레이 화면에 실제로 출력되는 스크린으로서, 임의의 서비스가 출력 스크린에 직접 설정되어 디스플레이 화면을 통하여 표현되거나, 출력 스크린의 일정한 영역으로 매핑된 적어도 하나 이상의 논리 스크린이 디스플레이 화면을 통하여 출력된다.An 'display screen' is a screen that is actually output on a display screen, in which any service is set directly on the output screen and represented through the display screen, or at least one logical screen mapped to a certain area of the output screen is displayed. It is output through the screen.

'논리 스크린(logical screen)'은 임의의 서비스가 표현되는 공간으로서, 출력 스크린에 매핑되기 전에는 메모리상에 가상적으로만 존재하며 실제 디스플레이 화면에는 표현되지 않는다.The 'logical screen' is a space in which an arbitrary service is represented and exists virtually only in memory before being mapped to an output screen and is not represented on an actual display screen.

또한, 논리 스크린과 출력 스크린은 백그라운드 스틸 이미지(background still image), 비디오 래스터(video raster) 그리고 그래픽 래스터(graphic raster)의 조합으로 구성될 수 있는데, 여기에서 그래픽 래스터(graphic raster)는 텍스트(text), 선(line), 컬러(color) 그리고 이미지(image)가 합성되거나, 비디오 프레임들이 혼합되어 제공될 수 있다.In addition, the logic screen and the output screen can consist of a combination of background still images, video rasters, and graphic rasters, where the graphic raster is text. ), Lines, colors and images may be synthesized or video frames may be provided in a mixture.

'메인 서비스(main service)'는 사용자가 디스플레이 화면에 나타나는 메뉴 또는 리모컨을 통하거나 어플리케이션이 API를 통해 주 서비스로서 선택한 서비스 를 의미하며, 메인 서비스가 표현되는 스크린을 '메인 스크린(main screen)'이라고 한다.The 'main service' refers to a service selected by the user as a main service through a menu or a remote control displayed on the display screen or by an application through the API, and refers to a screen on which the main service is represented. It is called.

'PiP 스크린(Picture-in-Picture screen)'은 도 1의 (a) 내지 (d)에서 도시하고 있는 것과 같이 다른 스크린 내의 일부 영역을 차지하는 스크린과, 도 1의 (e) 및 (f)에서 도시하고 있는 것과 같이 다른 스크린과 겹치지 않는 영역에 동시에 보여지는 스크린을 포함하고, 또한 도 1의 (g) 및 (h)에서 도시하고 있는 것과 같이 디스플레이 화면 내에서 임의의 위치와 영역에 보여지거나, 다른 스크린과 겹쳐져서 표현되는 스크린을 포함하는 개념으로 이해될 수 있다.'PiP Screen (Picture-in-Picture screen)' is a screen occupying some area in another screen as shown in Figs. 1A to 1D, and in Figs. A screen which is simultaneously shown in an area which does not overlap with another screen as shown, and also shown in any position and area within the display screen as shown in FIGS. 1G and 1H, or It can be understood as a concept including a screen that is displayed in superimposition with another screen.

도 2는 본 발명의 일 실시예에 따른 논리 스크린과 출력 스크린과의 관계를 나타내는 예시도이다.2 is an exemplary view showing a relationship between a logic screen and an output screen according to an embodiment of the present invention.

도 2를 참조하면, 서비스는 논리 스크린(210, 212, 214)을 통하여 표현될 수 있고, 이러한 논리 스크린들은 소정의 매핑 블록(230)에 의해 출력 스크린(220, 222, 224)으로 매핑되어 표현될 수 있다.Referring to FIG. 2, a service may be represented through logic screens 210, 212, and 214, which are then mapped and represented by output mappings 220, 222, and 224 by a predetermined mapping block 230. Can be.

이 때, 220으로 참조되는 출력 스크린은 210과 212로 참조되는 논리 스크린이 매핑되어 표현되고 있고, 222로 참조되는 출력 스크린은 212와 214로 참조되는 논리 스크린이 매핑되어 표현되고 있으며, 224로 참조되는 출력 스크린은 210, 212 및 214로 참조되는 논리 스크린이 매핑되어 표현되고 있다.In this case, the output screen referred to as 220 is represented by mapping logic screens referred to as 210 and 212, and the output screen referred to as 222 is represented as mapped logical logic screens referred to as 212 and 214, and referred to as 224. The output screen is mapped with the logical screens referred to as 210, 212 and 214.

이와 같이, 서비스가 표현되는 적어도 1이상의 논리 스크린은 매핑 블록(230)에 의해 출력 스크린의 임의의 영역으로 매핑될 수 있다.As such, at least one logical screen on which the service is represented may be mapped to any area of the output screen by the mapping block 230.

한편, 매핑 블록(230)은 논리 스크린과 출력 스크린을 매핑하도록 하는 다양 한 정보의 집합체로서 이해될 수 있다. 이러한 정보의 예로서, 논리 스크린이 출력 스크린으로 매핑되는 영역의 좌표 정보, 논리 스크린 및 출력 스크린을 구별하는 식별 정보, 출력 스크린에 다수의 논리 스크린이 표현되는 순서에 대한 정보 등을 포함할 수 있다.On the other hand, the mapping block 230 may be understood as a collection of various information for mapping the logical screen and the output screen. Examples of such information may include coordinate information of an area where the logical screen is mapped to the output screen, identification information for distinguishing the logical screen from the output screen, information about the order in which the plurality of logical screens are displayed on the output screen, and the like. .

매핑 블록(230)은 논리 스크린의 크기를 변경하여 출력 스크린의 일정한 영역으로 할당할 수 있다. 즉, 매핑 블록(230)은 논리 스크린에 대한 스케일링(scaling) 기능 및 위치 할당 기능을 수행할 수 있으며, 도 3a 내지 도 3e에서는 이러한 매핑 블록, 즉 매퍼(mapper)를 포함하는 스크린의 구성을 나타내고 있다.The mapping block 230 may change the size of the logical screen and allocate the same to a predetermined area of the output screen. That is, the mapping block 230 may perform a scaling function and a position allocation function for the logical screen, and FIGS. 3A to 3E illustrate the configuration of a screen including such a mapping block, that is, a mapper. have.

도 3a를 참조하면, 백그라운드 스틸 이미지(background still image)(B), 비디오 래스터(video raster)(V) 그리고 그래픽 래스터(graphic raster)(G)의 조합으로 이루어진 메인 스크린은 매퍼(mapper)에 의해 크기는 그대로 유지하면서 출력 스크린의 전체에 매핑된다. 그리고 비디오 성분만을 갖는 PiP 스크린은 매퍼(mapper)에 의해 그 크기가 작아지면서 출력 스크린의 일정 영역에 매핑된다. 이 때, 매핑된 PiP 스크린은 메인 스크린 위에 놓여지게 되며 이는 Z 값에 의해 결정된다. Z는 z-order 값을 나타내는 것으로서, z-order 에 대해서는 후술하기로 한다. 또한, 오버레이 스크린(overlay screen)이 상기 출력 스크린과 합성될 수 있는데, 오버레이 스크린은 가장 바깥 쪽에 놓여지는 특별한 스크린으로서, 예를 들어 자막(caption)을 제공할 필요가 있는 경우에 이용될 수 있다. PiP 스크린은 도 3a에서와 같이 비디오 성분만을 갖을 수도 있으나, 도 3b에 도시된 바와 같이 백그라운드 스틸 이미지(background still image)(B), 비디오 래스터(video raster)(V) 그리고 그래픽 래스터(graphic raster)(G)의 조합으로 이루어질 수도 있다.Referring to FIG. 3A, a main screen composed of a combination of a background still image (B), a video raster (V), and a graphic raster (G) is defined by a mapper. It is mapped to the entirety of the output screen while maintaining the size. PiP screens with only video components are mapped to a given area of the output screen as their size is reduced by a mapper. At this point, the mapped PiP screen is placed on the main screen, which is determined by the Z value. Z denotes a z-order value, and the z-order will be described later. In addition, an overlay screen can be composited with the output screen, which is the outermost special screen that can be used, for example, when it is necessary to provide a caption. The PiP screen may have only video components as in FIG. 3A, but as shown in FIG. 3B, a background still image (B), a video raster (V) and a graphic raster are shown. It may consist of a combination of (G).

도 3c를 참조하면, 백그라운드 스틸 이미지(B), 비디오 래스터(V) 그리고 그래픽 래스터(G)의 조합으로 이루어진 메인 스크린은 매퍼(mapper)에 의해 크기는 그대로 유지하면서 출력 스크린의 전체에 매핑된다. 그리고 비디오 성분만을 갖는 2개의 PiP 스크린들(#1, #2)이 각각 매퍼(mapper)에 의해 그 크기가 작아지면서 출력 스크린의 일정 영역으로 매핑된다. 이 때, 매핑된 PiP 스크린들은 메인 스크린 위에 놓여지게 되며 이 때 Z 값은 동일하게 유지될 수 있다. 또한, 오버레이 스크린(overlay screen)이 상기 출력 스크린과 합성될 수 있다. 스크린 구성은 도 3c에서와 같이 비디오 성분만을 갖는 복수의 PiP 스크린들을 포함할 수도 있으나, 도 3d에 도시된 바와 같이 백그라운드 스틸 이미지(B), 비디오 래스터(V) 그리고 그래픽 래스터(G)의 조합으로 이루어진 복수의 PiP 스크린들로 구성될 수도 있다.Referring to FIG. 3C, a main screen made up of a combination of background still image (B), video raster (V) and graphic raster (G) is mapped by the mapper to the entirety of the output screen while maintaining its size. The two PiP screens # 1 and # 2 having only the video component are each mapped by a mapper to a certain area of the output screen as their size is reduced. At this time, the mapped PiP screens are placed on the main screen, and the Z value can remain the same. In addition, an overlay screen can be combined with the output screen. The screen configuration may include a plurality of PiP screens having only video components as in FIG. 3C, but as shown in FIG. 3D in a combination of background still image (B), video raster (V) and graphic raster (G). It may also consist of a plurality of PiP screens.

도 3e에서는 POP 스크린이 도시되고 있는데, 종래의 PiP 스크린이 메인 스크린의 내부에서 표현되는 스크린이라고 한다면, POP 스크린은 메인 스크린의 외부에서 표현되는 스크린이라고 이해될 수 있다. 도 3e를 참조하면 백그라운드 스틸 이미지(B), 비디오 래스터(V) 그리고 그래픽 래스터(G)의 조합으로 이루어진 복수의 POP 스크린들(#1, #2)이 각각 매퍼(mapper)에 의해 그 크기가 작아지면서 출력 스크린의 일정 영역으로 매핑된다. 이 때, 매핑된 POP 스크린들(#1, #2)의 Z 값은 동일하게 유지될 수 있다. 그리고, 오버레이 스크린(overlay screen)이 상기 출력 스크린과 합성되어 표현될 수 있다.In FIG. 3E, a POP screen is illustrated. If the conventional PiP screen is a screen displayed inside the main screen, the POP screen may be understood as a screen displayed outside the main screen. Referring to FIG. 3E, a plurality of POP screens # 1 and # 2 having a combination of a background still image (B), a video raster (V), and a graphic raster (G) are each sized by a mapper. It gets smaller and maps to a certain area of the output screen. At this time, the Z values of the mapped POP screens # 1 and # 2 may be kept the same. In addition, an overlay screen may be represented by being synthesized with the output screen.

또한, 매핑 블록(230)은 각종 컴퓨터 프로그램 언어로 작성되어 실행되는 인 터페이스, 함수 등으로 구현될 수 있으며, 위와 같은 정보들은 파라미터로 하여 논리 스크린과 출력 스크린과의 관계를 생성하거나 변경할 수도 있다.In addition, the mapping block 230 may be implemented as an interface, a function, or the like, which is written and executed in various computer program languages. The above information may be used as a parameter to create or change a relationship between the logical screen and the output screen. .

또한, 매핑 블록(230)은 논리 스크린과 출력 스크린간에 매핑 기능을 수행하도록 하드웨어로 구현될 수도 있다.In addition, the mapping block 230 may be implemented in hardware to perform a mapping function between the logical screen and the output screen.

출력 스크린에는 다양한 소스(source)들로부터 제공되는 서비스들이 표현되어 디스플레이 화면을 통하여 출력될 수 있는데, 도 4에서 이를 나타내고 있다.In the output screen, services provided from various sources may be represented and output through a display screen, which is illustrated in FIG. 4.

일반적으로 서비스를 제공하는 소스로서, 지상파 방송(320), 케이블 방송(330)과 같은 방송 서비스를 제공하는 소스가 있고, PVR(Personal Video Recorder)(340)과 같이 소정의 저장 매체에 저장된 서비스를 제공하는 소스도 있다. 또한, 도 4에서는 도시되고 있지 않으나, 유선 또는 무선 네트워크를 통하여 서비스를 제공하는 소스도 여기에 포함될 수 있다.Generally, as a source for providing a service, there is a source for providing a broadcast service such as terrestrial broadcasting 320 or cable broadcasting 330, and a service stored in a predetermined storage medium such as a personal video recorder (PVR) 340. There is also a source available. In addition, although not shown in FIG. 4, a source for providing a service through a wired or wireless network may also be included.

이 때, 방송 수신 장치(310)는 이러한 소스들로부터 서비스를 수신하고, 각각의 서비스를 표현하는 논리 스크린을 생성한다.At this time, the broadcast receiving device 310 receives a service from these sources, and generates a logical screen representing each service.

그리고 나서, 기 설정된 방식, 사용자 또는 어플리케이션에 의해 설정된 방식에 따라 임의의 서비스가 출력 스크린에 직접 설정되어 디스플레이 화면(350)을 통하여 표현되거나, 출력 스크린의 일정한 영역으로 매핑된 적어도 하나 이상의 논리 스크린이 디스플레이 화면(350)을 통하여 출력된다. 도 4에서는 지상파 방송(320), 케이블 방송(330) 그리고 PVR(340)에 의해 제공되는 서비스가 디스플레이 화면(350)을 통해 표현되는 것을 나타내고 있다.Then, according to a preset method, a method set by a user or an application, any service is directly set on the output screen and represented through the display screen 350 or at least one logical screen mapped to a predetermined area of the output screen. It is output through the display screen 350. In FIG. 4, the services provided by the terrestrial broadcast 320, the cable broadcast 330, and the PVR 340 are represented through the display screen 350.

도 4에서는 서비스를 제공하는 소스의 예로서, 지상파 방송(320), 케이블 방 송(330), PVR(Personal Video Recorder)(340)을 도시하고 있지만, 서비스를 제공하는 소스는 이에 한정되지 않고, 하나의 묶음으로 표현되는 멀티미디어 컨텐츠를 제공한다면 본 발명에서의 소스에 포함될 수 있다.In FIG. 4, as an example of a source for providing a service, a terrestrial broadcast 320, a cable broadcast 330, and a personal video recorder (PVR) 340 are illustrated, but a source for providing a service is not limited thereto. If the multimedia content is represented as a bundle can be included in the source in the present invention.

한편, 본 발명에서의 서비스에는 추상 서비스(abstract service)와 비추상 서비스(non-abstract service)가 있는데 이를 도 5a와 도 5b에서 각각 도시하고 있다.Meanwhile, the services of the present invention include an abstract service and a non-abstract service, which are illustrated in FIGS. 5A and 5B, respectively.

추상 서비스(abstract service)는 방송 신호로부터 실시간 전달되는 서비스가 아닌 방송 채널에 대하여 독립된 서비스로서, 서비스 컴포넌트(service component) 중에서 비디오 컴포넌트, 오디오 컴포넌트가 없이, 데이터 컴포넌트, 즉 어플리케이션만으로 이루어진 서비스가 추상 서비스에 해당될 수 있다. 예를 들어, OCAP(Open Cable Application Platform) 규격에서 언바운드 어플리케이션들로 이루어진 서비스가 여기에 속한다.An abstract service is an independent service for a broadcast channel, not a service delivered in real time from a broadcast signal. Among the service components, an abstract service includes a data component, that is, an application only, without a video component or an audio component. It may correspond to. For example, services that consist of unbound applications in the Open Cable Application Platform (OCAP) specification fall into this category.

비추상 서비스(non-abstract service)는 추상 서비스를 제외한 나머지 서비스로 이해될 수 있다. A non-abstract service can be understood as a service other than an abstract service.

본 발명에서는 추상 서비스와 비추상 서비스 각각에 대하여 독립성을 부여할 수 있다. 예를 들어, 추상 서비스는 논리 스크린을 거치지 않고 직접 출력 스크린에 설정되고, 비추상 서비스는 논리 스크린에 표현되어 추상 서비스가 설정된 출력 스크린으로 매핑될 수 있다. 그리고 나서, 상기 출력 스크린이 디스플레이 화면을 통하여 출력될 수 있는데, 이렇게 함으로써 하나의 출력 스크린에서 추상 서비스와 비추상 서비스가 독립적으로 표현될 수 있다. 또한, 추상 서비스와 비추상 서비스 모두 각각 별도의 논리 스크린에 매핑된 후 각각의 논리 스크린이 하나의 출력 스크린으로 매핑될 수도 있다. 즉, 추상 서비스와 비추상 서비스는 각각 독립된 형태로서 출력 스크린에 표현될 수 있다.In the present invention, independence may be provided for each of the abstract service and the non-abstract service. For example, an abstract service may be set on an output screen directly without going through a logical screen, and a non-abstract service may be represented on a logical screen and mapped to an output screen on which an abstract service is set. The output screen can then be output via the display screen, whereby the abstract and non-abstract services can be represented independently on one output screen. In addition, both abstract and non-abstract services may be mapped to separate logical screens, and then each logical screen may be mapped to one output screen. In other words, the abstract service and the non-abstract service may be represented on the output screen as independent forms.

한편, 본 발명에서의 논리 스크린과 출력 스크린은 각각 별도의 객체로서 정의될 수도 있으나, '스크린'이라는 하나의 객체가 갖는 속성 정보에 따라 '스크린'이 논리 스크린으로서 기능하거나 출력 스크린으로서 기능할 수도 있다.Meanwhile, in the present invention, the logical screen and the output screen may be defined as separate objects, but the screen may function as the logical screen or the output screen according to the attribute information of one object called the screen. have.

즉, 스크린 객체에 관한 속성 정보들 중에서 타입(Type) 정보를 통해서 스크린이 논리 스크린인지 출력 스크린인지를 알 수 있다.That is, it is possible to know whether the screen is a logical screen or an output screen through type information among attribute information about the screen object.

이러한 스크린 객체의 속성 정보로서, 'Type', 'z-order', 'Display_Area', 'Visibility', 'Associated_Display_Screen', 'Associated_Service_Contexts', 'OutputPort' 등과 같은 속성 정보들이 있다.As attribute information of the screen object, there are attribute information such as 'Type', 'z-order', 'Display_Area', 'Visibility', 'Associated_Display_Screen', 'Associated_Service_Contexts', and 'OutputPort'.

도 6은 스크린 객체의 속성 정보와 이러한 속성 정보들을 처리하는 인터페이스의 종류를 나타내고 있다.6 shows the attribute information of the screen object and the type of interface for processing the attribute information.

'Type' 속성(510)은 스크린이 논리 스크린인지 출력 스크린인지를 나타내는 속성 정보이다.'Type' attribute 510 is attribute information indicating whether the screen is a logical screen or an output screen.

'z-order' 속성(520)은 논리 스크린들이 출력 스크린 상에서 표현될 때 z축 상에서의 순서를 결정하기 위한 것으로서, 도 7에서는 논리 스크린이 출력 스크린 상에서 z-order 속성에 따라 어떻게 보여지는지를 예시하고 있다.The 'z-order' attribute 520 is for determining the order on the z-axis when the logical screens are represented on the output screen, and FIG. 7 illustrates how the logical screen appears according to the z-order attribute on the output screen. Doing.

도 7에서 출력 스크린(610) 상에는 제 1 논리 스크린(620)과 제 2 논리 스크린(630)이 일정한 영역에 매핑되어 표현되고 있다. 이 때, 제 1 논리 스크린(620) 이 출력 스크린 상에서 표현되고, 그 위로 제 2 논리 스크린(630)이 표현되고 있다. 즉, z축 방향으로 출력 스크린(610), 제 1 논리 스크린(620) 그리고 제 2 논리 스크린(630)의 순서로 표현되고 있는데, 이러한 경우에 제 1 논리 스크린(620)의 z-order 속성값이 1로, 제 2 논리 스크린(620)의 z-order 속성값이 2로 설정될 수 있는 것이다. 이 때, z-order 속성값은 출력 스크린의 z축 상에서 논리 스크린이 표현되는 순서를 가리키는 정보라면 어떠한 숫자 또는 문자 형태도 가능하다.In FIG. 7, the first logical screen 620 and the second logical screen 630 are mapped to a certain area on the output screen 610. At this time, the first logical screen 620 is represented on the output screen, and the second logical screen 630 is represented above it. That is, it is expressed in the order of the output screen 610, the first logical screen 620 and the second logical screen 630 in the z-axis direction, in this case the z-order attribute value of the first logical screen 620 With this 1, the z-order attribute value of the second logical screen 620 can be set to 2. At this time, the z-order attribute value can be in any number or character form as long as it indicates the order in which the logical screen is expressed on the z axis of the output screen.

'Display_Area' 속성(530)은 논리 스크린이 출력 스크린에 매핑되어 출력될 출력 스크린의 영역에 대한 정보를 의미하는데, 도 8a 및 도 8b에서 이를 예시하고 있다.The 'Display_Area' property 530 indicates information about an area of an output screen to be output by mapping a logical screen to an output screen, which is illustrated in FIGS. 8A and 8B.

도 8a은 논리 스크린(710)이 출력 스크린(720)의 전체 영역에 매핑되어 출력되는 것을 나타내고 있으며, 도 8b는 논리 스크린(730)이 출력 스크린(740)의 일부 영역에 매핑되어 출력되는 것을 나타내고 있다.FIG. 8A illustrates that the logic screen 710 is mapped to the entire area of the output screen 720 and is output. FIG. 8B illustrates that the logic screen 730 is mapped and output to a partial area of the output screen 740. have.

이 때, 'Display_Area' 속성(530)을 나타내는 정보는 출력 스크린 상의 2차원 좌표 정보이거나, 출력 스크린 상에서의 특정 위치 및 상기 특정 위치로부터의 오프셋(offset) 값으로 표현될 수 있다.In this case, the information representing the 'Display_Area' attribute 530 may be two-dimensional coordinate information on the output screen, or may be expressed as a specific position on the output screen and an offset value from the specific position.

'Visibility' 속성(540)은 논리 스크린이 출력 스크린 상에 보여질 지의 여부를 결정하는 속성으로서, 이 속성 값을 변경함으로써, 논리 스크린을 물리적인 디스플레이 화면에 보이게 하거나 사라지게 할 수 있다.The 'Visibility' attribute 540 is an attribute that determines whether or not the logical screen is to be shown on the output screen. By changing this attribute value, the logical screen can be made visible or disappeared on the physical display screen.

'Associated_Display_Screen' 속성(550)은 해당 논리 스크린과 연결을 맺은 출력 스크린들의 식별 정보를 나타낸다. 출력 스크린에 연결되어 있지 않은 논리 스크린은 디스플레이 화면에 보여지지 않거나, 다른 외부 출력으로 보내지지 않는다.The 'Associated_Display_Screen' property 550 indicates identification information of output screens associated with the logical screen. Logical screens that are not connected to an output screen are not shown on the display screen or sent to other external outputs.

'Associated_Service_Contexts' 속성(560)은 논리 스크린 또는 출력 스크린 자신에게 연결된 서비스 컨텍스트들에 대한 정보를 나타내는데, 서비스 컨텍스트에 설정된 서비스가 논리 스크린 또는 출력 스크린에 표현된다.The 'Associated_Service_Contexts' attribute 560 represents information about service contexts associated with the logical screen or output screen itself, with the service set in the service context being represented on the logical screen or output screen.

'OutputPort' 속성(570)은 출력 스크린이 출력되는 대상에 대한 정보를 나타내는데, 출력 스크린이 출력되는 대상으로서 디스플레이 화면, 유/무선 통신 매체, 각종 저장 매체 등을 포함할 수 있다.The 'OutputPort' attribute 570 indicates information about an object on which an output screen is output, and may include a display screen, a wired / wireless communication medium, and various storage media as an object on which the output screen is output.

한편, 도 6에 도시된 속성 정보에 대한 값을 알아 오거나 변경하기 위한 인터페이스들이 제공될 수 있는데, 여기에는 도 6에 도시한 바와 같이, 속성 정보의 값을 설정하거나, 논리 스크린을 출력 스크린과 연결하기 위한 'set' 인터페이스, 속성 정보의 값을 추가하거나 또는 논리 스크린을 서비스와 연결하기 위한 'add' 인터페이스, 속성 정보의 값을 알아 오기 위한 'get' 인터페이스, 속성 정보의 값을 삭제하기 위한 'remove' 인터페이스 등이 있다. 이러한 인터페이스는 각각의 기능을 수행하는 프로세스(process), 함수(function), 프로시저(procedure), 메소드(method) 등으로 이해될 수 있다.Meanwhile, interfaces for acquiring or changing the value of the attribute information shown in FIG. 6 may be provided, as shown in FIG. 6, setting a value of the attribute information or connecting a logical screen to an output screen. 'Set' interface to add the value of the property information or 'add' interface to connect the logical screen with the service, 'get' interface to get the value of the property information, '' to delete the value of the property information remove 'interface. Such an interface may be understood as a process, a function, a procedure, a method, or the like that performs each function.

예컨대, 'getDisplayScreen(void)' 메소드는 현재 스크린과 연관된 출력 스크린을 반환하는 기능을 한다. 예를 들어 현재 스크린이 논리 스크린인 경우에는 연관된 출력 스크린이 반환되고, 현재 스크린이 출력 스크린인 경우에는 현재 스크린에 대한 참조 정보가 반환되며, 현재 스크린이 논리 스크린이지만 연관된 출력 스크린이 존재하지 않는 경우에는 'NULL'이 반환된다.For example, the 'getDisplayScreen (void)' method functions to return an output screen associated with the current screen. For example, if the current screen is a logical screen, the associated output screen is returned. If the current screen is an output screen, reference information about the current screen is returned. If the current screen is a logical screen but no associated output screen exists. Returns null.

또 다른 예로, 'public void setDisplayArea(HScreenRectangle rect) throws SecurityException, IllegalStateException' 메소드는 현재의 논리 스크린을 연관된 출력 스크린의 소정의 영역으로 연관시키는 기능을 제공한다. 파라미터로 제공되는 인스턴스는 'org.havi.ui' 패키지의 'HScreenRectangle' 클래스 타입으로서, 2차원 위치 정보를 갖는다. 그리고, 상기 'setDisplayArea(HScreenRectangle rect)' 메소드에 대한 예외 처리로서, 'SecurityException' 예외와 'IllegalStateException' 예외가 수행될 수 있다. 'IllegalStateException' 예외는 현재의 스크린이 논리 스크린이 아니거나, 하드웨어 또는 소프트웨어 플랫폼의 특성상 현재의 논리 스크린과 연관된 출력 스크린의 영역이 변경될 수 없는 경우에 수행될 수 있다.As another example, the 'public void setDisplayArea (HScreenRectangle rect) throws SecurityException, IllegalStateException' method provides the ability to associate the current logical screen with a given area of the associated output screen. The instance provided as a parameter is a 'HScreenRectangle' class type of the 'org.havi.ui' package and has two-dimensional location information. As an exception for the 'setDisplayArea (HScreenRectangle rect)' method, an 'SecurityException' exception and an 'IllegalStateException' exception may be performed. An 'IllegalStateException' exception may be performed if the current screen is not a logical screen, or if the area of the output screen associated with the current logical screen cannot be changed due to the nature of the hardware or software platform.

또 다른 예로, 'getDisplayArea(void)' 메소드는 현재 스크린의 영역에 대한 정보를 'HScreenRectangle' 클래스의 형태로 반환한다. 만일, 현재의 스크린이 출력 스크린인 경우에는 'HScreenRectangle(0,0,1,1)'과 동일한 값을 갖는 'HScreenRectangle' 정보를 반환하고, 현재의 스크린이 논리 스크린인 경우에는 연관된 출력 스크린에서 상기 논리 스크린이 차지하는 영역에 대한 정보가 반환된다. 그리고, 현재의 스크린이 논리 스크린이지만, 연관된 출력 스크린이 존재하지 않는 경우에는 'NULL' 값이 반환된다.As another example, the 'getDisplayArea (void)' method returns information about the current screen area in the form of the 'HScreenRectangle' class. If the current screen is an output screen, 'HScreenRectangle' information having the same value as 'HScreenRectangle (0,0,1,1)' is returned. If the current screen is a logical screen, the associated output screen is returned. Information about the area occupied by the logical screen is returned. If the current screen is a logical screen but there is no associated output screen, then a NULL value is returned.

위에서 언급된 각각의 인터페이스 이름은 각각의 기능을 나타내기 위한 명칭에 불과하므로, 그 명칭에 한정되는 것이 아니라 그 기능으로서 이해되어야 한다.Each interface name mentioned above is merely a name for indicating each function, and should not be limited to the name but should be understood as the function.

도 9는 두 개의 서비스가 두 개의 논리 스크린에 각각 설정되고 하나의 출력 스크린에 매핑되어 출력되는 과정을 나타내는 예시도이다.9 is an exemplary diagram illustrating a process in which two services are respectively set in two logical screens and mapped and output in one output screen.

도 9를 참조하면, 제 1 서비스는 비디오/오디오/데이터의 3가지 서비스 컴포넌트가 모두 존재하는 서비스이며, 제 2 서비스는 비디오 컴포넌트와 오디오 컴포넌트만 존재하는 경우를 예로 든 것이다. 물론 본 발명에서는 서비스 컴포넌트에 대한 제약 사항을 두지 않으며, 도 9의 경우는 하나의 가능한 예를 나타낸 것이다.Referring to FIG. 9, the first service is a service in which all three service components of video / audio / data exist, and the second service is an example in which only a video component and an audio component exist. Of course, the present invention does not place any restrictions on the service component, and FIG. 9 shows one possible example.

도 9에서 볼 수 있듯이, 제 1 서비스와 제 2 서비스가 종래의 방식과 유사한 형태로 디스플레이 화면에 나타나지만, 본 발명을 따를 경우 매핑(mapping)을 통하여 디스플레이 화면 상에 개수의 제한 없이 복수 개의 서비스를 다양한 위치에 독립적으로 표현할 수 있다.As shown in FIG. 9, the first service and the second service are displayed on the display screen in a similar manner to the conventional method, but according to the present invention, a plurality of services may be applied to the display screen through mapping without limitation. Can be expressed independently in various positions.

도 10은 본 발명의 일 실시예에 따른 다중 스크린을 제공하는 장치의 구성을 나타내는 블록도이다.10 is a block diagram showing the configuration of an apparatus for providing multiple screens according to an embodiment of the present invention.

도 10을 참조하면, 본 발명에 따른 다중 스크린 제공 장치(900)는 디지털 신호 처리 모듈(940), 동작 모듈(970), 사용자/어플리케이션 인터페이스 모듈(950) 및 검색 모듈(960)을 포함한다.Referring to FIG. 10, the multi-screen providing apparatus 900 according to the present invention includes a digital signal processing module 940, an operation module 970, a user / application interface module 950, and a search module 960.

이 때, 서비스를 제공하는 소스(source)로서, 방송 신호 수신 모듈(910), 저장 매체(920a) 또는 외부 입력 모듈(930)을 포함할 수 있고, 서비스가 출력되는 매체로서 디스플레이 화면(980), 저장 매체(920b) 또는 외부 출력 모듈(990)을 포함할 수 있다.In this case, a source for providing a service may include a broadcast signal receiving module 910, a storage medium 920a, or an external input module 930, and a display screen 980 as a medium for outputting a service. May include a storage medium 920b or an external output module 990.

이 때, 본 실시예에서 사용되는 '모듈'이라는 용어는 소프트웨어 또는 FPGA 또는 ASIC과 같은 하드웨어 구성요소를 의미하며, 모듈은 어떤 역할들을 수행한다. 그렇지만 모듈은 소프트웨어 또는 하드웨어에 한정되는 의미는 아니다. 모듈은 어드레싱할 수 있는 저장 매체에 있도록 구성될 수도 있고 하나 또는 그 이상의 프로세서들을 재생시키도록 구성될 수도 있다. 따라서, 일 예로서 모듈은 소프트웨어 구성요소들, 객체지향 소프트웨어 구성요소들, 클래스 구성요소들 및 태스크 구성요소들과 같은 구성요소들과, 프로세스들, 함수들, 속성들, 프로시저들, 서브루틴들, 프로그램 코드의 세그먼트들, 드라이버들, 펌웨어, 마이크로 코드, 회로, 데이터, 데이터베이스, 데이터 구조들, 테이블들, 어레이들, 및 변수들을 포함한다. 구성요소들과 모듈들 안에서 제공되는 기능은 더 작은 수의 구성요소들 및 모듈들로 결합되거나 추가적인 구성요소들과 모듈들로 더 분리될 수 있다. 뿐만 아니라, 구성요소들 및 모듈들은 디바이스 또는 보안 멀티미디어카드 내의 하나 또는 그 이상의 CPU들을 재생시키도록 구현될 수도 있다.In this case, the term 'module' used in the present embodiment refers to software or a hardware component such as an FPGA or an ASIC, and a module plays a role. However, modules are not meant to be limited to software or hardware. The module may be configured to be in an addressable storage medium and may be configured to play one or more processors. Thus, as an example, a module may include components such as software components, object-oriented software components, class components, and task components, and processes, functions, properties, procedures, subroutines. , Segments of program code, drivers, firmware, microcode, circuits, data, databases, data structures, tables, arrays, and variables. The functionality provided within the components and modules may be combined into a smaller number of components and modules or further separated into additional components and modules. In addition, the components and modules may be implemented to play one or more CPUs in a device or secure multimedia card.

디지털 신호 처리 모듈(940)은 방송 신호 수신 모듈(910), 저장 매체(920a) 또는 외부 입력 모듈(930)로부터 멀티미디어 컨텐츠와 같은 서비스를 구성하는 다양한 구성 정보들, 예를 들어 비디오 정보, 오디오 정보 또는 데이터 정보 등을 수신한다.The digital signal processing module 940 includes various configuration information constituting a service such as multimedia content from the broadcast signal receiving module 910, the storage medium 920a, or the external input module 930, for example, video information and audio information. Or data information or the like.

이 때, 방송 신호 수신 모듈(910)은 위성, 지상파 또는 케이블 방송 신호를 수신하여 전달하는 모듈이고, 저장 매체(920a)는 서비스를 구성하는 비디오 정보, 오디오 정보 또는 데이터 정보 등이 저장된 기기를 나타내고, 외부 입력 모듈(930)은 네트워크 인터페이스 모듈과 같이 네트워크로 연결된 다른 기기로부터 서비스를 구성하는 비디오 정보, 오디오 정보 또는 데이터 정보 등을 수신하여 전달하는 모듈로서 이해될 수 있다.In this case, the broadcast signal receiving module 910 is a module for receiving and transmitting satellite, terrestrial or cable broadcast signals, and the storage medium 920a represents a device in which video information, audio information, or data information, etc., which constitute a service are stored. The external input module 930 may be understood as a module that receives and transmits video information, audio information, or data information constituting a service from another networked device such as a network interface module.

디지털 신호 처리 모듈(940)은 수신된 서비스 컴포넌트들을 이용하여 서비스를 복원하는데, 이 때 복수의 서비스를 복원할 수 있다. 이 때, 상기 복원된 서비스는 추상 서비스 또는 비추상 서비스를 포함한다.The digital signal processing module 940 restores a service by using the received service components, and may restore a plurality of services. At this time, the restored service includes an abstract service or a non-abstract service.

또한, 여기에서, '복수의 서비스'란 예를 들어 방송 신호 수신 모듈(910)에서 전달되는 2개 이상의 서비스를 의미할 수도 있고, 방송 신호 수신 모듈(910)과 저장 매체(920a) 각각으로부터 전달되는 2개의 이상의 서비스를 의미할 수도 있다.In addition, the term 'plural services' may mean, for example, two or more services delivered from the broadcast signal receiving module 910, and may be delivered from each of the broadcast signal receiving module 910 and the storage medium 920a. It may mean two or more services.

디지털 신호 처리 모듈(940)에서 복원되는 서비스는 사용자/어플리케이션 인터페이스 모듈(950)을 통한 사용자 또는 어플리케이션의 선택에 따라 복원될 수도 있다. 이 때, 사용자 또는 어플리케이션은 어느 서비스를 어떤 스크린에 연결할 지 선택할 수 있다.The service restored by the digital signal processing module 940 may be restored according to the selection of a user or an application through the user / application interface module 950. At this time, the user or the application may select which service to connect to which screen.

동작 모듈(970)은 디지털 신호 처리 모듈(940)에 의하여 복원된 서비스를 논리 스크린에서 표현한 후 논리 스크린을 출력 스크린에 매핑하거나 서비스를 직접 출력 스크린에 표현하는 역할을 한다. 이를 위하여, 동작 모듈(970)은 서비스 처리 모듈(972) 및 출력 모듈(974)을 포함하여 구성될 수 있다.The operation module 970 represents the service restored by the digital signal processing module 940 on the logical screen, and then maps the logical screen to the output screen or directly expresses the service on the output screen. To this end, the operation module 970 may include a service processing module 972 and an output module 974.

서비스 처리 모듈(972)은 디지털 신호 처리 모듈(940)에 의해 복원된 서비스를 표현하기 위한 논리 스크린 및 출력 스크린을 생성한다.The service processing module 972 generates a logical screen and an output screen for representing the service restored by the digital signal processing module 940.

출력 모듈(974)은 출력 스크린 상의 소정의 영역으로 서비스 처리 모듈(972)에 의해 생성된 논리 스크린들을 매핑하고 출력한다. 이 때, 출력 스크린 상으로의 매핑은 이미 설정되거나 또는 사용자/어플리케이션 인터페이스 모듈(950)을 통하여 사용자 또는 어플리케이션에 의해 설정될 수 있다. The output module 974 maps and outputs the logical screens generated by the service processing module 972 to a predetermined area on the output screen. At this point, the mapping onto the output screen may already be set or may be set by the user or application via the user / application interface module 950.

또한, 서비스 처리 모듈(972)은 다수의 출력 스크린을 생성할 수 있는데, 이러한 경우에는 사용자/어플리케이션 인터페이스 모듈(950)을 통하여 선택된 출력 스크린만이 출력 모듈(974)을 통하여 제공될 수 있다.In addition, the service processing module 972 may generate multiple output screens, in which case only output screens selected through the user / application interface module 950 may be provided through the output module 974.

또한, 디지털 신호 처리 모듈(940)에 의해 복원된 서비스는 서비스 처리 모듈(972)에서 논리 스크린과 연결되지 않고, 출력 스크린과 직접 연결되어 출력 모듈(974)에 의해 출력될 수 있다.In addition, the service restored by the digital signal processing module 940 may be directly connected to the output screen and output by the output module 974 instead of being connected to the logical screen in the service processing module 972.

출력 모듈(974)에 의해 출력 스크린은 물리적인 디스플레이 화면(980)을 통하여 출력되거나, 저장 매체(920b)에 저장될 수 있다. 여기에서 저장 매체(920b)는 컴퓨터에 의해 판독이 가능하고 플로피 디스크, 하드 디스크, CD-ROM, DVD, DVD-ROM, BD(Blu-ray Disc) 및 반도체 메모리를 포함한다.The output screen by the output module 974 may be output through the physical display screen 980 or may be stored in the storage medium 920b. The storage medium 920b may be read by a computer and includes a floppy disk, a hard disk, a CD-ROM, a DVD, a DVD-ROM, a BD (Blu-ray Disc), and a semiconductor memory.

또한, 외부 출력 모듈(990)을 통하여 네트워크로 연결된 다른 기기로 전달될 수도 있다.Also, it may be delivered to another device connected through a network through the external output module 990.

이를 위하여, 출력 모듈(974)은 출력 스크린이 제공되는 다수의 출력 포트(output port)를 포함할 수 있는데, 이러한 경우에 이미 설정된 기본 출력 포트 또는 사용자/어플리케이션 인터페이스 모듈(950)을 통하여 지정된 출력 포트를 통하여 출력 스크린이 제공될 수 있다.For this purpose, the output module 974 may comprise a number of output ports on which an output screen is provided, in which case the output port designated via the default output port or user / application interface module 950 already set. Through the output screen can be provided.

검색 모듈(960)은 시스템에 존재하는 스크린들의 형태 및 연결 관계를 검색하는 역할을 한다. 이와 같은 검색은 4가지로 분류될 수 있는데, 검색 모듈(960)은 적어도 하나 이상의 스크린 중 수신된 서비스에 포함된 어플리케이션이 실행되는 스크린을 검색할 수 있고(이하, 제 1 검색이라 한다), 장치에 생성된 모든 논리 스크린과 출력 스크린을 검색할 수 있고(이하, 제 2 검색이라 한다), 수신된 서비스를 표현하기 위한 논리 스크린과 그 논리 스크린이 매핑된 출력 스크린을 검색할 수 있으며(이하, 제 3 검색이라 한다), 수신된 서비스를 표현하는 스크린이 논리 스크린인지 출력 스크린인지 검색할 수 있다(이하, 제 4 검색이라 한다).The search module 960 searches for the form and connection of screens present in the system. Such a search may be classified into four types. The search module 960 may search for a screen on which an application included in a received service is executed from among at least one or more screens (hereinafter, referred to as a first search). You can search all logical screens and output screens created in (hereinafter referred to as a second search), and you can search logical screens for representing received services and output screens to which the logical screens are mapped (hereinafter, It is possible to search whether the screen representing the received service is a logical screen or an output screen (hereinafter referred to as a fourth search).

여기서, 제 1 검색 내지 제 4 검색 과정을 통하여 검색되는 스크린은 논리 스크린 또는 출력 스크린일 수 있다.Here, the screen searched through the first to fourth search processes may be a logical screen or an output screen.

제 1 검색을 수행함에 있어서, 검색 모듈(960)은 어플리케이션이 실행되는 스크린의 설정 형태를 검색할 수 있는데 여기서, 설정 형태로는 어플리케이션이 실행된 스크린이 출력 스크린에 대응하는 단일 스크린 형태, 단일 스크린이 적어도 하나 이상의 중첩 스크린과 병존하는 중첩 스크린 형태, 어플리케이션이 실행된 스크린이 출력 스크린의 전체 영역에 매핑된 논리 스크린에 대응하고, 출력 스크린에 매핑된 적어도 하나 이상의 중첩되지 않은 논리 스크린에 대응하며, 중첩 스크린에 대응하지 않는 PiP 스크린 형태, PiP 스크린이 적어도 하나 이상의 중첩 스크린과 병존하는 중첩된 PiP 스크린 형태, 어플리케이션이 실행된 스크린이 출력 스크린의 전체 영역에 매핑된 적어도 둘 이상의 비중첩 논리 스크린의 조합에 대응하고, 중첩 스크린에 대응하지 않는 PoP 스크린 형태, PoP 스크린이 적어도 하나 이상의 중첩 스크린과 병존하는 중첩된 PoP 스크린 및 위의 형태 중 어느 하나에도 속하지 않는 일반 형태 중 적어도 하나를 포함한다.In performing the first search, the search module 960 may search a setting form of a screen on which an application is executed, wherein the setting form is a single screen form or a single screen in which the screen on which the application is executed corresponds to an output screen. A nested screen form that coexists with the at least one nested screen, a screen on which the application is executed corresponds to a logical screen mapped to the entire area of the output screen, and at least one non-overlapping logical screen mapped to the output screen, Combination of PiP screen types that do not correspond to nested screens, nested PiP screen types where the PiP screens coexist with at least one or more nested screens, and at least two non-overlapping logic screens where the screen on which the application is run is mapped to the entire area of the output screen. Corresponding to, not corresponding to overlapping screen At least one of a non-PoP screen form, a superimposed PoP screen in which the PoP screen coexists with at least one or more overlapping screens, and a general form not belonging to any of the above forms.

제 2 검색을 수행함에 있어서, 검색 모듈(960)은 어플리케이션의 권한 범위를 참조하여 권한이 부여된 경우에만 논리 스크린 및 출력 스크린에 대해서만 검색을 수행할 수도 있다. 여기서, 어플리케이션의 권한 범위는 서비스 제공자에 의하여 부여되는데, 검색 모듈(960)은 동작 모듈(970)에 의하여 생성된 스크린 중 어플리케이션의 권한 범위에 포함된 일부 스크린에 대해서만 검색을 수행할 수 있는 것이다. 한편, 서비스 제공자로부터 어떠한 권한 범위도 부여되지 않는 경우 검색 모듈(960)은 모든 논리 스크린 및 출력 스크린을 검색할 수도 있음은 물론이다.In performing the second search, the search module 960 may perform the search only for the logical screen and the output screen only when the permission is granted by referring to the permission range of the application. Here, the permission range of the application is granted by the service provider, and the search module 960 may search only some screens included in the permission range of the application among the screens generated by the operation module 970. On the other hand, the search module 960 may search all logical screens and output screens if no privilege range is granted from the service provider.

제 4 검색을 수행함에 있어서, 검색 모듈(960)은 어플리케이션이 실행되는 스크린이 논리 스크린(이하, 실행 논리 스크린이라 한다)인 경우, 출력 스크린상에서의 실행 논리 스크린의 위치, 크기 및 출력 스크린상에 존재하는 다른 논리 스크린과 실행 논리 스크린간의 중첩 관계를 검색할 수 있다. 여기서, 실행 논리 스크린의 위치는 출력 스크린상에서의 평면 좌표뿐만 아니라 z축상의 순서인 z-order를 포함한다.In performing the fourth search, the search module 960, if the screen on which the application is executed is a logical screen (hereinafter referred to as an execution logic screen), displays the position, size, and size of the execution logic screen on the output screen. You can search for overlapping relationships between existing logic screens and execution logic screens. Here, the position of the execution logic screen includes not only the plane coordinates on the output screen but also the z-order, which is the order on the z-axis.

또한, 제 4 검색을 수행함에 있어서, 검색 모듈(960)은 검색된 스크린의 서비스 컨텍스트를 검색할 수도 있다.In addition, in performing the fourth search, the search module 960 may search the service context of the searched screen.

한편, 검색 모듈(960)은 사용자로부터 입력된 제어 명령 또는 서비스 제공자로부터 제공된 어플리케이션의 제어 명령에 의하여 검색을 수행한다. 어플리케이션의 제어 명령에 의한 검색은 현재 전송된 어플리케이션 또는 기 저장된 어플리케이션의 제어 명령에 따라 검색 모듈(960)이 검색을 수행하는 것을 의미한다.Meanwhile, the search module 960 performs a search by a control command input from a user or a control command of an application provided from a service provider. The search by the control command of the application means that the search module 960 performs the search according to the control command of the currently transmitted application or the previously stored application.

사용자 또는 어플리케이션은 사용자/어플리케이션 인터페이스 모듈(950)을 통하여 원하는 서비스를 선택하거나 복원하게 할 수 있다. 또한, 사용자 또는 어플리케이션은 사용자/어플리케이션 인터페이스 모듈(950)을 통하여 다수의 출력 스크린 중 임의의 출력 스크린을 선택할 수도 있는데, 이와 같은 작업을 수행하기 위하여 사용자/어플리케이션 인터페이스 모듈(950)은 검색 모듈(960)에 의하여 검색된 결과를 이용할 수 있다.The user or application may select or restore a desired service through the user / application interface module 950. In addition, a user or an application may select any output screen from among a plurality of output screens through the user / application interface module 950. In order to perform such a task, the user / application interface module 950 may use a search module 960. Can use the search results.

도 10에 도시된 각 모듈들은 각각의 기능에 따라 분리되어 도시되고 있으므로, 실제 구현에 있어서는 각각 다른 모듈들과의 결합도 가능하다.Since each module illustrated in FIG. 10 is shown separately according to each function, the modules may be combined with other modules in an actual implementation.

도 11은 본 발명의 일 실시예에 따라 다중 스크린을 동적으로 구성하는 방법을 나타내는 플로우 차트이다.11 is a flowchart illustrating a method of dynamically configuring multiple screens according to an embodiment of the present invention.

일반적으로 멀티미디어 컨텐츠를 구성하는 비디오 정보, 오디오 정보, 데이터 정보 등은 예를 들어 MPEG 스트림과 같은 소정의 포맷에 따라 전달된다. 따라서, 멀티미디어 컨텐츠와 같은 서비스를 실행하는 장치는 상기와 같은 정보들을 수신하여 해당하는 서비스를 복원하게 된다(S1010). 이 때, 복원되는 서비스는 사용자 또는 어플리케이션에 의해 선택되거나 미리 설정될 수 있다. 사용자가 디스플레이 화면에서 나타나는 메뉴나 리모컨을 이용하거나 어플리케이션이 API를 이용하여 어느 서비스를 어떤 스크린에 연결할 지 선택할 수 있다.In general, video information, audio information, data information, etc. constituting multimedia content are delivered according to a predetermined format such as, for example, an MPEG stream. Therefore, the device executing the service such as the multimedia content receives the above information and restores the corresponding service (S1010). At this time, the service to be restored may be selected or preset by the user or the application. The user can select which service to connect to which screen by using a menu or remote control displayed on the display screen or by using an API.

한편, 데이터 정보는 서비스 내에 존재하는 어플리케이션에 관한 어플리케이션 정보를 포함하며, 이러한 어플리케이션 정보는 어플리케이션이 PiP 스크린에서 실행될 수 있는지 여부를 나타내는 시그널 정보(signal information)를 포함한다. 어플리케이션 정보의 예로서, MHP 규격에 따른 AIT(Application Information Table)과 OCAP 규격에 따른 XAIT(eXtended Application Information Table) 등이 있으며, 이러한 어플리케이션 정보에 상기 시그널 정보를 추가할 수 있다.On the other hand, the data information includes application information about an application existing in the service, and the application information includes signal information indicating whether the application can be executed on the PiP screen. Examples of the application information include an application information table (AIT) according to the MHP standard and an eXtended Application Information Table (XAIT) according to the OCAP standard, and the signal information may be added to the application information.

그리고 나서, 상기 복원된 서비스를 본 발명에 따른 논리 스크린에서 표현되도록 설정하고(S1020), 상기 논리 스크린을 본 발명에 따른 출력 스크린으로 매핑한 후(S1030), 디스플레이 화면(980), 저장 매체(920b) 또는 네트워크를 통하여 상기 출력 스크린이 제공된다(S1040).Then, the restored service is set to be represented on the logical screen according to the present invention (S1020), and after mapping the logical screen to the output screen according to the present invention (S1030), the display screen 980, the storage medium ( 920b) or the output screen is provided through a network (S1040).

이와 같이, 논리 스크린 및 출력 스크린이 생성된 후, 검색 모듈(960)은 생성된 스크린에 대한 검색을 수행한다(S1050). 검색 모듈(960)에 의하여 수행되는 검색은 전술한 제 1 검색 내지 제 4 검색을 포함하며, 이는 사용자/어플리케이션 인터페이스 모듈(950)을 통하여 입력된 사용자 또는 어플리케이션의 제어 명령에 따라 수행될 수 있다. 검색에 대한 자세한 설명은 도 10을 통하여 전술하였으므로 생략하기로 한다.In this way, after the logical screen and the output screen are generated, the search module 960 performs a search for the generated screen (S1050). The search performed by the search module 960 includes the first to fourth searches described above, which may be performed according to a control command of a user or an application input through the user / application interface module 950. Detailed description of the search has been described above with reference to FIG. 10 and will be omitted.

한편, 도 11에서는 복원된 서비스가 논리 스크린을 거쳐 출력 스크린을 통해 제공되는 것으로 표현되고 있으나, 논리 스크린을 거치지 않고 직접 출력 스크린을 통해 제공될 수도 있다.Meanwhile, although the restored service is represented as being provided through the output screen through the logical screen in FIG. 11, the restored service may be provided through the output screen directly without passing through the logical screen.

또한, 사용자가 PiP 서비스를 선택하는 경우에는 2가지 모드로서 PiP 서비스가 표현될 수 있는데 제 1 모드에서는 PiP 서비스를 위한 별도의 논리 스크린 예컨대 PiP 스크린이 생성되지 않고, 메인 스크린에서 선택된 PiP 서비스의 비디오 컴포넌트만 표현되고, 제 2 모드에서는 PiP 서비스를 위한 별도의 논리 스크린이 생성되어 생성된 PiP 스크린 내에서 선택된 PiP 서비스가 표현된다.In addition, when the user selects a PiP service, the PiP service may be represented in two modes. In the first mode, a separate logical screen, for example, a PiP screen for the PiP service, is not generated, and the video of the PiP service selected in the main screen is displayed. Only components are represented, and in the second mode, a separate logical screen for the PiP service is created to represent the selected PiP service within the generated PiP screen.

한편, 도 11에서는 설명의 편의상 하나의 서비스가 출력 스크린으로 매핑되는 과정을 설명하고 있으나, 스크린 속성 정보를 이용하여 다수의 서비스가 다수의 논리 스크린을 통하여 또는 직접적으로 하나의 출력 스크린 내의 임의의 영역으로 매핑될 수 있다.In FIG. 11, a process of mapping one service to an output screen is described for convenience of description. However, the screen property information may be used to display a plurality of services through a plurality of logical screens or directly in an arbitrary area within one output screen. Can be mapped to

따라서, 출력 스크린이 디스플레이 화면을 통하여 제공되는 경우에는 사용자 또는 어플리케이션은 다수의 서비스를 실행할 수 있게 된다.Therefore, when the output screen is provided through the display screen, the user or the application can execute a plurality of services.

도 12는 본 발명의 실시에 따라 다중 스크린을 제공하기 위한 소프트웨어 아키텍처를 나타내는 예시도이다.12 is an exemplary diagram illustrating a software architecture for providing multiple screens in accordance with an embodiment of the present invention.

도 12를 참조하면, 본 발명에 따른 소프트웨어 아키텍처(1100)는 디바이스 드라이버 레이어(Device Driver Layer)(1110), API 레이어(Application Program Interface Layer)(1120) 그리고 어플리케이션 레이어(Application Layer)(1130)를 포함한다.Referring to FIG. 12, the software architecture 1100 according to the present invention may include a device driver layer 1110, an application program interface layer 1120, and an application layer 1130. Include.

디바이스 드라이버 레이어(1110)는 멀티미디어 컨텐츠를 제공하는 다양한 소스들로부터 서비스를 구성하는 서비스 컴포넌트들을 수신하여 디코딩한다. 이 때, 서비스 컴포넌트의 예로서 비디오 정보, 오디오 정보 또는 데이터 정보 등을 포함한다.The device driver layer 1110 receives and decodes service components constituting a service from various sources that provide multimedia content. In this case, examples of the service component include video information, audio information or data information.

API 레이어(1120)는 논리 스크린 및 출력 스크린을 생성하고, 서비스, 논리 스크린, 출력 스크린 간의 매핑을 수행한다.The API layer 1120 creates a logical screen and an output screen and performs mapping between services, logical screens, and output screens.

어플리케이션 레이어(1130)는 서비스가 표현되는 논리 스크린을 사용자가 동적으로 구성할 수 있도록 하는 사용자 인터페이스를 제공하거나, 사용자의 명령을 API 레이어(1120)로 전달하여 해당 명령에 따른 동작을 수행하게 할 수 있다.The application layer 1130 may provide a user interface that allows a user to dynamically configure a logical screen on which a service is expressed, or transmit a user's command to the API layer 1120 to perform an operation according to the command. have.

이와 같은 작업을 수행하기 위하여 어플리케이션 레이어(1130)는 현재 전송된 어플리케이션 또는 기 저장된 어플리케이션을 통하여 작업을 수행할 수 있으며, 스크린 검색 등의 작업도 어플리케이션 레이어(1130)을 통하여 수행될 수 있다.In order to perform such a task, the application layer 1130 may perform a task through an application currently transmitted or a previously stored application, and a task such as screen search may also be performed through the application layer 1130.

한편, 사용자는 어플리케이션 레이어(1130)를 통하여 디바이스 드라이버 레이어(1110)로 하여금 출력 스크린을 물리적인 디스플레이 화면을 통하여 출력하도록 하거나 저장 매체(920b)에 저장하도록 할 수 있다. 또한, 디바이스 드라이버 레이어(1110)에 의해 출력 스크린을 네트워크를 통하여 다른 기기로 전송할 수도 있다.Meanwhile, the user may cause the device driver layer 1110 to output the output screen through the physical display screen or store the output screen through the application layer 1130 in the storage medium 920b. In addition, the device driver layer 1110 may transmit the output screen to another device through a network.

이를 위하여, 디바이스 드라이버 레이어(1110)는 상기 출력 스크린을 제공하는 다수의 출력 포트를 포함할 수도 있으나, 다수의 출력 포트는 API 레이어(1120)에 존재할 수도 있다.To this end, the device driver layer 1110 may include a plurality of output ports providing the output screen, but a plurality of output ports may be present in the API layer 1120.

한편, 다수의 논리 스크린을 출력 스크린 상에 동적으로 구성하기 위하여 API 레이어(1120)는 다수의 소프트웨어 모듈을 포함할 수 있는데, 여기에서는 'MultiScreenManager' 모듈, 'MultiScreenContext' 모듈, 'MultiScreenContextListener' 모듈 그리고 'MultiScreenContextEvent' 모듈을 예로 하여 설명하며, 이러한 모듈들의 관계를 도 13에서 도시하고 있다.Meanwhile, in order to dynamically configure a plurality of logical screens on an output screen, the API layer 1120 may include a plurality of software modules, wherein the 'MultiScreenManager' module, 'MultiScreenContext' module, 'MultiScreenContextListener' module, and ' MultiScreenContextEvent 'module is described as an example, and the relationship between these modules is shown in FIG.

'MultiScreenManager' 모듈(1210)은 'MultiScreenContext' 모듈을 관리하면서, 원하는 스크린을 찾거나 스크린들간의 디바이스 공유 정보를 알려 주거나, 'MultiScreenContextListener' 모듈(1250)의 등록 또는 해제를 담당하는 역할을 한 다. The 'MultiScreenManager' module 1210 manages the 'MultiScreenContext' module, finds a desired screen, informs device sharing information between the screens, or plays a role in registering or unregistering the 'MultiScreenContextListener' module 1250.

'MultiScreenContext' 모듈(1230)은 스크린 객체(1220)와 연관되어 스크린 객체에 대한 인터페이스 객체로서, 'MultiScreenContext' 모듈(1230)의 인터페이스 동작에 따라 스크린 객체가 논리 스크린과 출력 스크린으로 스크린의 유형이 결정될 수 있고, 도 6에 도시되고 있는 다양한 속성 정보들이 설정될 수 있다. 앞서, 언급한 'set', 'add', 'get', 'remove' 인터페이스들은 'MultiScreenContext' 모듈(1230)에 의해 제공될 수 있다.The 'MultiScreenContext' module 1230 is an interface object for the screen object in association with the screen object 1220. The screen type of the screen object may be determined as a logical screen and an output screen according to the interface operation of the 'MultiScreenContext' module 1230. And various attribute information shown in FIG. 6 may be set. The aforementioned 'set', 'add', 'get', and 'remove' interfaces may be provided by the 'MultiScreenContext' module 1230.

'MultiScreenContextEvent' 모듈(1240)은 'MultiScreenContext' 인터페이스 객체(1230)에 의하여 스크린 객체(1220)의 속성 정보들이 바뀐 경우, 이를 알려주기 위한 이벤트 클래스(event class)이고, 'MultiScreenContextListener' 모듈(1250)은 'MultiScreenContextEvent' 모듈(1240)에 의한 이벤트를 수신하고자 하는 소정의 어플리케이션 클래스에 구현될 수 있는 리스너 인터페이스(listener interface) 객체이다.The 'MultiScreenContextEvent' module 1240 is an event class for notifying when property information of the screen object 1220 is changed by the 'MultiScreenContext' interface object 1230, and the 'MultiScreenContextListener' module 1250 A listener interface object that can be implemented in a predetermined application class that wants to receive an event by the 'MultiScreenContextEvent' module 1240.

한편, 어플리케이션(1260)은 어플리케이션 레이어(1130)에서 동작하는 모듈로서, 사용자로 하여금 원하는 서비스를 선택하게 하고, 출력 스크린에 다수의 논리 스크린을 원하는 형태에 따라 자유롭게 배치하도록 한다.Meanwhile, the application 1260 is a module operating in the application layer 1130 and allows a user to select a desired service and freely arrange a plurality of logical screens according to a desired form on an output screen.

따라서, 어플리케이션(1260)은 사용자가 논리 스크린을 동적으로 배치하고 이를 관리하는 것에 관한 명령들을 MultiScreenManager 모듈(1210)로 전달하면, MultiScreenManager 모듈(1210)은 MultiScreenContext 모듈(1230)을 통하여 상기 명령에 대응하는 동작을 수행하도록 한다.Thus, if application 1260 communicates commands to MultiScreenManager module 1210 regarding the user's dynamic placement and management of a logical screen, MultiScreenManager module 1210 corresponds to the commands via MultiScreenContext module 1230. Perform the action.

한편, MultiScreenContext 모듈(1230)은 스크린 객체(1220)와 연관되어 도 6에 도시된 스크린 객체(1220)의 속성 정보들을 관리할 수 있으며 이러한 관리를 위하여 다양한 함수 또는 메소드(method)를 포함할 수 있다.Meanwhile, the MultiScreenContext module 1230 may manage attribute information of the screen object 1220 illustrated in FIG. 6 in association with the screen object 1220 and may include various functions or methods for such management. .

한편 미도시되었으나, MultiScreenManager 모듈(1210)은 디바이스 드라이버 레이어(1110)로부터 다양한 소스들로부터 제공된 서비스 컴포넌트들을 수신하여 논리 스크린 또는 출력 스크린에서 표현될 수 있도록 동작할 수도 있다. 물론, 이러한 기능은 도시되지 않은 별도의 모듈을 통해서 수행될 수도 있다.Meanwhile, although not shown, the MultiScreenManager module 1210 may operate to receive service components provided from various sources from the device driver layer 1110 so that they can be displayed on a logical screen or an output screen. Of course, this function may be performed through a separate module (not shown).

또한, 어플리케이션은 검색 모듈(960)을 이용하여 스크린 검색 작업을 수행할 수 있는데, 이에 대한 자세한 설명은 도 15를 통하여 후술하기로 한다.In addition, the application may perform a screen search operation by using the search module 960, which will be described later with reference to FIG. 15.

도 14는 도 13에서 도시된 각 모듈들에 의하여 복수 개의 서비스를 논리 스크린을 통하여 출력 스크린에 나타내는 과정을 도시한 플로우 차트이다.FIG. 14 is a flowchart illustrating a process of displaying a plurality of services on an output screen through a logical screen by each module illustrated in FIG. 13.

우선, MultiScreenManager 모듈(1210)은 하나의 출력 스크린과 실행될 서비스 개수만큼의 논리 스크린을 생성한다(S1310).First, the MultiScreenManager module 1210 generates one output screen and as many logical screens as the number of services to be executed (S1310).

그리고 나서, MultiScreenManager 모듈(1210)은 각각의 논리 스크린을 디바이스 드라이버 레이어(1110)로부터 수신한 서비스와 연결시킨다(S1320). 이 때, 각각의 논리 스크린에 대하여, 연결할 서비스에 대한 서비스 컨텍스트 객체를 파라미터로 하여 논리 스크린 객체의 'addServiceContext' 메소드를 호출할 수 있다. 여기에서 'addServiceContext' 메소드는 논리 스크린과 서비스를 연결하는 기능을 수행하는 메소드로서 이해될 수 있으며, MultiScreenContext 모듈(1230)에 의해 제공될 수 있다.Then, the MultiScreenManager module 1210 connects each logical screen with a service received from the device driver layer 1110 (S1320). At this time, for each logical screen, the 'addServiceContext' method of the logical screen object may be called using the service context object for the service to be connected as a parameter. Here, the 'addServiceContext' method may be understood as a method that performs a function of connecting a logical screen and a service, and may be provided by the MultiScreenContext module 1230.

논리 스크린과 서비스가 연결되면, MultiScreenManager 모듈(1210)은 각각의 논리 스크린을 출력 스크린과 연결한다(S1330). 이 때, 각각의 논리 스크린에 대하여, 연결할 출력 스크린 객체를 파라미터로 하여 논리 스크린 객체의 'setDisplayScreen' 메소드를 호출할 수 있다. 여기에서 'setDisplayScreen' 메소드는 논리 스크린과 출력 스크린을 연결하는 기능을 수행하는 메소드로서 이해될 수 있으며, MultiScreenContext 모듈(1230)에 의해 제공될 수 있다.When the logical screen and the service are connected, the MultiScreenManager module 1210 connects each logical screen with the output screen (S1330). At this time, for each logical screen, the 'setDisplayScreen' method of the logical screen object may be called using the output screen object to be connected as a parameter. Herein, the 'setDisplayScreen' method may be understood as a method that performs a function of connecting a logical screen and an output screen, and may be provided by the MultiScreenContext module 1230.

예를 들어, 'setDisplayScreen' 메소드는 'public void setDisplayScreen(HScreen screen) throws SecurityException, IllegalStateException'의 형태로 표현될 수 있으며, 이 메소드는 파라미터로 제공되는 'HScreen' 인스턴스를 현재의 논리 스크린과 매핑시키는 기능을 제공한다. 이 때, 상기 'HScreen' 인스턴스는 출력 스크린인 것이 바람직하다.For example, the 'setDisplayScreen' method can be expressed in the form of 'public void setDisplayScreen (HScreen screen) throws SecurityException, IllegalStateException', which maps the 'HScreen' instance provided as a parameter to the current logical screen. To provide. In this case, the 'HScreen' instance is preferably an output screen.

그리고, 상기 'setDisplayScreen(HScreen screen)' 메소드의 파라미터는 'NULL'을 포함할 수 있는데, 이 경우 예외 처리(exception handling) 없이 'setDisplayScreen(HScreen screen)' 메소드가 실행되면 현재의 논리 스크린은 더 이상 출력 스크린과 연관되지 않는다.The parameter of the 'setDisplayScreen (HScreen screen)' method may include 'NULL'. In this case, when the 'setDisplayScreen (HScreen screen)' method is executed without exception handling, the current logical screen is no longer present. It is not associated with an output screen.

그리고, 'setDisplayScreen(HScreen screen)' 메소드에 대한 예외 처리로서, 'SecurityException' 예외와 'IllegalStateException' 예외가 수행될 수 있다.As an exception for the 'setDisplayScreen (HScreen screen)' method, an 'SecurityException' exception and an 'IllegalStateException' exception may be performed.

'IllegalStateException' 예외는 현재의 스크린이 논리 스크린이 아니거나, 하드웨어 또는 소프트웨어 플랫폼의 특성상 파라미터로 제공되는 출력 스크린이 특정한 논리 스크린과 연관되어 현재의 논리 스크린을 상기 파라미터에 해당하는 출 력 스크린과 연관시킬 수 없는 경우에 수행될 수 있다.An 'IllegalStateException' exception is that the current screen is not a logical screen, or due to the nature of the hardware or software platform, an output screen that is provided as a parameter is associated with a particular logical screen to associate the current logical screen with an output screen corresponding to that parameter. It can be done if it can't.

서비스와 논리 스크린, 그리고 다수의 논리 스크린과 하나의 출력 스크린이 연결되면, 각각의 논리 스크린이 표현될 출력 스크린의 영역이 설정된다(S1340). 이 때, 각각의 논리 스크린에 대하여, 출력 스크린에 보여질 영역을 설정하기 위해 MultiScreenContext 모듈(1230)에 의해 제공되는 메소드를 호출할 수 있다.When a service and a logical screen, and a plurality of logical screens and one output screen are connected, an area of an output screen on which each logical screen is to be represented is set (S1340). At this time, for each logical screen, a method provided by the MultiScreenContext module 1230 may be called to set an area to be displayed on the output screen.

도 15는 본 발명의 실시예에 따른 검색 모듈(960)의 동작을 나타낸 예시도로서, 검색 모듈(960)은 전술한 제 1 검색 내지 제 4 검색(1510, 1520, 1530, 1540)을 수행할 수 있다.15 is a diagram illustrating an operation of the search module 960 according to an embodiment of the present invention, in which the search module 960 performs the above-described first to fourth searches 1510, 1520, 1530, and 1540. Can be.

제 1 검색(1510)을 수행하기 위하여 검색 모듈(960)은 'getScreenConfiguration' 메소드를 호출할 수 있다. 여기서, 'getScreenConfiguration' 메소드는 현재 활성화된 스크린의 설정 형태에 대한 인스턴스를 반환하는 메소드로서, 이는 MultiScreenConfiguration 클래스에 의해 제공될 수 있다.In order to perform the first search 1510, the search module 960 may call a 'getScreenConfiguration' method. Here, the 'getScreenConfiguration' method is a method that returns an instance of the configuration type of the currently activated screen, which may be provided by the MultiScreenConfiguration class.

예를 들어, 'getScreenConfiguration' 메소드는 'public MultiScreenConfiguration getScreenConfiguration() throws java.lang.SecurityException'의 형태로 표현될 수 있으며, 이 메소드는 현재 활성화된 스크린의 설정 형태에 대한 인스턴스인 MultiScreenConfiguration를 반환한다.For example, the 'getScreenConfiguration' method can be expressed in the form of 'public MultiScreenConfiguration getScreenConfiguration () throws java.lang.SecurityException', which returns a MultiScreenConfiguration that is an instance of the configuration type of the currently active screen.

그리고, 'getScreenConfiguration' 메소드의 호출이 허용되지 않는 경우 'SecurityException' 예외가 수행될 수 있다.In addition, when a call to the 'getScreenConfiguration' method is not allowed, an 'SecurityException' exception may be executed.

또한, 해당 스크린의 구체적인 설정 형태를 확인하기 위하여 검색 모듈(960)은 'getScreenConfigurationType' 메소드를 호출할 수 있다. 여기서, 'getScreenConfigurationType' 메소드는 현재 활성화된 스크린의 설정 형태를 반환하는 메소드로서, MultiScreenConfiguration 인터페이스에 의해 제공될 수 있다.In addition, the search module 960 may call a 'getScreenConfigurationType' method to check a specific configuration form of the screen. Here, the 'getScreenConfigurationType' method is a method for returning the setting type of the currently activated screen and may be provided by the MultiScreenConfiguration interface.

예를 들어, 'getScreenConfigurationType' 메소드는 For example, the 'getScreenConfigurationType' method

'int getScreenConfigurationType()'int getScreenConfigurationType ()

{return SCREEN_CONFIGURATION_NON_PIP, {return SCREEN_CONFIGURATION_NON_PIP,

SCREEN_CONFIGURATION_NON_PIP_WITH_OVERLAY,SCREEN_CONFIGURATION_NON_PIP_WITH_OVERLAY,

SCREEN_CONFIGURATION_PIP, SCREEN_CONFIGURATION_PIP,

SCREEN_CONFIGURATION_PIP_WITH_OVERLAY,SCREEN_CONFIGURATION_PIP_WITH_OVERLAY,

SCREEN_CONFIGURATION_POP, SCREEN_CONFIGURATION_POP,

SCREEN_CONFIGURATION_POP_WITH_OVERLAY, SCREEN_CONFIGURATION_POP_WITH_OVERLAY,

SCREEN_CONFIGURATION_GENERAL}'의 형태로 표현될 수 있으며, 이 메소드는 현재 활성화된 스크린의 설정 형태를 자신의 데이터 형인 정수형(integer)으로 반환한다. 여기서, 위에 나열된 설정 형태는 각각 전술한 단일 스크린 형태, 중첩 스크린 형태, PiP 스크린 형태, 중첩된 PiP 스크린 형태, PoP 스크린 형태, 중첩된 PoP 스크린 형태 및 일반 형태에 해당된다.SCREEN_CONFIGURATION_GENERAL} '. This method returns the configuration type of the currently active screen as its data type, integer. Here, the setting forms listed above correspond to the above-described single screen form, superimposed screen form, PiP screen form, superimposed PiP screen form, PoP screen form, superimposed PoP screen form and general form, respectively.

도 16a는 스크린의 설정 형태를 검색하기 위한 코드의 예시도로서, 현재 활성화된 스크린의 설정 형태가 PiP인지 PoP인지를 검색하는 코드이다. 즉, 검색 모듈(960)은 설정 형태가 SCREEN_CONFIGURATION_PIP이고, SCREEN_CONFIGURATION_PIP_WITH_OVERLAY인 경우를 PiP인 것으로 간주하고, 설정 형태가 SCREEN_CONFIGURATION_POP이고, SCREEN_CONFIGURATION_POP_WITH_OVERLAY인 경우를 PoP인 것으로 간주하며, 그 이외의 모든 경우를 PiP 또는 PoP가 아닌 것으로 간주하는 것이다.FIG. 16A illustrates an example of a code for searching for a setting form of a screen, and is a code for searching whether a setting form of a currently activated screen is PiP or PoP. That is, the search module 960 regards the case where the setting form is SCREEN_CONFIGURATION_PIP, the SCREEN_CONFIGURATION_PIP_WITH_OVERLAY is PiP, the case where the setting form is SCREEN_CONFIGURATION_POP, and the case where the setting form is SCREEN_CONFIGURATION_POP_WITH_OVERLAY is PoP, and all the other cases of PoP are It is not considered to be.

제 2 검색(1520)을 수행하기 위하여 검색 모듈(960)은 'getScreens' 메소드를 호출할 수 있다. 여기서, 'getScreens' 메소드는 장치에 생성된 모든 스크린의 집합을 반환하는 메소드로서, 그 데이터 형은 'org.havi.ui' 패키지의 'HScreen' 클래스 타입이다. 즉, 'getScreens' 메소드는 장치에 생성된 모든 'HScreen' 인스턴스의 집합을 반환하는 것이다.In order to perform the second search 1520, the search module 960 may call a 'getScreens' method. Here, the 'getScreens' method returns a set of all screens created on the device, and its data type is the 'HScreen' class type of the 'org.havi.ui' package. In other words, the 'getScreens' method returns a set of all 'HScreen' instances created on the device.

도 16b는 장치에 생성된 모든 스크린의 인스턴스를 검색하기 위한 코드의 예시도로서, 검색된 인스턴스를 이용하여 스크린의 설정 형태를 검색하는 코드이다. 즉, 'getScreens' 메소드를 통하여 반환된 접근 가능한 스크린의 인스턴스인 'screens'가 추출되고, 이를 통하여 각 스크린의 설정 형태가 순차적으로 검색되는 것이다.FIG. 16B is an exemplary diagram of a code for searching for all instances of screens generated in a device, and is a code for searching for a setting type of a screen using the found instance. That is, 'screens', which is an instance of the accessible screen returned through the 'getScreens' method, is extracted, and the setting type of each screen is sequentially retrieved.

제 3 검색(1530)을 수행하기 위하여 검색 모듈(960)은 'org.havi.ui.HScreen.getDefaultHScreen' 메소드를 호출할 수 있다. 여기서, 'getDefaultHScreen' 메소드는 단일 스크린을 검색하기 위한 것이다. 어플리케이션의 디폴트 스크린(default screen)은 그 어플리케이션이 속해있는 스크린이라고 정의하면, 어플리케이션은 'getDefaultHScreen' API를 이용하여 자신이 속한 스크린을 알아낼 수 있게 된다.In order to perform the third search 1530, the search module 960 may call an 'org.havi.ui.HScreen.getDefaultHScreen' method. Here, the 'getDefaultHScreen' method is for retrieving a single screen. If you define the default screen of the application as the screen to which the application belongs, the application can find out the screen to which it belongs using the 'getDefaultHScreen' API.

한편, 논리 스크린과 매핑된 출력 스크린을 검색하기 위하여 검색 모듈(960)은 'getDisplayScreen' 메소드가 호출될 수 있다. 여기서, 'getDisplayScreen' 메소드는 논리 스크린과 연결된 출력 스크린을 반환하는 메소드로서, 그 데이터 형은 'HScreen' 클래스 타입이며, 'MultiScreenContext' 인터페이스에 의해 제공될 수 있다.Meanwhile, in order to retrieve an output screen mapped with the logical screen, the search module 960 may call a 'getDisplayScreen' method. Here, the 'getDisplayScreen' method is a method for returning an output screen connected to a logical screen. The data type is 'HScreen' class type and may be provided by the 'MultiScreenContext' interface.

'getDisplayScreen' 메소드는 호출된 'HScreen'의 형태가 출력 스크린인 경우 이에 대한 참조 주소를 반환하고, 호출된 'HScreen'의 형태가 논리 스크린이고 이 논리 스크린이 출력 스크린과 연결된 경우 출력 스크린의 참조 주소를 반환한다. 한편, 'getDisplayScreen' 메소드는 호출된 'HScreen'의 형태가 논리 스크린이고 이 논리 스크린이 출력 스크린과 연결되어 있지 않는 경우 NULL을 반환한다.The 'getDisplayScreen' method returns a reference address for the type of the called 'HScreen' if it is an output screen, and a reference address for the output screen if the type of the called 'HScreen' is a logical screen and is associated with the output screen. Returns. On the other hand, the 'getDisplayScreen' method returns NULL if the type of the called 'HScreen' is a logical screen and the logical screen is not connected to the output screen.

도 16c는 어플리케이션이 속한 스크린을 검색하기 위한 코드의 예시도로서, 어플리케이션이 속한 스크린이 논리 스크린인지 출력 스크린인지를 판단한 후에 출력 스크린을 검색하는 코드이다FIG. 16C illustrates an example of code for searching for a screen to which an application belongs, and is a code for searching for an output screen after determining whether a screen to which the application belongs is a logical screen or an output screen.

즉, 'getDefaultHScreen' 메소드가 이용되어 디폴트 스크린인 'screen'이 추출되고, 이것이 'getScreenType' 메소드에 적용되어 해당 스크린이 논리 스크린인지 출력 스크린인지 확인되며, 그 결과에 따라 'getDisplayScreen' 메소드가 출력 스크린을 반환하는 것이다.In other words, the 'getDefaultHScreen' method is used to extract the default screen 'screen', which is applied to the 'getScreenType' method to determine whether the screen is a logical screen or an output screen, and accordingly the 'getDisplayScreen' method is an output screen. Will return

제 4 검색(1540)을 수행하기 위하여 검색 모듈(960)은 'getScreenType' 메소드, 'getDisplayArea' 메소드, 'getZOrder' 메소드, 'getServiceContexts' 메소드를 호출할 수 있다. 여기서, 'getScreenType' 메소드는 해당 스크린이 논리 스크린 인지 출력 스크린인지를 검색하기 위한 것으로서, 그 데이터 형은 정수형이며, 'SCREEN_TYPE_DISPLAY' 또는 'SCREEN_TYPE_LOGICAL'을 반환한다.In order to perform the fourth search 1540, the search module 960 may call a 'getScreenType' method, a 'getDisplayArea' method, a 'getZOrder' method, and a 'getServiceContexts' method. Here, the 'getScreenType' method is for searching whether the screen is a logical screen or an output screen. The data type is an integer and returns 'SCREEN_TYPE_DISPLAY' or 'SCREEN_TYPE_LOGICAL'.

'SCREEN_TYPE_DISPLAY'는 출력 스크린을 나타내는 값으로서, 'HScreen'이 'VideoOutputPort'에 연결되어 있고, 'VideoOutputPort'로부터 생성된 비디오 래스터에 매핑된 경우 'HScreen'의 형태는 'SCREEN_TYPE_DISPLAY'가 되는데, 이때의 'HScreen'을 출력 'HScreen'라 한다.'SCREEN_TYPE_DISPLAY' is a value representing the output screen. When 'HScreen' is connected to 'VideoOutputPort' and mapped to the video raster generated from 'VideoOutputPort', the type of 'HScreen' becomes 'SCREEN_TYPE_DISPLAY'. HScreen 'is called output' HScreen '.

한편, 'SCREEN_TYPE_LOGICAL'은 논리 스크린을 나타내는 값으로서, 'HScreen'이 'VideoOutputPort'에 연결되어 있지 않고, 'VideoOutputPort'로부터 생성된 비디오 래스터의 서브 영역(sub-region)에 매핑된 경우 'HScreen'의 형태는 'SCREEN_TYPE_LOGICAL'이 되는데, 이때의 'HScreen'을 논리 'HScreen'이라 한다.On the other hand, 'SCREEN_TYPE_LOGICAL' is a value representing a logical screen, and when 'HScreen' is not connected to 'VideoOutputPort' and is mapped to a sub-region of a video raster generated from 'VideoOutputPort', The type becomes 'SCREEN_TYPE_LOGICAL', where 'HScreen' is called logical 'HScreen'.

논리 'HScreen'은 출력 'HScreen'에 연결될 수도 있는데, 만일 논리 'HScreen'이 출력 'HScreen'에 연결되어 있지 않는 경우 시각적(visible)이고 청각적(audible)인 서비스는 논리 'HScreen'에 연결된 'ServiceContext'에 의하여 생성되지 않을 수 있다.Logical 'HScreen' may be connected to output 'HScreen', and if logical 'HScreen' is not connected to output 'HScreen', a visible and audible service will be connected to 'HScreen'. It may not be created by 'ServiceContext'.

도 16d는 어플리케이션이 속한 스크린의 형태를 검색하기 위한 코드의 예시도로서, 'getScreenType' 메소드를 이용하여 해당 스크린이 논리 스크린인지 출력 스크린인지를 검색하는 코드이다.FIG. 16D illustrates an example of code for searching for a form of a screen to which an application belongs, and is a code for searching whether a corresponding screen is a logical screen or an output screen using a 'getScreenType' method.

출력 스크린상에 위치한 어플리케이션의 좌표 및 z-order를 검색하기 위하여 'getDisplayArea' 메소드 및 'getZOrder' 메소드가 호출될 수 있다.The 'getDisplayArea' and 'getZOrder' methods can be called to retrieve the coordinates and z-order of the application located on the output screen.

'getDisplayArea' 메소드는 출력 스크린에 매핑된 논리 스크린의 좌표를 반 환하는데, 그 데이터 형은 'org.havi.ui.HScreenRectangle' 클래스 타입이다. 'getDisplayArea' 메소드는 'HScreen'의 범위(extent)를 반환하는데, 만일 'HScreen'의 형태가 'SCREEN_TYPE_DISPLAY'인 경우 'HScreenRectangle(0, 0, 1, 1)'을 반환하고, 만일 'HScreen'의 형태가 'SCREEN_TYPE_LOGICAL'이고 'HScreen'이 출력 'HScreen'에 연결된 경우 해당 논리 'HScreen'에 할당된 영역을 반환한다. 또한, 'HScreen'의 형태가 'SCREEN_TYPE_LOGICAL'이고, 'HScreen'이 출력 'HScreen'에 연결되어 있지 않는 경우 'getDisplayArea' 메소드는 NULL을 반환한다.The getDisplayArea method returns the coordinates of the logical screen mapped to the output screen, whose data type is of the 'org.havi.ui.HScreenRectangle' class type. The 'getDisplayArea' method returns an extent of 'HScreen'. If the type of 'HScreen' is 'SCREEN_TYPE_DISPLAY', it returns 'HScreenRectangle (0, 0, 1, 1)'. If the type is 'SCREEN_TYPE_LOGICAL' and 'HScreen' is connected to the output 'HScreen', the area allocated to the logical 'HScreen' is returned. Also, if the type of 'HScreen' is 'SCREEN_TYPE_LOGICAL' and 'HScreen' is not connected to the output 'HScreen', the 'getDisplayArea' method returns NULL.

도 16e는 어플리케이션이 속한 논리 스크린의 출력 스크린상에서의 위치 및 크기를 검색하기 위한 코드의 예시도로서, 'getDisplayArea' 메소드를 이용하여 해당 스크린의 위치 및 크기를 검색하는 코드이다.FIG. 16E illustrates an example of code for retrieving a position and size on an output screen of a logical screen to which an application belongs, and is a code for retrieving the position and size of a corresponding screen using a 'getDisplayArea' method.

'getZOrder' 메소드는 출력 스크린에 매핑된 논리 스크린의 z-order를 반환하는데, 그 데이터 형은 정수형이다. 'getZOrder' 메소드는 해당 'HScreen'이 출력 'HScreen'인 경우 0인 z-order를 반환하고, 해당 'HScreen'이 논리 'HScreen'인 경우 1 또는 그 이상의 값을 갖는 z-order를 반환한다.The getZOrder method returns the z-order of the logical screen mapped to the output screen, whose data type is integer. The 'getZOrder' method returns a z-order of 0 if the 'HScreen' is the output 'HScreen', and a z-order with 1 or more if the 'HScreen' is the logical 'HScreen'.

해당 스크린과 연관된 서비스 컨텍스트를 검색하기 위하여 'getServiceContexts' 메소드가 호출될 수 있다.The 'getServiceContexts' method can be called to retrieve the service contexts associated with the screen.

'getServiceContexts' 메소드는 'HScreen'에 연결된 서비스 컨텍스트의 집합을 반환하는데, 그 데이터 형은 'javax.tv.service.selection.ServiceContext' 클래스 타입이다.The 'getServiceContexts' method returns a set of service contexts associated with 'HScreen'. The data type is of the 'javax.tv.service.selection.ServiceContext' class type.

도 16f는 어플리케이션이 속한 스크린의 서비스 컨텍스트를 검색하기 위한 코드의 예시도로서, 'getServiceContexts' 메소드를 이용하여 해당 스크린의 서비스 컨텍스트를 검색하는 코드이다.FIG. 16F illustrates an example of code for retrieving a service context of a screen to which an application belongs, and is a code for retrieving service contexts of a corresponding screen by using a 'getServiceContexts' method.

도 17은 도 13에서 도시된 각 모듈들에 의하여 논리 스크린에 표현되는 서비스가 교환되는 과정을 도시한 플로우 차트이다.FIG. 17 is a flowchart illustrating a process of exchanging a service represented on a logical screen by each module illustrated in FIG. 13.

우선, MultiScreenManager 모듈(1210)은 서비스가 서로 교환될 두 논리 스크린에 존재하는 서비스를 일시 중지시킨다(S1410).First, the MultiScreenManager module 1210 suspends services existing in two logical screens whose services are to be exchanged with each other (S1410).

그리고 나서, 두 논리 스크린에 연결된 서비스의 정보를 교환한다(S1420). 이 때, 두 논리 스크린 객체 각각에 대해 'removeServiceContext' 메소드와 'addServiceContext' 메소드를 호출함으로써 논리 스크린에 설정된 서비스 컨텍스트를 교환할 수 있다. 여기에서 'removeServiceContext' 메소드는 논리 스크린에 연결되어 있던 서비스 컨텍스트를 제거하는 기능을 수행하는 메소드로서 이해될 수 있고, 'addServiceContext' 메소드는 논리 스크린에 새로운 서비스 컨텍스트를 추가하는 기능을 수행하는 메소드로서 이해될 수 있으며, 'removeServiceContext' 메소드와 'addServiceContext' 메소드는 MultiScreenContext 모듈(1230)에 의해 제공될 수 있다. 즉, 본 발명에서는 논리 스크린에 연결된 서비스에 대한 정보를 교환함으로써 종래의 주화면과 부화면을 서로 교환하는 효과뿐만 아니라, 예를 들어 디스플레이 화면(980)에 3개 이상의 서비스가 실연되고 있더라도 임의의 개수의 논리 스크린 간에 서비스의 교환이 가능하게 된다.Then, the information of the service connected to the two logical screens is exchanged (S1420). At this time, the service context set in the logical screen can be exchanged by calling the 'removeServiceContext' method and the 'addServiceContext' method for each of the two logical screen objects. Here, the 'removeServiceContext' method may be understood as a method for removing a service context connected to a logical screen, and the 'addServiceContext' method is used as a method for adding a new service context to a logical screen. The 'removeServiceContext' method and the 'addServiceContext' method may be provided by the MultiScreenContext module 1230. That is, in the present invention, not only the effect of exchanging the main and sub screens of the conventional main screen by exchanging information on the service connected to the logical screen, but also three or more services are demonstrated on the display screen 980, for example. It is possible to exchange services between a number of logical screens.

두 논리 스크린에 연결된 서비스의 정보가 교환되면, 서비스와 논리 스크린의 연결이 바뀌었다는 이벤트가 발생되고(S1430), 그리고 나서, 'MultiScreenContextEvent' 모듈(1240)은 발생된 이벤트를 'MultiScreenContextListener' 모듈(1250)로 전달하고, 두 논리 스크린에 새롭게 연결된 서비스에 대한 실행이 재개된다(S1440).When the information of the services connected to the two logical screens is exchanged, an event indicating that the connection between the service and the logical screen is changed is generated (S1430), and then the 'MultiScreenContextEvent' module 1240 sends the generated event to the 'MultiScreenContextListener' module 1250. ), And execution of the service newly connected to the two logical screens is resumed (S1440).

이상 첨부된 도면을 참조하여 본 발명의 실시예를 설명하였지만, 본 발명이 속하는 기술분야에서 통상의 지식을 가진 자는 본 발명이 그 기술적 사상이나 필수적인 특징을 변경하지 않고서 다른 구체적인 형태로 실시될 수 있다는 것을 이해할 수 있을 것이다. 그러므로 이상에서 기술한 실시예들은 모든 면에서 예시적인 것이며 한정적이 아닌 것으로 이해해야만 한다.Although embodiments of the present invention have been described above with reference to the accompanying drawings, those skilled in the art to which the present invention pertains may implement the present invention in other specific forms without changing the technical spirit or essential features thereof. I can understand that. Therefore, it should be understood that the embodiments described above are exemplary in all respects and not restrictive.

상기한 바와 같은 본 발명의 다중 스크린을 제공하는 장치 및 상기 다중 스크린의 동적 구성 방법에 따르면 시스템에 존재하는 스크린들의 형태 및 연결 관계를 검색함으로써 물리적인 디스플레이 화면에 복수 개의 컨텐츠를 제공하는 다수의 스크린을 사용자 또는 어플리케이션으로 하여금 용이하게 동적으로 구성할 수 있게 하는 장점이 있다.According to the apparatus for providing a multi-screen of the present invention and the dynamic configuration method of the multi-screen as described above, a plurality of screens for providing a plurality of contents on a physical display screen by searching for the form and connection relationship of the screens present in the system Has the advantage of allowing the user or application to easily and dynamically configure.

Claims (51)

삭제delete 삭제delete 삭제delete 삭제delete 삭제delete 삭제delete 삭제delete 삭제delete 삭제delete 삭제delete 삭제delete 삭제delete 삭제delete 삭제delete 삭제delete 삭제delete 삭제delete 삭제delete 삭제delete 삭제delete 삭제delete 삭제delete 삭제delete 삭제delete 삭제delete 삭제delete 삭제delete 삭제delete 삭제delete 삭제delete 삭제delete 삭제delete 삭제delete 삭제delete 삭제delete 비디오 서비스, 오디오 서비스, 데이터 서비스 중에서 적어도 하나의 서비스를 수신하고, 상기 수신된 서비스를 표시하는 스크린을 제공하는 장치에 있어서, An apparatus for receiving at least one of a video service, an audio service, and a data service, and providing a screen displaying the received service. 상기 스크린 및 상기 서비스의 연관 관계 및 상기 스크린 설정 형태 정보를 포함하는 상기 스크린의 스크린 속성 정보를 설정하는 모듈;A module configured to set screen property information of the screen including association information between the screen and the service and the screen setting type information; 상기 수신된 서비스가 상기 스크린 상에 표현되도록 상기 스크린 속성 정보의 설정 동작을 관리하는 모듈; 및A module for managing a setting operation of the screen attribute information such that the received service is represented on the screen; And 상기 스크린 중 어플리케이션이 접근할 수 있는 스크린을 확인하는 모듈을 포함하는 것을 특징으로 하는 스크린 제공 장치.And a module for identifying a screen accessible by an application among the screens. 제 36 항에 있어서, The method of claim 36, 상기 어플리케이션은 상기 데이터 서비스에 포함된 어플리케이션인 것을 특징으로 하는 스크린 제공 장치.And the application is an application included in the data service. 제 36 항에 있어서, 상기 스크린 확인 모듈은,The method of claim 36, wherein the screen identification module, 상기 스크린의 스크린 속성 정보 중 상기 스크린에 연관된 서비스 컨텍스트 정보에 기초하여 상기 어플리케이션이 접근할 수 있는 스크린을 확인하는 것을 특징으로 하는 스크린 제공 장치.And identifying a screen accessible by the application based on service context information associated with the screen among screen property information of the screen. 제 36 항에 있어서, The method of claim 36, 상기 스크린 속성 정보는, 상기 스크린의 표시 방식 정보 및 상기 스크린 및 출력 포트의 연관 관계 정보 중 적어도 하나를 더 포함하는 것을 특징으로 하는 스크린 제공 장치.The screen property information may further include at least one of display mode information of the screen and association information between the screen and an output port. 삭제delete 삭제delete 제 36 항에 있어서,The method of claim 36, 상기 스크린은 적어도 하나 이상인 것을 특징으로 하는 스크린 제공 장치.The screen providing apparatus, characterized in that at least one screen. 제 36항 있어서,The method of claim 36, 상기 스크린은 논리 스크린 및 출력 스크린 중 적어도 하나를 포함하고, The screen comprises at least one of a logic screen and an output screen, 상기 출력 스크린은 출력 포트에 출력되는 스크린이고, 상기 논리 스크린은 상기 서비스가 연관되는 스크린인 것을 특징으로 하는 스크린 제공 장치.And the output screen is a screen output to an output port, and the logical screen is a screen to which the service is associated. 비디오 서비스, 오디오 서비스, 데이터 서비스 중에서 적어도 하나의 서비스를 수신하고, 상기 수신된 서비스를 표시하는 스크린을 구성하는 방법에 있어서, A method of receiving a video service, an audio service, a data service and receiving at least one service, and configuring a screen displaying the received service. 상기 스크린 및 상기 서비스의 연관 관계 및 상기 스크린 설정 형태 정보를 포함하는 상기 스크린의 스크린 속성 정보를 설정하는 단계;Setting screen property information of the screen including the correlation between the screen and the service and the screen setting type information; 상기 수신된 서비스가 상기 스크린 상에 표현되도록 상기 스크린 속성 정보의 설정 동작을 관리하는 단계; 및Managing a setting operation of the screen attribute information such that the received service is represented on the screen; And 상기 스크린 중 어플리케이션이 접근할 수 있는 스크린을 확인하는 단계를 포함하는 것을 특징으로 하는 스크린 구성 방법.Identifying a screen accessible by an application among the screens. 제 44 항에 있어서, The method of claim 44, 상기 어플리케이션은 상기 데이터 서비스에 포함된 어플리케이션인 것을 특징으로 하는 스크린 구성 방법.And the application is an application included in the data service. 제 44 항에 있어서, 상기 스크린 확인 단계는,45. The method of claim 44, wherein checking the screen 상기 스크린의 스크린 속성 정보 중 상기 스크린에 연관된 서비스 컨텍스트 정보에 기초하여 상기 어플리케이션이 접근할 수 있는 스크린을 확인하는 것을 특징으로 하는 스크린 구성 방법.And identifying a screen accessible by the application based on service context information associated with the screen among screen property information of the screen. 제 44 항에 있어서, The method of claim 44, 상기 스크린 속성 정보는, 상기 스크린의 표시 방식 정보 및 상기 스크린 및 출력 포트의 연관 관계 정보 중 적어도 하나를 더 포함하는 것을 특징으로 하는 스크린 구성 방법.The screen property information may further include at least one of display method information of the screen and association information between the screen and an output port. 삭제delete 삭제delete 제 44 항에 있어서,The method of claim 44, 상기 스크린은 적어도 하나 이상인 것을 특징으로 하는 스크린 구성 방법.And at least one of said screens. 제 44항 있어서,The method of claim 44, 상기 스크린은 논리 스크린 및 출력 스크린 중 적어도 하나를 포함하고, The screen comprises at least one of a logic screen and an output screen, 상기 출력 스크린은 출력 포트에 출력되는 스크린이고, 상기 논리 스크린은 상기 서비스가 연관되는 스크린인 것을 특징으로 하는 스크린 구성 방법.The output screen is a screen output to an output port, and the logical screen is a screen to which the service is associated.
KR1020060073115A 2005-08-05 2006-08-02 Apparatus for providing multiple screens and method for dynamic configuration of the same KR100888595B1 (en)

Priority Applications (7)

Application Number Priority Date Filing Date Title
KR1020060073115A KR100888595B1 (en) 2005-08-05 2006-08-02 Apparatus for providing multiple screens and method for dynamic configuration of the same
PCT/KR2006/003083 WO2007018385A1 (en) 2005-08-05 2006-08-04 Apparatus for providing multiple screens and method of dynamically configuring multiple screens
EP06823626A EP1935174A4 (en) 2005-08-05 2006-08-04 Apparatus for providing multiple screens and method of dynamically configuring multiple screens
JP2008524905A JP2009503605A (en) 2005-08-05 2006-08-04 Apparatus for providing a multi-screen and a method for dynamically configuring the multi-screen
CA002616257A CA2616257A1 (en) 2005-08-05 2006-08-04 Apparatus for providing multiple screens and method of dynamically configuring multiple screens
CN2006800286553A CN101238717B (en) 2005-08-05 2006-08-04 Apparatus for providing multiple screens and method of dynamically configuring multiple screens
MX2008001483A MX2008001483A (en) 2005-08-05 2006-08-04 Apparatus for providing multiple screens and method of dynamically configuring multiple screens.

Applications Claiming Priority (4)

Application Number Priority Date Filing Date Title
US60/705,491 2005-08-05
US60/789,577 2006-04-06
US60/812,090 2006-06-09
KR1020060073115A KR100888595B1 (en) 2005-08-05 2006-08-02 Apparatus for providing multiple screens and method for dynamic configuration of the same

Related Child Applications (2)

Application Number Title Priority Date Filing Date
KR1020080023449A Division KR20080030974A (en) 2005-08-05 2008-03-13 Apparatus for providing multiple screens and method for dynamic configuration of the same
KR1020080088514A Division KR20080088552A (en) 2005-08-05 2008-09-08 Apparatus for providing multiple screens and method for dynamic configuration of the same

Publications (2)

Publication Number Publication Date
KR20070017008A KR20070017008A (en) 2007-02-08
KR100888595B1 true KR100888595B1 (en) 2009-03-16

Family

ID=41347097

Family Applications (1)

Application Number Title Priority Date Filing Date
KR1020060073115A KR100888595B1 (en) 2005-08-05 2006-08-02 Apparatus for providing multiple screens and method for dynamic configuration of the same

Country Status (1)

Country Link
KR (1) KR100888595B1 (en)

Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR19980048945A (en) * 1996-12-18 1998-09-15 양승택 Video and graphic window control device and its control method
KR20020078256A (en) * 2001-04-06 2002-10-18 엘지전자 주식회사 Apparatus for processing multi screen in digital TV

Patent Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR19980048945A (en) * 1996-12-18 1998-09-15 양승택 Video and graphic window control device and its control method
KR20020078256A (en) * 2001-04-06 2002-10-18 엘지전자 주식회사 Apparatus for processing multi screen in digital TV

Also Published As

Publication number Publication date
KR20070017008A (en) 2007-02-08

Similar Documents

Publication Publication Date Title
KR20080088552A (en) Apparatus for providing multiple screens and method for dynamic configuration of the same
KR100846790B1 (en) Apparatus for providing multiple screens and method for dynamic configuration of the same
JP2009504066A (en) Apparatus for providing a multi-screen and a method for dynamically configuring the multi-screen
KR100917885B1 (en) Method and apparatus for providing a plurality of screens, and a computer readable recording medium having embodied thereon a computer program for executing the method for providing a plurality of screens
KR100888595B1 (en) Apparatus for providing multiple screens and method for dynamic configuration of the same
KR100891111B1 (en) Apparatus for providing multiple screens and method for dynamic configuration of the same
KR20070100138A (en) Apparatus and method for identifying an application in the multiple screens environment
KR100725421B1 (en) Apparatus for providing multiple screens and method for dynamic configuration of the same
KR100791302B1 (en) Apparatus for providing multiple screens and method for dynamic configuration of the same
KR100791301B1 (en) Apparatus for providing multiple screens and method for dynamic configuration of the same
KR20070100112A (en) Apparatus for providing multiple screens and method for dynamic configuration of the same
KR100900973B1 (en) Apparatus for providing multiple screens and method for dynamic configuration of the same
KR100725420B1 (en) Apparatus and method for multiple screen
KR100781529B1 (en) Apparatus and method for multiple screen
KR100900975B1 (en) Apparatus for providing multiple screens and method for dynamic configuration of the same
KR100900974B1 (en) Apparatus for providing multiple screens and method for dynamic configuration of the same
JP2009503605A (en) Apparatus for providing a multi-screen and a method for dynamically configuring the multi-screen
JP2009504068A (en) Apparatus for providing a multi-screen and a method for dynamically configuring the multi-screen

Legal Events

Date Code Title Description
A201 Request for examination
E902 Notification of reason for refusal
A107 Divisional application of patent
E90F Notification of reason for final refusal
A107 Divisional application of patent
E701 Decision to grant or registration of patent right
GRNT Written decision to grant
FPAY Annual fee payment

Payment date: 20130227

Year of fee payment: 5

FPAY Annual fee payment

Payment date: 20140227

Year of fee payment: 6

FPAY Annual fee payment

Payment date: 20150226

Year of fee payment: 7

FPAY Annual fee payment

Payment date: 20160226

Year of fee payment: 8

FPAY Annual fee payment

Payment date: 20170224

Year of fee payment: 9

LAPS Lapse due to unpaid annual fee