KR102609450B1 - 전자 장치 및 전자 장치의 전자 문서 출력 방법 - Google Patents

전자 장치 및 전자 장치의 전자 문서 출력 방법 Download PDF

Info

Publication number
KR102609450B1
KR102609450B1 KR1020160056703A KR20160056703A KR102609450B1 KR 102609450 B1 KR102609450 B1 KR 102609450B1 KR 1020160056703 A KR1020160056703 A KR 1020160056703A KR 20160056703 A KR20160056703 A KR 20160056703A KR 102609450 B1 KR102609450 B1 KR 102609450B1
Authority
KR
South Korea
Prior art keywords
area
code
electronic device
display
processor
Prior art date
Application number
KR1020160056703A
Other languages
English (en)
Other versions
KR20170126362A (ko
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 KR1020160056703A priority Critical patent/KR102609450B1/ko
Priority to US15/588,971 priority patent/US10325533B2/en
Publication of KR20170126362A publication Critical patent/KR20170126362A/ko
Application granted granted Critical
Publication of KR102609450B1 publication Critical patent/KR102609450B1/ko

Links

Images

Classifications

    • GPHYSICS
    • G09EDUCATION; CRYPTOGRAPHY; DISPLAY; ADVERTISING; SEALS
    • G09GARRANGEMENTS OR CIRCUITS FOR CONTROL OF INDICATING DEVICES USING STATIC MEANS TO PRESENT VARIABLE INFORMATION
    • G09G3/00Control arrangements or circuits, of interest only in connection with visual indicators other than cathode-ray tubes
    • G09G3/001Control arrangements or circuits, of interest only in connection with visual indicators other than cathode-ray tubes using specific devices not provided for in groups G09G3/02 - G09G3/36, e.g. using an intermediate record carrier such as a film slide; Projection systems; Display of non-alphanumerical information, solely or in combination with alphanumerical information, e.g. digital display on projected diapositive as background
    • G09G3/003Control arrangements or circuits, of interest only in connection with visual indicators other than cathode-ray tubes using specific devices not provided for in groups G09G3/02 - G09G3/36, e.g. using an intermediate record carrier such as a film slide; Projection systems; Display of non-alphanumerical information, solely or in combination with alphanumerical information, e.g. digital display on projected diapositive as background to produce spatial visual effects
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/90Details of database functions independent of the retrieved data types
    • G06F16/95Retrieval from the web
    • G06F16/954Navigation, e.g. using categorised browsing
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/90Details of database functions independent of the retrieved data types
    • G06F16/95Retrieval from the web
    • G06F16/957Browsing optimisation, e.g. caching or content distillation
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/01Input arrangements or combined input and output arrangements for interaction between user and computer
    • G06F3/011Arrangements for interaction with the human body, e.g. for user immersion in virtual reality
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/01Input arrangements or combined input and output arrangements for interaction between user and computer
    • G06F3/011Arrangements for interaction with the human body, e.g. for user immersion in virtual reality
    • G06F3/013Eye tracking input arrangements
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/01Input arrangements or combined input and output arrangements for interaction between user and computer
    • G06F3/048Interaction techniques based on graphical user interfaces [GUI]
    • G06F3/0481Interaction techniques based on graphical user interfaces [GUI] based on specific properties of the displayed interaction object or a metaphor-based environment, e.g. interaction with desktop elements like windows or icons, or assisted by a cursor's changing behaviour or appearance
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/01Input arrangements or combined input and output arrangements for interaction between user and computer
    • G06F3/048Interaction techniques based on graphical user interfaces [GUI]
    • G06F3/0481Interaction techniques based on graphical user interfaces [GUI] based on specific properties of the displayed interaction object or a metaphor-based environment, e.g. interaction with desktop elements like windows or icons, or assisted by a cursor's changing behaviour or appearance
    • G06F3/04815Interaction with a metaphor-based environment or interaction object displayed as three-dimensional, e.g. changing the user viewpoint with respect to the environment or object
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/01Input arrangements or combined input and output arrangements for interaction between user and computer
    • G06F3/048Interaction techniques based on graphical user interfaces [GUI]
    • G06F3/0481Interaction techniques based on graphical user interfaces [GUI] based on specific properties of the displayed interaction object or a metaphor-based environment, e.g. interaction with desktop elements like windows or icons, or assisted by a cursor's changing behaviour or appearance
    • G06F3/0482Interaction with lists of selectable items, e.g. menus
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/14Digital output to display device ; Cooperation and interconnection of the display device with other functional units
    • G06F3/147Digital output to display device ; Cooperation and interconnection of the display device with other functional units using display panels
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F40/00Handling natural language data
    • G06F40/10Text processing
    • G06F40/103Formatting, i.e. changing of presentation of documents
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F40/00Handling natural language data
    • G06F40/10Text processing
    • G06F40/12Use of codes for handling textual entities
    • G06F40/14Tree-structured documents
    • G06F40/143Markup, e.g. Standard Generalized Markup Language [SGML] or Document Type Definition [DTD]
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F40/00Handling natural language data
    • G06F40/20Natural language analysis
    • G06F40/205Parsing
    • G06F40/221Parsing markup language streams
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/44Arrangements for executing specific programs
    • G06F9/451Execution arrangements for user interfaces
    • GPHYSICS
    • G09EDUCATION; CRYPTOGRAPHY; DISPLAY; ADVERTISING; SEALS
    • G09GARRANGEMENTS OR CIRCUITS FOR CONTROL OF INDICATING DEVICES USING STATIC MEANS TO PRESENT VARIABLE INFORMATION
    • G09G5/00Control arrangements or circuits for visual indicators common to cathode-ray tube indicators and other visual indicators
    • G09G5/14Display of multiple viewports
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N13/00Stereoscopic video systems; Multi-view video systems; Details thereof
    • H04N13/20Image signal generators
    • H04N13/293Generating mixed stereoscopic images; Generating mixed monoscopic and stereoscopic images, e.g. a stereoscopic image overlay window on a monoscopic image background
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N13/00Stereoscopic video systems; Multi-view video systems; Details thereof
    • H04N13/30Image reproducers
    • H04N13/332Displays for viewing with the aid of special glasses or head-mounted displays [HMD]
    • H04N13/344Displays for viewing with the aid of special glasses or head-mounted displays [HMD] with head-mounted left-right displays
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F2203/00Indexing scheme relating to G06F3/00 - G06F3/048
    • G06F2203/048Indexing scheme relating to G06F3/048
    • G06F2203/04803Split screen, i.e. subdividing the display area or the window area into separate subareas
    • GPHYSICS
    • G09EDUCATION; CRYPTOGRAPHY; DISPLAY; ADVERTISING; SEALS
    • G09GARRANGEMENTS OR CIRCUITS FOR CONTROL OF INDICATING DEVICES USING STATIC MEANS TO PRESENT VARIABLE INFORMATION
    • G09G2370/00Aspects of data communication
    • G09G2370/02Networking aspects
    • GPHYSICS
    • G09EDUCATION; CRYPTOGRAPHY; DISPLAY; ADVERTISING; SEALS
    • G09GARRANGEMENTS OR CIRCUITS FOR CONTROL OF INDICATING DEVICES USING STATIC MEANS TO PRESENT VARIABLE INFORMATION
    • G09G2370/00Aspects of data communication
    • G09G2370/02Networking aspects
    • G09G2370/027Arrangements and methods specific for the display of internet documents
    • GPHYSICS
    • G09EDUCATION; CRYPTOGRAPHY; DISPLAY; ADVERTISING; SEALS
    • G09GARRANGEMENTS OR CIRCUITS FOR CONTROL OF INDICATING DEVICES USING STATIC MEANS TO PRESENT VARIABLE INFORMATION
    • G09G2380/00Specific applications
    • G09G2380/08Biomedical applications

Abstract

전자 장치가 개시된다. 본 발명의 일 실시 예에 따른 VR(virtual reality) 환경을 지원하는 전자 장치는 웹 브라우저의 실행 화면을 출력하는 디스플레이, 디스플레이에 구성되거나 디스플레이와 별도로 구성되는 입력 장치, 인터넷과 무선 또는 유선으로 통신 채널을 형성하는 통신 회로, 통신 회로, 디스플레이 및 입력 장치와 전기적으로 연결된 프로세서, 및 웹 브라우저를 위한 프로그램 및 인스트럭션(instruction)을 저장하고, 프로세서와 전기적으로 연결된 메모리를 포함하고, 메모리는, 실행 시에, 프로세서가 디스플레이에 웹 브라우저를 표시하고, 컨텐츠를 표시하는 평면적 표시 영역인 제1 영역과 연관된 제1 코드 및 웹 브라우저의 사용자 인터페이스를 표시하는 입체적 표시 영역인 제2 영역과 연관된 제2 코드를 포함하는 웹 문서를 통신 회로를 통해 수신하고, 제1 코드에 기초하여 제1 영역에 컨텐츠를 표시하고, 제2 코드에 기초하여 제2 영역에 컨텐츠와 상호작용 가능한 오브젝트를 표시하도록 하는 인스트럭션들(instructions)을 저장할 수 있다. 이 외에도 명세서를 통해 파악되는 다양한 실시 예가 가능하다.

Description

전자 장치 및 전자 장치의 전자 문서 출력 방법{ELECTRONIC DEVICE AND METHOD FOR DISPLAY ELECTRONIC DOCUMENT THEREOF}
본 발명의 다양한 실시 예들은 VR(virtual reality) 환경에서 전자 문서를 출력하는 기술과 관련된다.
전자 기술의 발달에 힘입어 다양한 유형의 전자 제품들이 개발 및 보급되고 있다. 최근에는 VR(virtual reality) 환경을 지원하는 전자 장치에 대한 관심이 확대되고 있다. 예를 들어, 사용자의 머리에 착용될 수 있는 머리 착용형 장치(HMD: head-mounted device)에 대한 개발이 활발히 이루어지고 있다. 머리 착용형 장치는 사용자의 움직임이 감지하고, 움직임에 대응하는 전방위 영상의 일부를 사용자에게 제공할 수 있다.
VR(virtual reality) 환경을 지원하는 전자 장치(예: 스마트 폰)는 웹 브라우저를 이용하여 웹 페이지를 표시하는 경우 평면적 영역에 웹 페이지를 표시하고, 웹 페이지가 표시된 영역을 제외한 주변 영역에 웹 브라우저의 사용자 인터페이스를 표시할 수 있다. VR 환경을 지원하는 전자 장치에 의해 제공되는 영상이 전방위 영상인 경우, 주변 영역의 면적은 오히려 웹 페이지가 표시된 영역의 면적보다 클 수 있다. 따라서, 공간의 효과적인 활용을 위해 주변 영역의 다양한 활용 방법이 요구될 수 있다.
본 발명의 다양한 실시 예들은, 웹 페이지가 표시되는 영역의 외부 영역에 다양한 오브젝트를 표시할 수 있는 전자 장치 및 방법을 제공할 수 있다.
본 발명의 일 실시 예에 따른 VR(virtual reality) 환경을 지원하는 전자 장치는 웹 브라우저의 실행 화면을 출력하는 디스플레이, 디스플레이에 구성되거나 디스플레이와 별도로 구성되는 입력 장치, 인터넷과 무선 또는 유선으로 통신 채널을 형성하는 통신 회로, 통신 회로, 디스플레이 및 입력 장치와 전기적으로 연결된 프로세서, 및 웹 브라우저를 위한 프로그램 및 인스트럭션(instruction)을 저장하고, 프로세서와 전기적으로 연결된 메모리를 포함하고, 메모리는, 실행 시에, 프로세서가 디스플레이에 웹 브라우저를 표시하고, 컨텐츠를 표시하는 평면적 표시 영역인 제1 영역과 연관된 제1코드 및 웹 브라우저의 사용자 인터페이스를 표시하는 입체적 표시 영역인 제2 영역과 연관된 제2 코드를 포함하는 웹 문서를 통신 회로를 통해 수신하고, 제1 코드에 기초하여 제1 영역에 컨텐츠를 표시하고, 제2 코드에 기초하여 제2 영역에 컨텐츠와 상호작용 가능한 오브젝트를 표시하도록 하는 인스트럭션들(instructions)을 저장할 수 있다.
또한, 본 발명의 일 실시 예에 따른 전자 장치는 다시점 이미지로 제공되는 웹 브라우저의 실행 화면을 출력하는 디스플레이 -웹 브라우저의 실행 화면은 컨텐츠를 표시하는 평면적 표시 영역인 제1 영역 및 웹 브라우저의 사용자 인터페이스를 표시하는 입체적 표시 영역인 제2 영역을 포함함-, 서버로부터 제1 영역과 연관된 제1 코드 및 제2 영역과 연관된 제2 코드를 포함하는 웹 문서를 수신하는 통신 회로, 제1 코드에 기초하여 제1 영역에 컨텐츠를 표시하고, 제2 코드에 기초하여 제2 영역에 오브젝트를 표시하도록 설정된 프로세서를 포함할 수 있다.
또한, 본 발명의 일 실시 예에 따른 방법은 웹 브라우저를 실행하는 동작, 다시점 이미지로 제공되는 웹 브라우저의 실행 화면을 출력하는 동작 -웹 브라우저의 실행 화면은 컨텐츠를 표시하는 평면적 표시 영역인 제1 영역 및 웹 브라우저의 사용자 인터페이스를 표시하는 입체적 표시 영역인 제2 영역을 포함함-, 서버로부터 제1 영역과 연관된 제1 코드 및 제2 영역과 연관된 제2 코드를 포함하는 웹 문서를 수신하는 동작, 제1 코드에 기초하여 제1 영역에 컨텐츠를 표시하는 동작 및 제2 코드에 기초하여 제2 영역에 오브젝트를 표시하는 동작을 포함할 수 있다.
또한, 본 발명의 일 실시 예에 따른 저장 매체는 적어도 하나의 프로세서 또는 디스플레이 구동 회로에 의해 실행되며 컴퓨터로 읽을 수 있는 명령어가 저장되고, 명령어는 웹 브라우저를 실행하는 동작, 다시점 이미지로 제공되는 웹 브라우저의 실행 화면을 출력하는 동작 -웹 브라우저의 실행 화면은 컨텐츠를 표시하는 평면적 표시 영역인 제1 영역 및 웹 브라우저의 사용자 인터페이스를 표시하는 입체적 표시 영역인 제2 영역을 포함함-, 서버로부터 제1 영역과 연관된 제1 코드 및 제2 영역과 연관된 제2 코드를 포함하는 웹 문서를 수신하는 동작, 제1 코드에 기초하여 제1 영역에 컨텐츠를 표시하는 동작 및 제2 코드에 기초하여 제2 영역에 오브젝트를 표시하는 동작을 수행하도록 설정될 수 있다.
본 발명의 일 실시 예에 따르면, 사용자 인터페이스를 표시하는 크롬(chrome) 영역에 다양한 오브젝트를 표시함으로써, 크롬 영역의 활용성을 향상시킬 수 있는 전자 장치 및 방법이 제공될 수 있다.
이 외에, 본 문서를 통해 직접적 또는 간접적으로 파악되는 다양한 효과들이 제공될 수 있다.
도 1은 본 발명의 일 실시 예에 따른 전자 장치의 동작 환경을 나타낸다.
도 2는 본 발명의 일 실시 예에 따른 전자 장치의 구성을 나타내는 블록도이다.
도 3은 본 발명의 일 실시 예에 따른 전자 장치의 웹 문서 출력 방법을 설명하기 위한 흐름도이다.
도 4는 본 발명의 일 실시 예에 따른 전자 장치에 의해 출력된 예시적인 화면을 도시한다.
도 5는 본 발명의 일 실시 예에 따른 전자 장치에 의해 출력된 예시적인 화면을 도시한다.
도 6은 본 발명의 일 실시 예에 따른 전자 장치에 의해 출력된 예시적인 화면을 도시한다.
도 7은 본 발명의 일 실시 예에 따른 전자 장치에 의해 출력된 예시적인 화면을 도시한다.
도 8은 본 발명의 일 실시 예에 따른 전자 장치에 의해 출력된 예시적인 화면을 도시한다.
도 9는 본 발명의 일 실시 예에 따른 전자 장치에 의해 출력된 예시적인 화면을 도시한다.
도 10은 본 발명의 일 실시 예에 따른 전자 장치에 의해 출력된 예시적인 화면을 도시한다.
도 11은 본 발명의 일 실시 예에 따른 전자 장치에 의해 출력된 예시적인 화면을 도시한다.
도 12는 본 발명의 다양한 실시 예에 따른 네트워크 환경 내의 전자 장치를 나타낸다.
도 13은 본 발명의 다양한 실시 예에 따른 전자 장치의 블록도를 나타낸다.
도 14는 본 발명의 다양한 실시 예에 따른 프로그램 모듈의 블록도를 나타낸다.
이하, 본 문서의 다양한 실시예들이 첨부된 도면을 참조하여 기재된다. 실시예 및 이에 사용된 용어들은 본 문서에 기재된 기술을 특정한 실시 형태에 대해 한정하려는 것이 아니며, 해당 실시예의 다양한 변경, 균등물, 및/또는 대체물을 포함하는 것으로 이해되어야 한다. 도면의 설명과 관련하여, 유사한 구성요소에 대해서는 유사한 참조 부호가 사용될 수 있다. 단수의 표현은 문맥상 명백하게 다르게 뜻하지 않는 한, 복수의 표현을 포함할 수 있다. 본 문서에서, "A 또는 B" 또는 "A 및/또는 B 중 적어도 하나" 등의 표현은 함께 나열된 항목들의 모든 가능한 조합을 포함할 수 있다. "제 1," "제 2," "첫째," 또는 "둘째,"등의 표현들은 해당 구성요소들을, 순서 또는 중요도에 상관없이 수식할 수 있고, 한 구성요소를 다른 구성요소와 구분하기 위해 사용될 뿐 해당 구성요소들을 한정하지 않는다. 어떤(예: 제 1) 구성요소가 다른(예: 제 2) 구성요소에 "(기능적으로 또는 통신적으로) 연결되어" 있다거나 "접속되어" 있다고 언급된 때에는, 상기 어떤 구성요소가 상기 다른 구성요소에 직접적으로 연결되거나, 다른 구성요소(예: 제 3 구성요소)를 통하여 연결될 수 있다.
본 문서에서, "~하도록 구성된(또는 설정된)(configured to)"은 상황에 따라, 예를 들면, 하드웨어적 또는 소프트웨어적으로 "~에 적합한," "~하는 능력을 가지는," "~하도록 변경된," "~하도록 만들어진," "~를 할 수 있는," 또는 또는 "~하도록 설계된"과 상호 호환적으로(interchangeably) 사용될 수 있다. 어떤 상황에서는, "~하도록 구성된 장치"라는 표현은, 그 장치가 다른 장치 또는 부품들과 함께 "~할 수 있는" 것을 의미할 수 있다. 예를 들면, 문구 "A, B, 및 C를 수행하도록 구성된(또는 설정된) 프로세서"는 해당 동작을 수행하기 위한 전용 프로세서(예: 임베디드 프로세서), 또는 메모리 장치에 저장된 하나 이상의 소프트웨어 프로그램들을 실행함으로써, 해당 동작들을 수행할 수 있는 범용 프로세서(예: CPU 또는 application processor)를 의미할 수 있다.
본 문서의 다양한 실시예들에 따른 전자 장치는, 예를 들면, 스마트폰, 태블릿 PC, 이동 전화기, 영상 전화기, 전자책 리더기, 데스크탑 PC, 랩탑 PC, 넷북 컴퓨터, 워크스테이션, 서버, PDA, PMP(portable multimedia player), MP3 플레이어, 의료기기, 카메라, 또는 웨어러블 장치 중 적어도 하나를 포함할 수 있다. 웨어러블 장치는 액세서리형(예: 시계, 반지, 팔찌, 발찌, 목걸이, 안경, 콘택트 렌즈, 또는 머리 착용형 장치(head-mounted-device(HMD)), 직물 또는 의류 일체형(예: 전자 의복), 신체 부착형(예: 스킨 패드 또는 문신), 또는 생체 이식형 회로 중 적어도 하나를 포함할 수 있다. 어떤 실시예들에서, 전자 장치는, 예를 들면, 텔레비전, DVD(digital video disk) 플레이어, 오디오, 냉장고, 에어컨, 청소기, 오븐, 전자레인지, 세탁기, 공기 청정기, 셋톱 박스, 홈 오토매이션 컨트롤 패널, 보안 컨트롤 패널, 미디어 박스(예: 삼성 HomeSyncTM, 애플TVTM, 또는 구글 TVTM), 게임 콘솔(예: XboxTM, PlayStationTM), 전자 사전, 전자 키, 캠코더, 또는 전자 액자 중 적어도 하나를 포함할 수 있다.
다른 실시예에서, 전자 장치는, 각종 의료기기(예: 각종 휴대용 의료측정기기(혈당 측정기, 심박 측정기, 혈압 측정기, 또는 체온 측정기 등), MRA(magnetic resonance angiography), MRI(magnetic resonance imaging), CT(computed tomography), 촬영기, 또는 초음파기 등), 네비게이션 장치, 위성 항법 시스템(GNSS(global navigation satellite system)), EDR(event data recorder), FDR(flight data recorder), 자동차 인포테인먼트 장치, 선박용 전자 장비(예: 선박용 항법 장치, 자이로 콤파스 등), 항공 전자기기(avionics), 보안 기기, 차량용 헤드 유닛(head unit), 산업용 또는 가정용 로봇, 드론(drone), 금융 기관의 ATM, 상점의 POS(point of sales), 또는 사물 인터넷 장치 (예: 전구, 각종 센서, 스프링클러 장치, 화재 경보기, 온도조절기, 가로등, 토스터, 운동기구, 온수탱크, 히터, 보일러 등) 중 적어도 하나를 포함할 수 있다. 어떤 실시예에 따르면, 전자 장치는 가구, 건물/구조물 또는 자동차의 일부, 전자 보드(electronic board), 전자 사인 수신 장치(electronic signature receiving device), 프로젝터, 또는 각종 계측 기기(예: 수도, 전기, 가스, 또는 전파 계측 기기 등) 중 적어도 하나를 포함할 수 있다. 다양한 실시예에서, 전자 장치는 플렉서블하거나, 또는 전술한 다양한 장치들 중 둘 이상의 조합일 수 있다. 본 문서의 실시예에 따른 전자 장치는 전술한 기기들에 한정되지 않는다. 본 문서에서, 사용자라는 용어는 전자 장치를 사용하는 사람 또는 전자 장치를 사용하는 장치(예: 인공지능 전자 장치)를 지칭할 수 있다.
이하, 첨부 도면을 참조하여, 다양한 실시 예에 따른 전자 장치가 설명된다. 본 문서에서, 사용자라는 용어는 전자 장치를 사용하는 사람 또는 전자 장치를 사용하는 장치 (예: 인공지능 전자 장치)를 지칭할 수 있다.
도 1은 본 발명의 일 실시 예에 따른 전자 장치의 동작 환경을 나타낸다.
도 1을 참조하면, 컨텐츠 제작자(10)는 웹 문서를 제작할 수 있다. 컨텐츠 제작자(10)에 의해 제작된 전자 문서(예: 웹 문서)는 서버(20)에 업로드될 수 있다. 웹 문서는 컨텐츠 제공 업체(CP: contents provider)에 의해 배포될 수도 있다. 일 실시 예에 따르면, 서버(20)는 웹 문서를 저장할 수 있다. 일 실시 예에 따르면, 전자 장치(100)는 머리 착용형 장치(200)(head-mounted device)에 장착될 수 있다. 전자 장치(100)는, 예를 들어, 웹 브라우저를 통해 웹 문서에 대응하는 URI(uniform resource identifier)가 입력된 경우 웹 문서를 서버(20)로부터 수신할 수 있다. 전자 장치(100)는 수신된 웹 문서를 디스플레이를 통해 출력될 수 있다. 예를 들어, 디스플레이를 통해 출력된 이미지는 머리 착용형 장치(200)에 포함된 렌즈 등을 통해 사용자에게 제공될 수 있다. 전자 장치(100)의 상세한 구성에 대해서는 도 2를 참조하여 상세히 설명한다. 머리 착용형 장치(200)를 통해 제공되는 예시적인 화면 구성은 도 4 내지 도 11을 참조하여 상세히 설명한다.
도 2는 본 발명의 일 실시 예에 따른 전자 장치의 구성을 나타내는 블록도이다.
도 2를 참조하면, 본 발명의 일 실시 예에 따른 전자 장치(100)는 커넥터(110), 디스플레이(120), 카메라(130), 통신 회로(140), 메모리(150) 및 프로세서(160)를 포함할 수 있다. 예를 들어, 전자 장치(100)는 머리 착용형 장치(200) 내에 장착될 수 있는 스마트 폰 등과 같은 장치일 수 있다. 도 2에서 전자 장치(100)가 머리 착용형 장치(200) 내에 장착되는 장치인 것으로 도시되었으나, 이에 제한되지 않고, 전자 장치(100)는 머리 착용형 전자 장치일 수도 있다. 또는, 전자 장치(100)는 머리 착용형 장치(200) 외에 VR(virtual reality) 환경을 지원할 수 있는 다양한 형태의 장치에 장착될 수도 있다. 전자 자치(100)는 머리 착용형 전자 장치 외에 VR 환경을 지원할 수 있는 다양한 형태의 전자 장치 중 하나일 수도 있다.
커넥터(110)는 머리 착용형 장치(200)와 전기적으로 연결되도록 구성될 수 있다. 커넥터(110)는, 예를 들어, 전자 장치(100)가 스마트 폰 등과 같은 모바일 디바이스인 경우 전자 장치(100)가 장착된 머리 착용형 장치(200)와 전기적으로 연결될 수 있다. 커넥터(110)는, 예를 들어, USB(universal serial bus) 포트 등과 같은 입출력 인터페이스일 수 있다.
일 실시 예에 따르면, 디스플레이(120)는 다시점 이미지로 제공되는 웹 브라우저(151)의 실행 화면을 출력할 수 있다. 다시점 이미지는 시점이 다양하게 변경될 수 있는 이미지일 수 있다. 예를 들어, 다시점 이미지는 전자 장치(100) 또는 머리 착용형 장치(200)에 의해 감지된 사용자의 움직임에 따라 시점이 변경될 수 있다. 다시점 이미지는, 예를 들어, 전방위 이미지, 360도 이미지, skydom 이미지, 6개의 이미지를 포함하는 skybox 이미지, 또는 12개의 이미지를 포함하는 stereo skybox 이미지 등과 같은 다양한 종류의 이미지 중 하나일 수 있다. 디스플레이(120)에 출력된 이미지는 전자 장치(100)와 연결된 머리 착용형 장치(200)의 렌즈 등을 통해 사용자에게 제공될 수도 있다.
디스플레이(120)는 머리 착용형 장치(200)의 좌측 렌즈에 대응하는 위치 및 머리 착용형 장치(200)의 우측 렌즈에 대응하는 위치에 이미지를 표시할 수 있다. 예를 들어, 디스플레이(120)는 스테레오 이미지 중 좌안 이미지를 좌측 렌즈에 대응하는 위치에 표시하고, 스테레오 이미지 중 우안 이미지를 우측 렌즈에 대응하는 위치에 표시할 수 있다. 다른 예를 들면, 디스플레이(120)는 일반 이미지를 좌측 렌즈에 대응하는 위치 및 우측 렌즈에 대응하는 위치에 표시할 수도 있다. 또 다른 예를 들면, 디스플레이(120)는 3차원 오브젝트를 스테레오 이미지로 가공하고, 가공된 스테레오 이미지 중 좌안 이미지를 좌측 렌즈에 대응하는 위치에 표시하고, 가공된 스테레오 이미지 중 우안 이미지를 우측 렌즈에 대응하는 위치에 표시할 수 있다.
일 실시 예에 따르면, 웹 브라우저(151)의 실행 화면은 컨텐츠를 표시하는 평면적 표시 영역인 제1 영역(문서 영역) 및 웹 브라우저(151)의 사용자 인터페이스를 표시하는 입체적 표시 영역인 제2 영역(또는, 크롬(chrome) 영역)을 포함할 수 있다. 예를 들어, 제1 영역은 통상적인 웹 문서에 포함된 컨텐츠를 표시할 수 있다. 제1 영역은 사각형 등의 평면적 표시 영역일 수 있다. 제1 영역은 웹 브라우저(151)의 실행 화면의 중앙부에 위치될 수 있다. 예를 들어, 제2 영역은 웹 브라우저(151)의 사용자 인터페이스를 표시할 수 있다. 제2 영역은 구형 또는 원통형 등의 입체적 표시 영역일 수 있다. 제2 영역은 사용자가 깊이를 인지할 수 있도록 구성될 수 있다. 제2 영역은 웹 브라우저(151)의 실행 화면 중 제1 영역을 제외한 나머지 영역일 수 있다. 일 실시 예에 따르면, 다시점 이미지로 표시되는 웹 브라우저(151)의 실행 화면은 통상적인 PC 또는 모바일 디바이스 등에 표시되는 웹 브라우저의 실행 화면에 비해 제2 영역의 면적이 넓을 수 있다. 예를 들어, 제2 영역의 면적은 제1 영역의 면적보다 넓을 수 있다.
카메라(130)는 정지 영상 및 동영상을 촬영할 수 있다. 카메라(130)는 카메라(130)의 화각(angle of view) 내에 들어온 피사체(subject)를 촬영할 수 있다.
통신 회로(140)는 서버(20)와 다양한 통신망을 통해 통신할 수 있다. 예를 들어, 통신 회로(140)는 셀룰러 모듈(예: 도 13의 셀룰러 모듈(1321)) 또는 Wi-Fi 모듈(예: 도 13의 Wi-Fi 모듈(1322))일 수 있다. 통신 회로(140)는 서버(20)로부터 웹 문서를 수신할 수 있다. 일 실시 예에 따르면, 수신된 웹 문서는 제1 영역과 연관된 제1 코드 및 제2 영역과 연관된 제2 코드를 포함할 수 있다. 예를 들어, 제1 코드는 제1 영역에 표시될 컨텐츠가 기술된 코드일 수 있다. 제2 코드는 제2 영역에 표시될 오브젝트(object)가 기술된 코드일 수 있다. 제1 코드는 통상적인 웹 문서들에 포함된 코드일 수 있고, 제2 코드는 본 발명의 일 실시 예에 따른 제2 영역에 오브젝트를 표시하기 위해 웹 문서에 삽입된 코드일 수 있다. 제2 코드는 웹 문서와 연결된 다른 파일(예: 자막 파일)에 삽입된 코드일 수도 있다. 제1 코드 및 제2 코드는 HTML(hypertext markup language)로 작성된 코드일 수 있다.
메모리(150)는 휘발성 메모리(150) 및 비휘발성 메모리(150)를 포함할 수 있다. 메모리(150)는 웹 브라우저(151)를 저장할 수 있다. 웹 브라우저(151)는 웹 문서를 파싱하는 파싱 모듈(152), 제1 코드를 실행하는 제1 실행 모듈(153) 및 제2 코드를 실행하는 제2 실행 모듈(154)을 포함할 수 있다. 메모리(150)에 저장된 웹 브라우저(151)는 프로세서(160)에 의해 실행될 수 있다.
프로세서(160)는 커넥터(110), 디스플레이(120), 카메라(130), 통신 회로(140) 및 메모리(150)와 전기적으로 연결될 수 있다.
일 실시 예에 따르면, 프로세서(160)는 제1 코드에 기초하여 제1 영역에 컨텐츠를 표시하고, 제2 코드에 기초하여 제2 영역에 상기 컨텐츠와 상호작용할 수 있는 오브젝트를 표시할 수 있다. 제1 영역에 표시되는 컨텐츠는 웹 문서에 포함된 주된 컨텐츠일 수 있다. 제1 영역에 표시되는 컨텐츠는 통상적인 웹 브라우저에 표시되는 웹 페이지일 수 있다. 제1 영역에 표시되는 컨텐츠는 텍스트, 이미지 및 비디오 등을 포함할 수 있다. 컨텐츠는 2차원 컨텐츠일 수도 있고 3차원 컨텐츠일 수도 있다. 제2 영역에 표시되는 오브젝트는, 예를 들어, 360도 이미지, skydom 이미지, skybox 이미지, 3D skybox 이미지 또는 비디오 클립 등일 수 있다. 다른 예를 들면, 오브젝트는 3차원 오브젝트일 수도 있다. 3차원 오브젝트는, 예를 들어, fbx, obj, declarative 3D format(예: x3d 등), 또는 imperative 3D format (예: webGL 또는 webVR 등) 등과 같은 다양한 형식으로 이루어질 수 있다.
일 실시 예에 따르면, 프로세서(160)는 웹 브라우저(151)의 파싱 모듈(152)을 이용하여 웹 문서를 파싱함으로써 제1 코드 및 제2 코드를 추출할 수 있다. 프로세서(160)는 제1 실행 모듈(153)을 이용하여 제1 코드를 실행함으로써 제1 영역에 컨텐츠를 표시할 수 있다. 프로세서(160)는 제2 실행 모듈(154)을 이용하여 제2 코드를 실행함으로써 제2 영역에 오브젝트를 표시할 수 있다. 제1 영역 및 제2 영역에 이미지가 표시된 예시적인 화면 구성에 대해서는 도 4 내지 도 11을 참조하여 상세히 설명한다.
일 실시 예에 따르면, 프로세서(160)는 제2 코드에 기초하여 전자 장치(100)와 연동된 외부 장치(30)를 제어할 수 있다. 외부 장치(30)는, 예를 들어, 조이스틱 또는 전동 의자 등과 같이 전자 장치(100)와 연동될 수 있는 다양한 장치일 수 있다. 프로세서(160)는 제2 코드에 진동에 대한 효과가 정의된 경우 외부 장치(30)가 진동하도록 제어 신호를 외부 장치(30)로 전달할 수 있다. 프로세서(160)는 통신 회로(140)(예: 도 13의 Wi-Fi 모듈(1322) 또는 블루투스 모듈(1323))를 이용하여 외부 장치(30)를 제어할 수 있다.
도 3은 본 발명의 일 실시 예에 따른 전자 장치의 웹 문서 출력 방법을 설명하기 위한 흐름도이다.
도 3에 도시된 흐름도는 도 2에 도시된 전자 장치(100)에서 처리되는 동작들을 도시할 수 있다. 따라서, 이하에서 생략된 내용이라 하더라도 도 2를 참조하여 전자 장치(100)에 관하여 기술된 내용은 도 3에 도시된 흐름도에도 적용될 수 있다.
도 3을 참조하면, 동작 310에서, 전자 장치(100)는 웹 브라우저를 실행할 수 있다. 전자 장치(100)는, 예를 들어, 전자 장치(100) 자체 또는 전자 장치(100)와 전기적으로 연결된 머리 착용형 장치에 의해 다시점 이미지를 제공할 수 있는 웹 브라우저를 실행할 수 있다.
동작 320에서, 전자 장치(100)는 웹 브라우저의 실행 화면을 다시점 이미지로 출력할 수 있다. 전자 장치(100)는 컨텐츠를 표시하는 평면적 표시 영역인 제1 영역 및 웹 브라우저의 사용자 인터페이스를 표시하는 입체적 표시 영역인 제2 영역을 포함하는 웹 브라우저의 실행 화면을 표시할 수 있다.
동작 330에서, 전자 장치(100)는 서버로부터 제1 영역과 연관된 제1 코드 및 제2 영역과 연관된 제2 코드를 포함하는 웹 문서를 수신할 수 있다. 전자 장치(100)는 수신된 웹 문서를 파싱함으로써 제1 코드 및 제2 코드를 추출할 수도 있다.
동작 340에서, 전자 장치(100)는 제1 코드에 기초하여 제1 영역에 컨텐츠를 표시할 수 있다.
동작 350에서, 전자 장치(100)는 제2 코드에 기초하여 제2 영역에 오브젝트를 표시할 수 있다. 예를 들어, 전자 장치는 제1 영역에 표시된 컨텐츠와 상호작용할 수 있는 오브젝트를 제2 영역에 표시할 수 있다. 제1 영역 및 제2 영역에 이미지가 표시된 예시적인 화면 구성에 대해서는 도 4 내지 도 11을 참조하여 상세히 설명한다.
도 4는 본 발명의 일 실시 예에 따른 전자 장치에 의해 출력된 예시적인 화면을 도시한다.
도 4를 참조하면, 전자 장치는 웹 브라우저의 실행 화면을 표시할 수 있다. 도 4에서는 웹 브라우저의 실행 화면이 원통형의 360도 이미지인 것으로 도시되었으나, 이에 제한되지 않고, 웹 브라우저의 실행 화면은 구형의 전방위 이미지 등과 같은 다양한 다시점 이미지일 수 있다. 웹 브라우저의 실행 화면은 컨텐츠를 표시하는 제1 영역(410) 및 사용자 인터페이스를 표시하는 제2 영역(420)을 포함할 수 있다. 전자 장치는 웹 브라우저를 통해 URI가 입력되면 URI에 대응하는 웹 문서를 서버로부터 수신할 수 있다. 전자 장치는 웹 문서에 포함된 제1 코드 및 제2 코드를 각각 실행함으로써 제1 영역(410) 및 제2 영역(420)에 이미지를 표시할 수 있다. 예를 들어, 제1 영역(410) 내에 웹 브라우저에 입력된 URI에 대응하는 웹 사이트의 홈 페이지가 표시될 수 있다. 또는, 제2 영역(420) 내에 웹 브라우저의 사용자 인터페이스 및 배경 이미지가 표시될 수 있다.
일 실시 예에 따르면, 전자 장치는 웹 문서에 포함된 제2 코드와 연관된 이미지를 제2 영역(420)의 배경으로서 제2 영역(420)에 표시할 수 있다. 전자 장치는 웹 문서에 포함된 제2 코드를 파싱할 수 있다. 전자 장치는 제2 코드에 기술된 이미지를 제2 영역(420)에 표시할 수 있다. 이미지는 전방위 이미지 등과 같은 다시점 이미지일 수 있다. 다시점 이미지를 제2 영역(420)의 배경으로서 표시하도록 하는 예시적인 제2 코드는 아래와 같을 수 있다.
[웹 문서의 코드]
<link id=“watch” async rel=“vr-background” href=“bg.jpg”>
여기서, href=”bg.jpg” 는 제2 영역(420)에 삽입되는 이미지를 의미하고, rel=”vr-background” 는 bg.jpg 를 제2 영역(420)의 배경으로 삽입한다는 것을 의미할 수 있다.
일 실시 예에 따르면, 전자 장치는 제1 영역(410)에 표시된 웹 페이지 내에서 이벤트가 발생되면 제2 영역(420)의 배경을 변경할 수 있다. 예를 들어, 전자 장치는 제1 영역(410)의 지정된 지점에 사용자의 입력이 인가되면 제2 영역(420)의 배경 이미지를 변경할 수 있다. 예컨대, 상술한 지정된 지점 및 배경 이미지는 제2 코드에 포함될 수 있다.
도 5는 본 발명의 일 실시 예에 따른 전자 장치에 의해 출력된 예시적인 화면을 도시한다.
도 5를 참조하면, 전자 장치는 제1 영역(510) 및 제2 영역(520)을 포함하는 웹 브라우저의 실행 화면을 표시할 수 있다. 웹 브라우저의 실행 화면은 다시점 이미지일 수 있다. 제2 영역(520)은 웹 브라우저의 실행 화면 중 제1 영역(510)을 제외한 나머지 영역으로서, 제1 영역(510)의 외부 영역일 수 있다.
일 실시 예에 따르면, 전자 장치는 제1 코드와 연관된 동영상을 제1 영역(510)에 표시할 수 있다. 전자 장치는 제1 영역(510)에 표시된 동영상과 연관된 자막 파일을 파싱함으로써 제2 코드를 추출할 수 있다. 자막 파일은, 예를 들어, vtt 표준 형식으로 이루어질 수 있다. 자막 파일에 대한 정보는 웹 문서에 제1 코드로서 기술될 수 있다. 전자 장치는 제2 코드와 연관된 오브젝트를 제2 영역(520)에 표시할 수 있다. 예를 들어, 전자 장치는 제2 코드에 기술된 이미지를 제2 영역(520)에 표시할 수 있다. 또는, 전자 장치는 제2 코드에 기술된 이미지를 제2 코드에 설정된 시간에 표시할 수도 있다. 예를 들어, 전자 장치는 7초부터 2분 32초까지의 구간 동안 제2 코드에 기술된 이미지를 제2 영역(520)에 표시할 수 있다. 설정된 시간에 제2 영역(520)에 이미지를 표시하도록 하는 예시적인 제1 코드 및 제2 코드는 아래와 같을 수 있다.
[웹 문서(index.html)의 코드]
<!doctype html>
<video controls autoplay src=”xmen.webm”>
<track default src=”xmen.vtt”>
</video>
[자막 파일(xmen.vtt)의 코드]
00:00:07.000 --> 00:02:32.000
<background src=”cloud.jpg”>
여기서, <track default src=”xmen.vtt”> 는 제1 영역(510)에 재생되는 동영상과 연관된 자막 파일을 의미하고, <background src=”cloud.jpg”> 는 제2 영역(520)에 삽입되는 이미지를 의미하고, 00:00:07.000 --> 00:02:32.000 은 cloud.jpg 가 제2 영역(520)에 표시되는 시간을 의미할 수 있다.
일 실시 예에 따르면, 전자 장치는 오브젝트를 제2 코드에 설정된 크기로 표시할 수 있다. 예를 들어, 전자 장치는 이미지의 폭이 제1 영역(510)의 폭의 120%가 되도록 이미지를 제2 영역(520)에 표시할 수 있다. 이미지를 설정된 크기로 제2 영역(520)에 표시하도록 하는 예시적인 제2 코드는 아래와 같을 수 있다.
[자막 파일(xmen.vtt)의 코드]
00:00:07.000 --> 00:02:32.000
<video src=”xmen_bg1.webm” style=”width:120%”>
여기서, 00:00:07.000 --> 00:02:32.000 은 이미지가 제2 영역(520)에 표시되는 시간을 의미하고, style=”width:120%” 는 제2 영역(520)에 표시되는 이미지의 폭과 제1 영역(510)의 폭의 비율을 의미한다.
일 실시 예에 따르면, 전자 장치는 이미지를 동영상의 컨트롤(예: 재생, 정지, 일시정지, 빨리감기 또는 되감기 등)에 따라 변경할 수도 있다. 예를 들어, 전자 장치는 재생 중인 경우 제1 이미지를 제2 영역(520)에 표시하고, 빨리 감기 중인 경우 제2 이미지를 제2 영역(520)에 표시할 수도 있다. 동영상의 컨트롤에 따른 이미지들과 관련된 정보는 제2 코드에 포함될 수 있다.
도 6은 본 발명의 일 실시 예에 따른 전자 장치에 의해 출력된 예시적인 화면을 도시한다.
도 6을 참조하면, 전자 장치는 제1 영역(610) 및 제2 영역(620)을 포함하는 웹 브라우저의 실행 화면을 표시할 수 있다. 웹 브라우저의 실행 화면은 다시점 이미지일 수 있다. 제2 영역(620)은 웹 브라우저의 실행 화면 중 제1 영역(610)을 제외한 나머지 영역으로서, 제1 영역(610)의 외부 영역일 수 있다.
도 6의 (a)를 참조하면, 전자 장치는 제1 영역(610)에 웹 페이지를 표시할 수 있고, 제2 영역(620)에 웹 브라우저의 사용자 인터페이스를 표시할 수 있다. 전자 장치는 제1 영역(610)에 제1 코드에 기술된 광고 이미지(611)를 표시할 수 있다.
도 6의 (b)를 참조하면, 전자 장치는 제1 영역(610)에 표시된 컨텐츠와 관련된 오브젝트(621)를 표시할 수 있다. 예를 들어, 전자 장치는 광고 이미지(611)에 대한 입력이 인가된 경우 광고 이미지(611)와 관련된 오브젝트(621)(예: 차량 형상의 3차원 오브젝트)를 표시할 수 있다. 전자 장치는 제2 코드에 기술된 오브젝트(621)를 제2 영역(620)에 표시할 수 있다. 오브젝트(621)의 일부는 제1 영역(610) 상에 표시될 수도 있다. 전자 장치는 오브젝트(621)가 제2 코드에 포함된 스크립트에 따라 움직이도록 오브젝트(621)를 표시할 수 있다. 예를 들어, 오브젝트(621)는 실행 화면의 우측 방향으로 움직이도록 표시될 수 있다. 전자 장치는 오브젝트(621)를 확대하거나 축소할 수도 있다.
도 6의 (c)를 참조하면, 전자 장치는 오브젝트(621)를 스크립트에 따라 이동시킨 후 정지시킬 수 있다. 전자 장치는 오브젝트(621)가 표시된 영역에 대한 사용자의 입력을 수신할 수 있다.
도 6의 (d)를 참조하면, 오브젝트(621)에 대한 사용자의 입력이 인가되면, 전자 장치는 오브젝트(621)를 확대하여 표시할 수 있다.
도 6의 (e)를 참조하면, 오브젝트(621)에 대한 사용자의 입력이 인가되면, 전자 장치는 오브젝트(621)를 확대한 후 화면을 전환할 수 있다. 전자 장치는 제1 영역(610)에 오브젝트(621)와 연관된 다른 컨텐츠를 표시하고, 제2 영역(620)에 오브젝트(621)와 연관된 다른 오브젝트를 표시할 수 있다. 예를 들어, 전자 장치는 오브젝트(621)의 정보를 표시하는 웹 페이지를 제1 영역(610)에 표시하고, 차량 내부 이미지를 제2 영역(620)에 표시할 수 있다. 오브젝트(621)와 연관된 다른 컨텐츠 및/또는 다른 오브젝트는, 예를 들어, 웹 문서에 포함된 제2 코드에 기술될 수도 있다. 다른 예를 들면, 오브젝트(621)와 연관된 다른 컨텐츠와 관련된 다른 웹 문서가 제2 코드에 기술되고, 다른 오브젝트는 다른 웹 문서의 제2 코드에 기술될 수도 있다. 상술한 동작을 수행하도록 하는 예시적인 제2 코드는 아래와 같다.
[웹 문서의 코드]
<link id=“car” async rel=“vr-object” href=“car.obj”>
<script>window. watch.onload = function() { /* control the obj */ };</script>
여기서, href=“car.obj” 는 제2 영역(620)에 삽입되는 오브젝트(621)를 의미하고, rel=“vr-object” 는 car.obj 를 제2 영역(620)에 오브젝트로 삽입한다는 것을 의미할 수 있다. <script>window. watch.onload = function() 은 오브젝트(621)을 움직이는 스크립트일 수 있다.
일 실시 예에 따르면, 전자 장치는 오브젝트(621)를 제2 코드에 설정된 시간에 표시할 수도 있다. 설정된 시간에 제2 영역(620)에 오브젝트(621)를 표시하도록 하는 예시적인 제2 코드는 아래와 같다.
[자막 파일의 코드]
00:00:07.000 --> 00:02:32.000
<object id=”car” src=”car.obj”>
여기서, src=”car.obj” 는 제2 영역(620)에 삽입되는 오브젝트(621)를 의미하고, object id=”car” 는 오브젝트(621)의 아이디를 의미하고, 00:00:07.000 --> 00:02:32.000 는 제2 영역에 car.obj 가 삽입되는 시간을 의미할 수 있다.
일 실시 예에 따르면, 전자 장치는 오브젝트(621)와 함께 제1 영역(610)에 표시된 웹 페이지의 일부를 제2 영역(620)에 표시할 수 있다. 예를 들어, 전자 장치는 오브젝트(621)의 주변에 차량과 관련된 정보를 포함하는 웹 페이지의 일부를 제2 영역(620)에 표시할 수 있다.
도 7은 본 발명의 일 실시 예에 따른 전자 장치에 의해 출력된 예시적인 화면을 도시한다.
도 7을 참조하면, 전자 장치는 제1 영역(710), 제2 영역(720), 제3 영역(730) 및 제4 영역(740)을 포함하는 웹 브라우저의 실행 화면을 표시할 수 있다. 제3 영역(730) 및 제4 영역(740) 각각은 제1 영역(710)과 동일한 타입의 영역일 수 있다. 예를 들어, 제3 영역(730) 및 제4 영역(740) 각각은 컨텐츠를 표시하는 평면적 표시 영역일 수 있다. 제3 영역(730)은 제1 영역(710)의 좌측과 인접하도록 배치될 수 있고, 제4 영역(740)은 제1 영역(710)의 우측과 인접하도록 배치될 수 있다.
일 실시 예에 따르면, 전자 장치는 제1 영역(710), 제3 영역(730) 및 제4 영역(740)에 컨텐츠를 표시할 수 있다. 제1 영역(710), 제3 영역(730) 및 제4 영역(740) 상에 사용자의 입력이 인가되면, 제1 영역(710), 제3 영역(730) 및 제4 영역(740)에 표시된 컨텐츠는 변경될 수 있다. 예를 들어, 좌측에서 우측으로 향하는 플리킹(flicking) 입력이 인가된 경우, 플리킹 입력 전에 제3 영역(730)에 표시된 컨텐츠가 제1 영역(710)에 표시되고, 플리킹 입력 전에 제1 영역(710)에 표시된 컨텐츠가 제4 영역(740)에 표시되고, 제3 영역(730)에는 다른 컨텐츠가 표시될 수 있다. 다른 예를 들면, 우측에서 좌측으로 향하는 플리킹 입력이 인가된 경우, 플리킹 입력 전에 제4 영역(740)에 표시된 컨텐츠가 제1 영역(710)에 표시되고, 플리킹 입력 전에 제1 영역(710)에 표시된 컨텐츠가 제3 영역(730)에 표시되고, 제4 영역(740)에는 다른 컨텐츠가 표시될 수 있다. 또한, 제2 영역(720)에 표시된 이미지는 플리킹 입력 후에 제1 영역(710)에 표시된 컨텐츠와 연관된 이미지로 변경될 수 있다.
도 8은 일 실시 예에 따른 전자 장치에 의해 출력된 예시적인 화면을 도시한다.
도 8을 참조하면, 전자 장치는 제1 영역(810) 및 제2 영역(820)을 포함하는 웹 브라우저의 실행 화면을 표시할 수 있다. 제2 영역(820)은 웹 브라우저의 실행 화면 중 제1 영역(810)을 제외한 나머지 영역으로서, 제1 영역(810)의 외부 영역일 수 있다.
일 실시 예에 따르면, 전자 장치는 제2 코드에 설정된 영역(811)에 입력이 인가되면, 제2 코드와 연관된 오브젝트(821)를 제2 영역(820)에 표시할 수 있다. 예를 들어, 전자 장치는 설정된 영역(811)에 입력이 인가되면, 설정된 영역(811)과 연관된 오브젝트(821)를 제2 영역(820)에 표시할 수 있다. 예를 들어, 전자 장치는 제1 영역(810)에 동영상을 표시할 수 있다. 전자 장치는 사용자가 제1 영역(810) 중 설정된 영역(811)을 응시하는 경우 설정된 영역과 연관된 오브젝트(821)를 표시할 수 있다. 제2 코드는 설정된 영역(811)과 연관된 정보를 표시하는 오브젝트(821) 에 대한 코드를 포함할 수 있다. 예를 들어, 전자 장치는 제1 영역(810)의 동영상 내의 특정 인물이 표시된 영역(811) 내의 지점(p)에 입력이 인가되면 특정 인물에 대한 정보를 포함하는 오브젝트(821)를 제2 영역(820)에 표시할 수 있다. 예컨대, 전자 장치는 오브젝트(821)를 미리 렌더링한 후 특정 인물이 표시된 영역(811)에 대한 입력이 인식되면 동영상과 함께 오브젝트(821)를 표시할 수 있다. 제2 영역(820)에 상술한 오브젝트(821)를 표시하도록 하는 예시적인 제1 코드 및 제2 코드는 아래와 같다.
[웹 문서(index.html)의 코드]
<div id=”wolverine_info”>
<img src=”~~”><p>Wolverine is a mutant>
[자막 파일(xmen.vtt)의 코드]
00:00:07.000 --> 00:00:09.000
<a id=”wolverine” coords=”23 53 536 343 634 343 43 53” href=”# wolverine_info”>
여기서, href=”# wolverine_info” 제2 영역(820)에 표시되는 오브젝트(821)를 의미하고, coords=”23 53 536 343 634 343 43 53” 은 설정된 영역(811)을 의미하고, id=”wolverine” 는 오브젝트(821)의 아이디를 의미하고, 00:00:07.000 --> 00:00:09.000 은 설정된 영역(811)에 대한 입력에 반응하여 오브젝트(821)가 표시될 수 있는 시간을 의미할 수 있다.
도 9는 본 발명의 일 실시 예에 따른 전자 장치에 의해 출력된 예시적인 화면을 도시한다.
도 9를 참조하면, 전자 장치는 제1 영역(910) 및 제2 영역(920)을 포함하는 웹 브라우저의 실행 화면을 표시할 수 있다. 제2 영역(920)은 웹 브라우저의 실행 화면 중 제1 영역(910)을 제외한 나머지 영역으로서, 제1 영역(910)의 외부 영역일 수 있다.
일 실시 예에 따르면, 전자 장치는 제1 영역(910)에 동영상을 표시하고, 제2 영역(920)에 배경 이미지를 표시할 수 있다. 예를 들어, 전자 장치는 제1 영역(910)에 영화를 재생하고, 제2 영역(920)에 영화관의 실내 이미지를 표시할 수 있다. 전자 장치는 제2 코드에 기초하여 제2 코드와 연관된 오브젝트와 함께 제2 영역(920)에 표시된 다른 오브젝트(921)를 변경할 수 있다. 예를 들어, 전자 장치는 제1 영역(910)에 표시된 컨텐츠에서 발생하는 물리적 효과에 대응하여 제2 영역에 표시된 오브젝트(921)를 제2 코드에 기반하여 표시된 위치, 각도 및 크기 등을 변경할 수 있다. 예를 들어, 전자 장치는 제2 영역(920)에 영화관 의자 형상의 오브젝트(921)를 표시할 수 있다. 의자 형상의 오브젝트(921)는 전자 장치에 저장된 오브젝트로서 동영상의 재생을 위해 수신된 웹 문서에 기술되지 않은 오브젝트일 수 있다. 전자 장치는 제1 영역에 표시된 컨텐츠에서 주변의 금속을 움직이는 물리적 효과가 발생되면, 제2 영역에 표시된 의자 형상의 오브젝트(921)가 부유하는 것처럼 보이는 효과를 제공할 수 있다. 제2 영역(920)에 표시된 상술한 오브젝트(921)를 변경하도록 하는 예시적인 제2 코드는 아래와 같다.
[자막 파일(xmen.vtt)의 코드]
00:00:07.000 --> 00:00:09.000
<effect type=levitative strength=30%>
여기서, effect type=levitative 는 오브젝트(921)에 적용되는 효과를 의미하고, strength=30% 는 효과가 적용되는 정도(level)를 의미하고, 00:00:07.000 --> 00:00:09.000 는 효과가 적용되는 시간을 의미할 수 있다.
일 실시 예에 따르면, 전자 장치는 제1 영역에 표시된 컨텐츠에서 발생하는 물리효과를 연결된 외부 전자 장치에 전달할 수 있다. 예를 들어, 전자 장치에 진동효과를 줄 수 있는 쇼파와 연결되어 있는 경우, 전자 장치의 제1 영역에 표시된 컨텐츠에서 지진이 발생하면, 지진이 발생한 신호를 쇼파에 전달하여 쇼파에서 진동이 발생하도록 할 수 있다.
일 실시 예에 따르면, 전자 장치의 제1 영역에 영화 예매 페이지가 표시된 경우, 제2 영역에 상영관 이미지를 표시할 수 있다. 전자 장치는 제1 영역에 표시된 좌석표 중 선택된 좌석에 기반하여, 상기 선택된 좌석의 위치에 기반하여 제1 영역 또는 제2 영역에 표시된 상영관 이미지를 변경하여 표시할 수 있다.
도 10은 본 발명의 일 실시 예에 따른 전자 장치에 의해 출력된 예시적인 화면을 도시한다.
도 10을 참조하면, 전자 장치는 제1 영역(1010) 및 제2 영역(1020)을 포함하는 웹 브라우저의 실행 화면을 표시할 수 있다. 제2 영역(1020)은 웹 브라우저의 실행 화면 중 제1 영역(1010)을 제외한 나머지 영역으로서, 제1 영역(1010)의 외부 영역일 수 있다.
일 실시 예에 따르면, 전자 장치는 제2 영역(1020)에 표시된 오브젝트(1021)에 대한 입력이 인가되면, 오브젝트(1021)가 표시되는 위치, 각도 또는 크기 등을 변경할 수 있다. 예를 들어, 전자 장치는 시계 형상의 오브젝트(1021)가 표시된 영역에 대한 클릭 또는 드래그 등의 입력이 인가되면, 오브젝트(1021)가 표시되는 크기를 변경할 수 있다. 다른 예를 들면, 전자 장치는 오브젝트(1021) 위에 표시된 버튼(1022)에 입력을 인가하면 오브젝트(1021)가 표시되는 위치, 각도 또는 크기 등을 변경할 수 있다.
도 11은 본 발명의 일 실시 예에 따른 전자 장치에 의해 출력된 예시적인 화면을 도시한다.
도 11을 참조하면, 전자 장치는 제1 영역(1110) 및 제2 영역(1120)을 포함하는 웹 브라우저의 실행 화면을 표시할 수 있다. 제2 영역(1120)은 웹 브라우저의 실행 화면 중 제1 영역(1110)을 제외한 나머지 영역으로서, 제1 영역(1110)의 외부 영역일 수 있다.
일 실시 예에 따르면, 전자 장치는 제1 영역(1110) 또는 제2 영역(1120)에 오브젝트(1121)를 표시할 수 있다. 전자 장치는 오브젝트(1121)를 카메라에 의해 촬영된 물체(1131) 및 오브젝트(1121)의 실제 크기와 비례하게 표시할 수 있다. 예를 들어, 전자 장치는 제1 영역(1110)에 배터리 형상의 3차원 오브젝트(1121)를 표시할 수 있다. 전자 장치는 카메라를 이용하여 사용자의 손(1131)을 촬영할 수 있다. 전자 장치는 배터리 형상의 3차원 오브젝트(1121)와 함께 촬영된 손(1131)을 표시할 수 있다. 전자 장치는 3차원 오브젝트(1121)가 나타내는 배터리 및 촬영된 손(1131)의 실제 크기와 비례하도록 3차원 오브젝트(1121) 및 촬영된 손(1131)을 제1 영역(1110) 또는 제2 영역(1120)에 표시할 수 있다. 사용자의 손(1131)의 크기는 전자 장치에 저장된 값일 수도 있고, 촬영된 이미지에 기반하여 산출된 값일 수도 있다. 3차원 오브젝트(1121)가 나타내는 배터리의 크기는 웹 문서에 저장된 값일 수 있다. 전자 장치는 사용자의 손(1131)의 크기와 배터리의 크기를 시각적으로 비교할 수 있도록 사용자의 손(1131) 및 배터리의 실제 크기를 반영하여 사용자의 손(1131) 및 배터리 형상의 3차원 오브젝트(1121)를 표시할 수 있다.
본 발명의 일 실시 예에 따른 VR(virtual reality) 환경을 지원하는 전자 장치는 웹 브라우저의 실행 화면을 출력하는 디스플레이, 디스플레이에 구성되거나 디스플레이와 별도로 구성되는 입력 장치, 인터넷과 무선 또는 유선으로 통신 채널을 형성하는 통신 회로, 통신 회로, 디스플레이 및 입력 장치와 전기적으로 연결된 프로세서, 및 웹 브라우저를 위한 프로그램 및 인스트럭션(instruction)을 저장하고, 프로세서와 전기적으로 연결된 메모리를 포함하고, 메모리는, 실행 시에, 프로세서가 디스플레이에 웹 브라우저를 표시하고, 컨텐츠를 표시하는 평면적 표시 영역인 제1 영역과 연관된 제1코드 및 웹 브라우저의 사용자 인터페이스를 표시하는 입체적 표시 영역인 제2 영역과 연관된 제2 코드를 포함하는 웹 문서를 통신 회로를 통해 수신하고, 제1 코드에 기초하여 제1 영역에 컨텐츠를 표시하고, 제2 코드에 기초하여 제2 영역에 컨텐츠와 상호작용 가능한 오브젝트를 표시하도록 하는 인스트럭션들(instructions)을 저장할 수 있다.
본 발명의 다른 특징에 따르면, 인스트럭션들은, 프로세서가, 제1 영역에 표시된 컨텐츠에 기반하여 제2 영역에 제2 코드에 기술된 이미지를 제2 영역의 배경으로 표시할 수 있다.
본 발명의 일 실시 예에 따른 전자 장치는 다시점 이미지로 제공되는 웹 브라우저의 실행 화면을 출력하는 디스플레이 -웹 브라우저의 실행 화면은 컨텐츠를 표시하는 평면적 표시 영역인 제1 영역 및 웹 브라우저의 사용자 인터페이스를 표시하는 입체적 표시 영역인 제2 영역을 포함함-, 서버로부터 제1 영역과 연관된 제1 코드 및 제2 영역과 연관된 제2 코드를 포함하는 웹 문서를 수신하는 통신 회로, 제1 코드에 기초하여 제1 영역에 컨텐츠를 표시하고, 제2 코드에 기초하여 제2 영역에 오브젝트를 표시하도록 설정된 프로세서를 포함할 수 있다.
본 발명의 다른 특징에 따르면, 제1 영역은 사각형의 표시 영역이고, 제2 영역은 구형 또는 원통형의 표시 영역일 수 있다.
본 발명의 또 다른 특징에 따르면, 웹 문서를 파싱하는 파싱 모듈, 제1 코드를 실행하는 제1 실행 모듈 및 제2 코드를 실행하는 제2 실행 모듈을 포함하는 웹 브라우저가 저장된 메모리를 더 포함하고, 프로세서는, 파싱 모듈을 이용하여 웹 문서를 파싱함으로써 제1 코드 및 제2 코드를 추출하고, 제1 실행 모듈을 이용하여 제1 영역에 컨텐츠를 표시하고, 제2 실행 모듈을 이용하여 제2 영역에 오브젝트를 표시하도록 설정될 수 있다.
본 발명의 또 다른 특징에 따르면, 프로세서는, 제2 코드와 연관된 이미지를 제2 영역에 표시하도록 설정될 수 있다.
본 발명의 또 다른 특징에 따르면, 프로세서는, 제1 코드와 연관된 동영상을 제1 영역에 표시하고, 제1 코드와 연관된 자막 파일을 파싱함으로써 제2 코드를 추출하고, 제2 코드와 연관된 오브젝트를 제2 영역에 표시하도록 설정될 수 있다.
본 발명의 또 다른 특징에 따르면, 프로세서는, 오브젝트를 제2 코드에 설정된 시간에 표시하도록 설정될 수 있다.
본 발명의 또 다른 특징에 따르면, 프로세서는, 오브젝트를 제2 코드에 설정된 크기로 표시하도록 설정될 수 있다.
본 발명의 또 다른 특징에 따르면, 프로세서는, 제2 코드에 포함된 스크립트에 따라 오브젝트를 변경하도록 설정될 수 있다.
본 발명의 또 다른 특징에 따르면, 프로세서는, 오브젝트에 대한 입력이 인가되면, 제1 영역에 오브젝트와 연관된 다른 컨텐츠를 표시하고, 제2 영역에 오브젝트와 연관된 다른 오브젝트를 표시하도록 설정될 수 있다.
본 발명의 또 다른 특징에 따르면, 프로세서는, 전자 장치의 사용자가 제2 코드에 설정된 영역을 응시하는 경우, 제2 코드와 연관된 오브젝트를 표시하도록 설정될 수 있다.
본 발명의 또 다른 특징에 따르면, 프로세서는, 제2 코드에 기초하여 제2 코드와 연관된 오브젝트와 함께 제2 영역에 표시된 다른 오브젝트를 변경하도록 설정될 수 있다.
본 발명의 또 다른 특징에 따르면, 프로세서는, 제2 코드에 기초하여 전자 장치와 연동된 외부 장치를 제어하도록 설정될 수 있다.
본 발명의 또 다른 특징에 따르면, 프로세서는, 오브젝트에 대한 입력이 인가되면, 오브젝트가 표시되는 위치, 각도 또는 크기를 변경하도록 설정될 수 있다.
본 발명의 또 다른 특징에 따르면, 프로세서와 전기적으로 연결된 카메라를 더 포함하고, 프로세서는, 오브젝트를 카메라에 의해 촬영된 물체와 함께 오브젝트 및 촬영된 물체의 실제 크기와 비례하게 표시하도록 설정될 수 있다.
본 발명의 일 실시 예에 따른 방법은 웹 브라우저를 실행하는 동작, 다시점 이미지로 제공되는 웹 브라우저의 실행 화면을 출력하는 동작 -웹 브라우저의 실행 화면은 컨텐츠를 표시하는 평면적 표시 영역인 제1 영역 및 웹 브라우저의 사용자 인터페이스를 표시하는 입체적 표시 영역인 제2 영역을 포함함-, 서버로부터 제1 영역과 연관된 제1 코드 및 제2 영역과 연관된 제2 코드를 포함하는 웹 문서를 수신하는 동작, 제1 코드에 기초하여 제1 영역에 컨텐츠를 표시하는 동작 및 제2 코드에 기초하여 제2 영역에 오브젝트를 표시하는 동작을 포함할 수 있다.
본 발명의 다른 특징에 따르면, 웹 문서를 파싱함으로써 제1 코드 및 제2 코드를 추출하는 동작을 더 포함할 수 있다.
본 발명의 또 다른 특징에 따르면, 제1 코드와 연관된 자막 파일을 파싱함으로써, 제2 코드를 추출하는 동작을 더 포함할 수 있다.
본 발명의 일 실시 예에 따른 컴퓨터 기록 매체는 적어도 하나의 프로세서 또는 디스플레이 구동 회로에 의해 실행되며 컴퓨터로 읽을 수 있는 명령어가 저장되고, 명령어는 웹 브라우저를 실행하는 동작, 다시점 이미지로 제공되는 웹 브라우저의 실행 화면을 출력하는 동작 -웹 브라우저의 실행 화면은 컨텐츠를 표시하는 평면적 표시 영역인 제1 영역 및 웹 브라우저의 사용자 인터페이스를 표시하는 입체적 표시 영역인 제2 영역을 포함함-, 서버로부터 제1 영역과 연관된 제1 코드 및 제2 영역과 연관된 제2 코드를 포함하는 웹 문서를 수신하는 동작, 제1 코드에 기초하여 제1 영역에 컨텐츠를 표시하는 동작 및 제2 코드에 기초하여 제2 영역에 오브젝트를 표시하는 동작을 수행하도록 설정될 수 있다.
도 12를 참조하여, 다양한 실시예에서의, 네트워크 환경(1200) 내의 전자 장치(1201)가 기재된다. 전자 장치(1201)는 버스(1210), 프로세서(1220), 메모리(1230), 입출력 인터페이스(1250), 디스플레이(1260), 및 통신 인터페이스(1270)를 포함할 수 있다. 어떤 실시예에서는, 전자 장치(1201)는, 구성요소들 중 적어도 하나를 생략하거나 다른 구성요소를 추가적으로 구비할 수 있다. 버스(1210)는 구성요소들(1210-1270)을 서로 연결하고, 구성요소들 간의 통신(예: 제어 메시지 또는 데이터)을 전달하는 회로를 포함할 수 있다. 프로세서(1220)는, 중앙처리장치, 어플리케이션 프로세서, 또는 커뮤니케이션 프로세서(communication processor(CP)) 중 하나 또는 그 이상을 포함할 수 있다. 프로세서(1220)는, 예를 들면, 전자 장치(1201)의 적어도 하나의 다른 구성요소들의 제어 및/또는 통신에 관한 연산이나 데이터 처리를 실행할 수 있다.
메모리(1230)는, 휘발성 및/또는 비휘발성 메모리를 포함할 수 있다. 메모리(1230)는, 예를 들면, 전자 장치(1201)의 적어도 하나의 다른 구성요소에 관계된 명령 또는 데이터를 저장할 수 있다. 한 실시예에 따르면, 메모리(1230)는 소프트웨어 및/또는 프로그램(1240)을 저장할 수 있다. 프로그램(1240)은, 예를 들면, 커널(1241), 미들웨어(1243), 어플리케이션 프로그래밍 인터페이스(API)(1245), 및/또는 어플리케이션 프로그램(또는 "어플리케이션")(1247) 등을 포함할 수 있다. 커널(1241), 미들웨어(1243), 또는 API(1245)의 적어도 일부는, 운영 시스템으로 지칭될 수 있다. 커널(1241)은, 예를 들면, 다른 프로그램들(예: 미들웨어(1243), API(1245), 또는 어플리케이션 프로그램(1247))에 구현된 동작 또는 기능을 실행하는 데 사용되는 시스템 리소스들(예: 버스(1210), 프로세서(1220), 또는 메모리(1230) 등)을 제어 또는 관리할 수 있다. 또한, 커널(1241)은 미들웨어(1243), API(1245), 또는 어플리케이션 프로그램(1247)에서 전자 장치(1201)의 개별 구성요소에 접근함으로써, 시스템 리소스들을 제어 또는 관리할 수 있는 인터페이스를 제공할 수 있다.
미들웨어(1243)는, 예를 들면, API(1245) 또는 어플리케이션 프로그램(1247)이 커널(1241)과 통신하여 데이터를 주고받을 수 있도록 중개 역할을 수행할 수 있다. 또한, 미들웨어(1243)는 어플리케이션 프로그램(1247)으로부터 수신된 하나 이상의 작업 요청들을 우선 순위에 따라 처리할 수 있다. 예를 들면, 미들웨어(1243)는 어플리케이션 프로그램(1247) 중 적어도 하나에 전자 장치(1201)의 시스템 리소스(예: 버스(1210), 프로세서(1220), 또는 메모리(1230) 등)를 사용할 수 있는 우선 순위를 부여하고, 상기 하나 이상의 작업 요청들을 처리할 수 있다. API(1245)는 어플리케이션(1247)이 커널(1241) 또는 미들웨어(1243)에서 제공되는 기능을 제어하기 위한 인터페이스로, 예를 들면, 파일 제어, 창 제어, 영상 처리, 또는 문자 제어 등을 위한 적어도 하나의 인터페이스 또는 함수(예: 명령어)를 포함할 수 있다. 입출력 인터페이스(1250)는, 예를 들면, 사용자 또는 다른 외부 기기로부터 입력된 명령 또는 데이터를 전자 장치(1201)의 다른 구성요소(들)에 전달하거나, 또는 전자 장치(1201)의 다른 구성요소(들)로부터 수신된 명령 또는 데이터를 사용자 또는 다른 외부 기기로 출력할 수 있다.
디스플레이(1260)는, 예를 들면, 액정 디스플레이(LCD), 발광 다이오드(LED) 디스플레이, 유기 발광 다이오드(OLED) 디스플레이, 또는 마이크로 전자기계 시스템 (MEMS) 디스플레이, 또는 전자종이(electronic paper) 디스플레이를 포함할 수 있다. 디스플레이(1260)는, 예를 들면, 사용자에게 각종 콘텐츠(예: 텍스트, 이미지, 비디오, 아이콘, 및/또는 심볼 등)을 표시할 수 있다. 디스플레이(1260)는, 터치 스크린을 포함할 수 있으며, 예를 들면, 전자 펜 또는 사용자의 신체의 일부를 이용한 터치, 제스쳐, 근접, 또는 호버링 입력을 수신할 수 있다. 통신 인터페이스(1270)는, 예를 들면, 전자 장치(1201)와 외부 장치(예: 제 12 외부 전자 장치(1202), 제 13 외부 전자 장치(1204), 또는 서버(1206)) 간의 통신을 설정할 수 있다. 예를 들면, 통신 인터페이스(1270)는 무선 통신 또는 유선 통신을 통해서 네트워크(1262)에 연결되어 외부 장치(예: 제 13 외부 전자 장치(1204) 또는 서버(1206))와 통신할 수 있다.
무선 통신은, 예를 들면, LTE, LTE-A(LTE Advance), CDMA(code division multiple access), WCDMA(wideband CDMA), UMTS(universal mobile telecommunications system), WiBro(Wireless Broadband), 또는 GSM(Global System for Mobile Communications) 등 중 적어도 하나를 사용하는 셀룰러 통신을 포함할 수 있다. 한 실시예에 따르면, 무선 통신은, 예를 들면, WiFi(wireless fidelity), 블루투스, 블루투스 저전력(BLE), 지그비(Zigbee), NFC(near field communication), 자력 시큐어 트랜스미션(Magnetic Secure Transmission), 라디오 프리퀀시(RF), 또는 보디 에어리어 네트워크(BAN) 중 적어도 하나를 포함할 수 있다. 한실시예에 따르면, 무선 통신은 GNSS를 포함할 수 있다. GNSS는, 예를 들면, GPS(Global Positioning System), Glonass(Global Navigation Satellite System), Beidou Navigation Satellite System(이하 "Beidou") 또는 Galileo, the European global satellite-based navigation system일 수 있다. 이하, 본 문서에서는, "GPS"는 "GNSS"와 상호 호환적으로 사용될 수 있다. 유선 통신은, 예를 들면, USB(universal serial bus), HDMI(high definition multimedia interface), RS-232(recommended standard232), 전력선 통신, 또는 POTS(plain old telephone service) 등 중 적어도 하나를 포함할 수 있다. 네트워크(1262)는 텔레커뮤니케이션 네트워크, 예를 들면, 컴퓨터 네트워크(예: LAN 또는 WAN), 인터넷, 또는 텔레폰 네트워크 중 적어도 하나를 포함할 수 있다.
제 12 및 제 13 외부 전자 장치(1202, 1204) 각각은 전자 장치(1201)와 동일한 또는 다른 종류의 장치일 수 있다. 다양한 실시예에 따르면, 전자 장치(1201)에서 실행되는 동작들의 전부 또는 일부는 다른 하나 또는 복수의 전자 장치(예: 전자 장치(1202,104), 또는 서버(1206)에서 실행될 수 있다. 한 실시예에 따르면, 전자 장치(1201)가 어떤 기능이나 서비스를 자동으로 또는 요청에 의하여 수행해야 할 경우에, 전자 장치(1201)는 기능 또는 서비스를 자체적으로 실행시키는 대신에 또는 추가적으로, 그와 연관된 적어도 일부 기능을 다른 장치(예: 전자 장치(1202, 1204), 또는 서버(1206))에게 요청할 수 있다. 다른 전자 장치(예: 전자 장치(1202, 1204), 또는 서버(1206))는 요청된 기능 또는 추가 기능을 실행하고, 그 결과를 전자 장치(1201)로 전달할 수 있다. 전자 장치(1201)는 수신된 결과를 그대로 또는 추가적으로 처리하여 요청된 기능이나 서비스를 제공할 수 있다. 이를 위하여, 예를 들면, 클라우드 컴퓨팅, 분산 컴퓨팅, 또는 클라이언트-서버 컴퓨팅 기술이 이용될 수 있다.
도 13은 다양한 실시예에 따른 전자 장치(1301)의 블록도이다. 전자 장치(1301)는, 예를 들면, 도 12에 도시된 전자 장치(1201)의 전체 또는 일부를 포함할 수 있다. 전자 장치(1301)는 하나 이상의 프로세서(예: AP)(1310), 통신 모듈(1320), (가입자 식별 모듈(1324), 메모리(1330), 센서 모듈(1340), 입력 장치(1350), 디스플레이(1360), 인터페이스(1370), 오디오 모듈(1380), 카메라 모듈(1391), 전력 관리 모듈(1395), 배터리(1396), 인디케이터(1397), 및 모터(1398) 를 포함할 수 있다. 프로세서(1310)는, 예를 들면, 운영 체제 또는 응용 프로그램을 구동하여 프로세서(1310)에 연결된 다수의 하드웨어 또는 소프트웨어 구성요소들을 제어할 수 있고, 각종 데이터 처리 및 연산을 수행할 수 있다. 프로세서(1310)는, 예를 들면, SoC(system on chip) 로 구현될 수 있다. 한 실시예에 따르면, 프로세서(1310)는 GPU(graphic processing unit) 및/또는 이미지 신호 프로세서를 더 포함할 수 있다. 프로세서(1310)는 도 13에 도시된 구성요소들 중 적어도 일부(예: 셀룰러 모듈(1321))를 포함할 수도 있다. 프로세서(1310) 는 다른 구성요소들(예: 비휘발성 메모리) 중 적어도 하나로부터 수신된 명령 또는 데이터를 휘발성 메모리에 로드)하여 처리하고, 결과 데이터를 비휘발성 메모리에 저장할 수 있다.
통신 모듈(1320)(예: 통신 인터페이스(1270))와 동일 또는 유사한 구성을 가질 수 있다. 통신 모듈(1320)은, 예를 들면, 셀룰러 모듈(1321), WiFi 모듈(1323), 블루투스 모듈(1325), GNSS 모듈(1327), NFC 모듈(1328) 및 RF 모듈(1329)를 포함할 수 있다. 셀룰러 모듈(1321)은, 예를 들면, 통신망을 통해서 음성 통화, 영상 통화, 문자 서비스, 또는 인터넷 서비스 등을 제공할 수 있다. 한 실시예에 따르면, 셀룰러 모듈(1321)은 가입자 식별 모듈(예: SIM 카드)(1324)을 이용하여 통신 네트워크 내에서 전자 장치(1301)의 구별 및 인증을 수행할 수 있다. 한 실시예에 따르면, 셀룰러 모듈(1321)은 프로세서(1310)가 제공할 수 있는 기능 중 적어도 일부 기능을 수행할 수 있다. 한 실시예에 따르면, 셀룰러 모듈(1321)은 커뮤니케이션 프로세서(CP)를 포함할 수 있다. 어떤 실시예에 따르면, 셀룰러 모듈(1321), WiFi 모듈(1323), 블루투스 모듈(1325), GNSS 모듈(1327) 또는 NFC 모듈(1328) 중 적어도 일부(예: 두 개 이상)는 하나의 integrated chip(IC) 또는 IC 패키지 내에 포함될 수 있다. RF 모듈(1329)은, 예를 들면, 통신 신호(예: RF 신호)를 송수신할 수 있다. RF 모듈(1329)은, 예를 들면, 트랜시버, PAM(power amp module), 주파수 필터, LNA(low noise amplifier), 또는 안테나 등을 포함할 수 있다. 다른 실시예에 따르면, 셀룰러 모듈(1321), WiFi 모듈(1323), 블루투스 모듈(1325), GNSS 모듈(1327) 또는 NFC 모듈(1328) 중 적어도 하나는 별개의 RF 모듈을 통하여 RF 신호를 송수신할 수 있다. 가입자 식별 모듈(1324)은, 예를 들면, 가입자 식별 모듈을 포함하는 카드 또는 임베디드 SIM을 포함할 수 있으며, 고유한 식별 정보(예: ICCID(integrated circuit card identifier)) 또는 가입자 정보(예: IMSI(international mobile subscriber identity))를 포함할 수 있다.
메모리(1330)(예: 메모리(1230))는, 예를 들면, 내장 메모리(1332) 또는 외장 메모리(1334)를 포함할 수 있다. 내장 메모리(1332)는, 예를 들면, 휘발성 메모리(예: DRAM, SRAM, 또는 SDRAM 등), 비휘발성 메모리(예: OTPROM(one time programmable ROM), PROM, EPROM, EEPROM, mask ROM, flash ROM, 플래시 메모리, 하드 드라이브, 또는 솔리드 스테이트 드라이브 (SSD) 중 적어도 하나를 포함할 수 있다. 외장 메모리(1334)는 플래시 드라이브(flash drive), 예를 들면, CF(compact flash), SD(secure digital), Micro-SD, Mini-SD, xD(extreme digital), MMC(multi-media card) 또는 메모리 스틱 등을 포함할 수 있다. 외장 메모리(1334)는 다양한 인터페이스를 통하여 전자 장치(1301)와 기능적으로 또는 물리적으로 연결될 수 있다.
센서 모듈(1340)은, 예를 들면, 물리량을 계측하거나 전자 장치(1301)의 작동 상태를 감지하여, 계측 또는 감지된 정보를 전기 신호로 변환할 수 있다. 센서 모듈(1340)은, 예를 들면, 제스처 센서(1340A), 자이로 센서(1340B), 기압 센서(1340C), 마그네틱 센서(1340D), 가속도 센서(1340E), 그립 센서(1340F), 근접 센서(1340G), 컬러(color) 센서(1340H)(예: RGB(red, green, blue) 센서), 생체 센서(1340I), 온/습도 센서(1340J), 조도 센서(1340K), 또는 UV(ultra violet) 센서(1340M) 중의 적어도 하나를 포함할 수 있다. 추가적으로 또는 대체적으로, 센서 모듈(1340)은, 예를 들면, 후각(e-nose) 센서, 일렉트로마이오그라피(EMG) 센서, 일렉트로엔씨팔로그램(EEG) 센서, 일렉트로카디오그램(ECG) 센서, IR(infrared) 센서, 홍채 센서 및/또는 지문 센서를 포함할 수 있다. 센서 모듈(1340)은 그 안에 속한 적어도 하나 이상의 센서들을 제어하기 위한 제어 회로를 더 포함할 수 있다. 어떤 실시예에서는, 전자 장치(1301)는 프로세서(1310)의 일부로서 또는 별도로, 센서 모듈(1340)을 제어하도록 구성된 프로세서를 더 포함하여, 프로세서(1310)가 슬립(sleep) 상태에 있는 동안, 센서 모듈(1340)을 제어할 수 있다.
입력 장치(1350)는, 예를 들면, 터치 패널(1352), (디지털) 펜 센서(1354), 키(1356), 또는 초음파 입력 장치(1358)를 포함할 수 있다. 터치 패널(1352)은, 예를 들면, 정전식, 감압식, 적외선 방식, 또는 초음파 방식 중 적어도 하나의 방식을 사용할 수 있다. 또한, 터치 패널(1352)은 제어 회로를 더 포함할 수도 있다. 터치 패널(1352)은 택타일 레이어(tactile layer)를 더 포함하여, 사용자에게 촉각 반응을 제공할 수 있다. (디지털) 펜 센서(1354)는, 예를 들면, 터치 패널의 일부이거나, 별도의 인식용 쉬트를 포함할 수 있다. 키(1356)는, 예를 들면, 물리적인 버튼, 광학식 키, 또는 키패드를 포함할 수 있다. 초음파 입력 장치(1358)는 마이크(예: 마이크(1388))를 통해, 입력 도구에서 발생된 초음파를 감지하여, 상기 감지된 초음파에 대응하는 데이터를 확인할 수 있다.
디스플레이(1360)(예: 디스플레이(1260))는 패널(1362), 홀로그램 장치(1364), 프로젝터(1366), 및/또는 이들을 제어하기 위한 제어 회로를 포함할 수 있다. 패널(1362)은, 예를 들면, 유연하게, 투명하게, 또는 착용할 수 있게 구현될 수 있다. 패널(1362)은 터치 패널(1352)과 하나 이상의 모듈로 구성될 수 있다. 한 실시예에 따르면, 패널(1362)은 사용자의 터치에 대한 압력의 세기를 측정할 수 있는 압력 센서(또는 포스 센서)를 포함할 수 있다. 상기 압력 센서는 터치 패널(1352)과 일체형으로 구현되거나, 또는 터치 패널(1352)과는 별도의 하나 이상의 센서로 구현될 수 있다. 홀로그램 장치(1364)는 빛의 간섭을 이용하여 입체 영상을 허공에 보여줄 수 있다. 프로젝터(1366)는 스크린에 빛을 투사하여 영상을 표시할 수 있다. 스크린은, 예를 들면, 전자 장치(1301)의 내부 또는 외부에 위치할 수 있다. 인터페이스(1370)는, 예를 들면, HDMI(1372), USB(1374), 광 인터페이스(optical interface)(1376), 또는 D-sub(D-subminiature)(1378)를 포함할 수 있다. 인터페이스(1370)는, 예를 들면, 도 12에 도시된 통신 인터페이스(1270)에 포함될 수 있다. 추가적으로 또는 대체적으로, 인터페이스(1370)는, 예를 들면, MHL(mobile high-definition link) 인터페이스, SD카드/MMC(multi-media card) 인터페이스, 또는 IrDA(infrared data association) 규격 인터페이스를 포함할 수 있다.
오디오 모듈(1380)은, 예를 들면, 소리와 전기 신호를 쌍방향으로 변환시킬 수 있다. 오디오 모듈(1380)의 적어도 일부 구성요소는, 예를 들면, 도 12 에 도시된 입출력 인터페이스(1245)에 포함될 수 있다. 오디오 모듈(1380)은, 예를 들면, 스피커(1382), 리시버(1384), 이어폰(1386), 또는 마이크(1388) 등을 통해 입력 또는 출력되는 소리 정보를 처리할 수 있다. 카메라 모듈(1391)은, 예를 들면, 정지 영상 및 동영상을 촬영할 수 있는 장치로서, 한 실시예에 따르면, 하나 이상의 이미지 센서(예: 전면 센서 또는 후면 센서), 렌즈, 이미지 시그널 프로세서(ISP), 또는 플래시(예: LED 또는 xenon lamp 등)를 포함할 수 있다. 전력 관리 모듈(1395)은, 예를 들면, 전자 장치(1301)의 전력을 관리할 수 있다. 한 실시예에 따르면, 전력 관리 모듈(1395)은 PMIC(power management integrated circuit), 충전 IC, 또는 배터리 또는 연료 게이지를 포함할 수 있다. PMIC는, 유선 및/또는 무선 충전 방식을 가질 수 있다. 무선 충전 방식은, 예를 들면, 자기공명 방식, 자기유도 방식 또는 전자기파 방식 등을 포함하며, 무선 충전을 위한 부가적인 회로, 예를 들면, 코일 루프, 공진 회로, 또는 정류기 등을 더 포함할 수 있다. 배터리 게이지는, 예를 들면, 배터리(1396)의 잔량, 충전 중 전압, 전류, 또는 온도를 측정할 수 있다. 배터리(1396)는, 예를 들면, 충전식 전지 및/또는 태양 전지를 포함할 수 있다.
인디케이터(1397)는 전자 장치(1301) 또는 그 일부(예: 프로세서(1310))의 특정 상태, 예를 들면, 부팅 상태, 메시지 상태 또는 충전 상태 등을 표시할 수 있다. 모터(1398)는 전기적 신호를 기계적 진동으로 변환할 수 있고, 진동, 또는 햅틱 효과 등을 발생시킬 수 있다. 전자 장치(1301)는, 예를 들면, DMB(digital multimedia broadcasting), DVB(digital video broadcasting), 또는 미디어플로(mediaFloTM) 등의 규격에 따른 미디어 데이터를 처리할 수 있는 모바일 TV 지원 장치(예: GPU)를 포함할 수 있다. 본 문서에서 기술된 구성요소들 각각은 하나 또는 그 이상의 부품(component)으로 구성될 수 있으며, 해당 구성요소의 명칭은 전자 장치의 종류에 따라서 달라질 수 있다. 다양한 실시예에서, 전자 장치(예: 전자 장치(1301))는 일부 구성요소가 생략되거나, 추가적인 구성요소를 더 포함하거나, 또는, 구성요소들 중 일부가 결합되어 하나의 개체로 구성되되, 결합 이전의 해당 구성요소들의 기능을 동일하게 수행할 수 있다.
도 14는 다양한 실시예에 따른 프로그램 모듈의 블록도이다. 한 실시예에 따르면, 프로그램 모듈(1410)(예: 프로그램(1240))은 전자 장치(예: 전자 장치(1201))에 관련된 자원을 제어하는 운영 체제 및/또는 운영 체제 상에서 구동되는 다양한 어플리케이션(예: 어플리케이션 프로그램(1247))을 포함할 수 있다. 운영 체제는, 예를 들면, AndroidTM, iOSTM, WindowsTM, SymbianTM, TizenTM, 또는 BadaTM를 포함할 수 있다. 도 14를 참조하면, 프로그램 모듈(1410)은 커널(1420)(예: 커널(1241)), 미들웨어(1430)(예: 미들웨어(1243)), (API(1460)(예: API(1245)), 및/또는 어플리케이션(1470)(예: 어플리케이션 프로그램(1247))을 포함할 수 있다. 프로그램 모듈(1410)의 적어도 일부는 전자 장치 상에 프리로드 되거나, 외부 전자 장치(예: 전자 장치(1202, 1204), 서버(1206) 등)로부터 다운로드 가능하다.
커널(1420)은, 예를 들면, 시스템 리소스 매니저(1421) 및/또는 디바이스 드라이버(1423)를 포함할 수 있다. 시스템 리소스 매니저(1421)는 시스템 리소스의 제어, 할당, 또는 회수를 수행할 수 있다. 한 실시예에 따르면, 시스템 리소스 매니저(1421)는 프로세스 관리부, 메모리 관리부, 또는 파일 시스템 관리부를 포함할 수 있다. 디바이스 드라이버(1423)는, 예를 들면, 디스플레이 드라이버, 카메라 드라이버, 블루투스 드라이버, 공유 메모리 드라이버, USB 드라이버, 키패드 드라이버, WiFi 드라이버, 오디오 드라이버, 또는 IPC(inter-process communication) 드라이버를 포함할 수 있다. 미들웨어(1430)는, 예를 들면, 어플리케이션(1470)이 공통적으로 필요로 하는 기능을 제공하거나, 어플리케이션(1470)이 전자 장치 내부의 제한된 시스템 자원을 사용할 수 있도록 API(1460)를 통해 다양한 기능들을 어플리케이션(1470)으로 제공할 수 있다. 한 실시예에 따르면, 미들웨어(1430) 는 런타임 라이브러리(1435), 어플리케이션 매니저(1441), 윈도우 매니저(1442), 멀티미디어 매니저(1443), 리소스 매니저(1444), 파워 매니저(1445), 데이터베이스 매니저(1446), 패키지 매니저(1447), 커넥티비티 매니저(1448), 노티피케이션 매니저(1449), 로케이션 매니저(1450), 그래픽 매니저(1451), 또는 시큐리티 매니저(1452) 중 적어도 하나를 포함할 수 있다.
런타임 라이브러리(1435)는, 예를 들면, 어플리케이션(1470)이 실행되는 동안에 프로그래밍 언어를 통해 새로운 기능을 추가하기 위해 컴파일러가 사용하는 라이브러리 모듈을 포함할 수 있다. 런타임 라이브러리(1435)는 입출력 관리, 메모리 관리, 또는 산술 함수 처리를 수행할 수 있다. 어플리케이션 매니저(1441)는, 예를 들면, 어플리케이션(1470)의 생명 주기를 관리할 수 있다. 윈도우 매니저(1442)는 화면에서 사용되는 GUI 자원을 관리할 수 있다. 멀티미디어 매니저(1443)는 미디어 파일들의 재생에 필요한 포맷을 파악하고, 해당 포맷에 맞는 코덱을 이용하여 미디어 파일의 인코딩 또는 디코딩을 수행할 수 있다. 리소스 매니저(1444)는 어플리케이션(1470)의 소스 코드 또는 메모리의 공간을 관리할 수 있다. 파워 매니저(1445)는, 예를 들면, 배터리의 용량 또는 전원을 관리하고, 전자 장치의 동작에 필요한 전력 정보를 제공할 수 있다. 한 실시예에 따르면, 파워 매니저(1445)는 바이오스(BIOS: basic input/output system)와 연동할 수 있다. 데이터베이스 매니저(1446)는, 예를 들면, 어플리케이션(1470)에서 사용될 데이터베이스를 생성, 검색, 또는 변경할 수 있다. 패키지 매니저(1447)는 패키지 파일의 형태로 배포되는 어플리케이션의 설치 또는 갱신을 관리할 수 있다.
커넥티비티 매니저(1448)는, 예를 들면, 무선 연결을 관리할 수 있다. 노티피케이션 매니저(1449)는, 예를 들면, 도착 메시지, 약속, 근접성 알림 등의 이벤트를 사용자에게 제공할 수 있다. 로케이션 매니저(1450)는, 예를 들면, 전자 장치의 위치 정보를 관리할 수 있다. 그래픽 매니저(1451)는, 예를 들면, 사용자에게 제공될 그래픽 효과 또는 이와 관련된 사용자 인터페이스를 관리할 수 있다. 보안 매니저(1452)는, 예를 들면, 시스템 보안 또는 사용자 인증을 제공할 수 있다. 한 실시예에 따르면, 미들웨어(1430)는 전자 장치의 음성 또는 영상 통화 기능을 관리하기 위한 통화(telephony) 매니저 또는 전술된 구성요소들의 기능들의 조합을 형성할 수 있는 하는 미들웨어 모듈을 포함할 수 있다. 한 실시예에 따르면, 미들웨어(1430)는 운영 체제의 종류 별로 특화된 모듈을 제공할 수 있다. 미들웨어(1430)는 동적으로 기존의 구성요소를 일부 삭제하거나 새로운 구성요소들을 추가할 수 있다. API(1460)는, 예를 들면, API 프로그래밍 함수들의 집합으로, 운영 체제에 따라 다른 구성으로 제공될 수 있다. 예를 들면, 안드로이드 또는 iOS의 경우, 플랫폼 별로 하나의 API 셋을 제공할 수 있으며, 타이젠의 경우, 플랫폼 별로 두 개 이상의 API 셋을 제공할 수 있다.
어플리케이션(1470)은, 예를 들면, 홈(1471), 다이얼러(1472), SMS/MMS(1473), IM(instant message)(1474), 브라우저(1475), 카메라(1476), 알람(1477), 컨택트(1478), 음성 다이얼(1479), 이메일(1480), 달력(1481), 미디어 플레이어(1482), 앨범(1483), 와치(1484), 헬스 케어(예: 운동량 또는 혈당 등을 측정), 또는 환경 정보(예: 기압, 습도, 또는 온도 정보) 제공 어플리케이션을 포함할 수 있다. 한 실시예에 따르면, 어플리케이션(1470)은 전자 장치와 외부 전자 장치 사이의 정보 교환을 지원할 수 있는 정보 교환 어플리케이션을 포함할 수 있다. 정보 교환 어플리케이션은, 예를 들면, 외부 전자 장치에 특정 정보를 전달하기 위한 노티피케이션 릴레이 어플리케이션, 또는 외부 전자 장치를 관리하기 위한 장치 관리 어플리케이션을 포함할 수 있다. 예를 들면, 알림 전달 어플리케이션은 전자 장치의 다른 어플리케이션에서 발생된 알림 정보를 외부 전자 장치로 전달하거나, 또는 외부 전자 장치로부터 알림 정보를 수신하여 사용자에게 제공할 수 있다. 장치 관리 어플리케이션은, 예를 들면, 전자 장치와 통신하는 외부 전자 장치의 기능(예: 외부 전자 장치 자체(또는, 일부 구성 부품)의 턴-온/턴-오프 또는 디스플레이의 밝기(또는, 해상도) 조절), 또는 외부 전자 장치에서 동작하는 어플리케이션을 설치, 삭제, 또는 갱신할 수 있다. 한 실시예에 따르면, 어플리케이션(1470)은 외부 전자 장치의 속성에 따라 지정된 어플리케이션(예: 모바일 의료 기기의 건강 관리 어플리케이션)을 포함할 수 있다. 한 실시예에 따르면, 어플리케이션(1470)은 외부 전자 장치로부터 수신된 어플리케이션을 포함할 수 있다. 프로그램 모듈(1410)의 적어도 일부는 소프트웨어, 펌웨어, 하드웨어(예: 프로세서(1310)), 또는 이들 중 적어도 둘 이상의 조합으로 구현(예: 실행)될 수 있으며, 하나 이상의 기능을 수행하기 위한 모듈, 프로그램, 루틴, 명령어 세트 또는 프로세스를 포함할 수 있다.
본 문서에서 사용된 용어 "모듈"은 하드웨어, 소프트웨어 또는 펌웨어로 구성된 유닛을 포함하며, 예를 들면, 로직, 논리 블록, 부품, 또는 회로 등의 용어와 상호 호환적으로 사용될 수 있다. "모듈"은, 일체로 구성된 부품 또는 하나 또는 그 이상의 기능을 수행하는 최소 단위 또는 그 일부가 될 수 있다. "모듈"은 기계적으로 또는 전자적으로 구현될 수 있으며, 예를 들면, 어떤 동작들을 수행하는, 알려졌거나 앞으로 개발될, ASIC(application-specific integrated circuit) 칩, FPGAs(field-programmable gate arrays), 또는 프로그램 가능 논리 장치를 포함할 수 있다. 다양한 실시예에 따른 장치(예: 모듈들 또는 그 기능들) 또는 방법(예: 동작들)의 적어도 일부는 프로그램 모듈의 형태로 컴퓨터로 판독 가능한 저장 매체(예:메모리(1230))에 저장된 명령어로 구현될 수 있다. 상기 명령어가 프로세서(예: 프로세서(1220))에 의해 실행될 경우, 프로세서가 상기 명령어에 해당하는 기능을 수행할 수 있다. 컴퓨터로 판독 가능한 기록 매체는, 하드디스크, 플로피디스크, 마그네틱 매체(예: 자기테이프), 광기록 매체(예: CD-ROM, DVD, 자기-광 매체 (예: 플롭티컬 디스크), 내장 메모리 등을 포함할 수 있다. 명령어는 컴파일러에 의해 만들어지는 코드 또는 인터프리터에 의해 실행될 수 있는 코드를 포함할 수 있다. 다양한 실시예에 따른 모듈 또는 프로그램 모듈은 전술한 구성요소들 중 적어도 하나 이상을 포함하거나, 일부가 생략되거나, 또는 다른 구성요소를 더 포함할 수 있다. 다양한 실시예에 따른, 모듈, 프로그램 모듈 또는 다른 구성요소에 의해 수행되는 동작들은 순차적, 병렬적, 반복적 또는 휴리스틱하게 실행되거나, 적어도 일부 동작이 다른 순서로 실행되거나, 생략되거나, 또는 다른 동작이 추가될 수 있다.
그리고 본 문서에 개시된 실시 예는 개시된, 기술 내용의 설명 및 이해를 위해 제시된 것이며, 본 발명의 범위를 한정하는 것은 아니다. 따라서, 본 문서의 범위는, 본 발명의 기술적 사상에 근거한 모든 변경 또는 다양한 다른 실시 예를 포함하는 것으로 해석되어야 한다.

Claims (20)

  1. 전자 장치에 있어서,
    카메라;
    웹 브라우저의 실행 화면을 출력하는 디스플레이;
    입력 장치;
    무선 연결 또는 유선 무선 연결을 통해 네트워크와 통신 채널을 형성하는 통신 회로;
    상기 카메라, 상기 통신 회로, 상기 디스플레이 및 상기 입력 장치와 전기적으로 연결된 프로세서; 및
    상기 웹 브라우저를 위한 프로그램 및 인스트럭션(instruction)을 저장하고, 상기 프로세서와 전기적으로 연결된 메모리를 포함하고;
    상기 메모리는, 실행 시에, 상기 프로세서가
    상기 디스플레이에 상기 웹 브라우저를 표시하고,
    컨텐츠를 표시하는 평면적 표시 영역인 제1 영역과 연관된 제1 코드 및 상기 웹 브라우저의 사용자 인터페이스를 표시하는 입체적 표시 영역인 제2 영역과 연관된 제2 코드를 포함하는 웹 문서를 상기 통신 회로를 통해 수신하고,
    상기 제1 코드에 기초하여 상기 제1 영역에 상기 컨텐츠를 표시하고, 상기 제2 코드에 기초하여 상기 제2 영역에 상기 컨텐츠 연관된 제1 오브젝트를 표시하고,
    상기 제1 오브젝트에 대한 입력이 수신되면, 상기 제1 오브젝트와 연관된 다른 컨텐츠를 상기 제1 영역에 표시하고, 상기 제1 오브젝트와 연관된 제2 오브젝트를 상기 제2 영역에 표시하도록 하는 인스트럭션들(instructions)을 저장하며,
    상기 프로세서는 상기 컨텐츠와 연관된 제1 오브젝트를 표시함에 있어서,
    상기 제1 오브젝트를 상기 카메라에 의해 촬영된 물체에 대응하는 제3 오브젝트와 함께 표시하되, 상기 제1 오브젝트의 크기는 상기 촬영된 물체의 실제 크기와 비례하도록 표시하는, 전자 장치.
  2. 제 1 항에 있어서,
    상기 인스트럭션들은, 상기 프로세서가,
    상기 제1 영역에 표시된 컨텐츠에 기반하여 제2 영역에 제2 코드에 기술된 이미지를 제2 영역의 배경으로 표시하도록 하는 것을 특징으로 하는, 전자 장치.
  3. 전자 장치에 있어서,
    카메라;
    다시점 이미지로 제공되는 웹 브라우저의 실행 화면을 출력하는 디스플레이 -상기 웹 브라우저의 실행 화면은 컨텐츠를 표시하는 평면적 표시 영역인 제1 영역 및 상기 웹 브라우저의 사용자 인터페이스를 표시하는 입체적 표시 영역인 제2 영역을 포함함-;
    서버로부터 상기 제1 영역과 연관된 제1 코드 및 상기 제2 영역과 연관된 제2 코드를 포함하는 웹 문서를 수신하는 통신 회로;
    상기 제1 코드에 기초하여 상기 제1 영역에 상기 컨텐츠를 표시하고, 상기 제2 코드에 기초하여 상기 제2 영역에 제1 오브젝트를 표시하도록 설정된 프로세서를 포함하며,
    상기 프로세서는, 상기 제1 오브젝트에 대한 입력이 수신되면, 상기 제1 오브젝트와 연관된 다른 컨텐츠를 상기 제1 영역에 표시하고, 상기 제1 오브젝트와 연관된 제2 오브젝트를 상기 제2 영역에 표시하고,
    상기 프로세서는 상기 컨텐츠와 연관된 제1 오브젝트를 표시함에 있어서,
    상기 제1 오브젝트를 상기 카메라에 의해 촬영된 물체에 대응하는 제3 오브젝트와 함께 표시하되, 상기 제1 오브젝트의 크기는 상기 촬영된 물체의 실제 크기와 비례하도록 표시하도록 설정된, 전자 장치.
  4. 제 3 항에 있어서,
    상기 제1 영역은 평면형태의 표시 영역이고,
    상기 제2 영역은 구형 또는 원통형의 표시 영역인, 전자 장치.
  5. 제 3 항에 있어서,
    상기 웹 문서를 파싱하는 파싱 모듈, 상기 제1 코드를 실행하는 제1 실행 모듈 및 상기 제2 코드를 실행하는 제2 실행 모듈을 포함하는 상기 웹 브라우저가 저장된 메모리를 더 포함하고,
    상기 프로세서는,
    상기 파싱 모듈을 이용하여 상기 웹 문서를 파싱함으로써 상기 제1 코드 및 상기 제2 코드를 추출하고, 상기 제1 실행 모듈을 이용하여 상기 제1 영역에 상기 컨텐츠를 표시하고, 상기 제2 실행 모듈을 이용하여 상기 제2 영역에 상기 제1 오브젝트를 표시하도록 설정된, 전자 장치.
  6. 제 3 항에 있어서,
    상기 프로세서는,
    상기 제2 코드와 연관된 이미지를 상기 제2 영역에 표시하도록 설정된, 전자 장치.
  7. 제 3 항에 있어서,
    상기 프로세서는,
    상기 제1 코드와 연관된 동영상을 상기 제1 영역에 표시하고,
    상기 제1 코드와 연관된 자막 파일을 파싱함으로써 상기 제2 코드를 추출하고,
    상기 제2 코드와 연관된 상기 제1 오브젝트를 상기 제2 영역에 표시하도록 설정된, 전자 장치.
  8. 제 3 항에 있어서,
    상기 프로세서는,
    상기 제1 오브젝트를 상기 제2 코드에 설정된 시간에 표시하도록 설정된, 전자 장치.
  9. 제 3 항에 있어서,
    상기 프로세서는,
    상기 제1 오브젝트를 상기 제2 코드에 설정된 크기로 표시하도록 설정된, 전자 장치.
  10. 제 3 항에 있어서,
    상기 프로세서는,
    상기 제2 코드에 포함된 스크립트에 따라 상기 제1 오브젝트를 변경하도록 설정된, 전자 장치.
  11. 삭제
  12. 제 3 항에 있어서,
    상기 프로세서는,
    상기 전자 장치의 사용자가 상기 제2 코드에 설정된 영역을 응시하는 경우, 상기 제2 코드와 연관된 상기 제1 오브젝트를 표시하도록 설정된, 전자 장치.
  13. 제 3 항에 있어서,
    상기 프로세서는,
    상기 제2 코드에 기초하여 상기 제2 코드와 연관된 상기 제1 오브젝트와 함께 상기 제2 영역에 표시된 제2 오브젝트를 변경하도록 설정된, 전자 장치.
  14. 제 3 항에 있어서,
    상기 프로세서는,
    상기 제2 코드에 기초하여 상기 전자 장치와 연동된 외부 장치를 제어하도록 설정된, 전자 장치.
  15. 제 3 항에 있어서,
    상기 프로세서는,
    상기 제1 오브젝트에 대한 입력이 인가되면, 상기 제1 오브젝트가 표시되는 위치, 각도 또는 크기를 변경하도록 설정된, 전자 장치.
  16. 삭제
  17. 전자 장치의 웹 문서 출력 방법에 있어서,
    웹 브라우저를 실행하는 동작;
    다시점 이미지로 제공되는 상기 웹 브라우저의 실행 화면을 출력하는 동작 -상기 웹 브라우저의 실행 화면은 컨텐츠를 표시하는 평면적 표시 영역인 제1 영역 및 상기 웹 브라우저의 사용자 인터페이스를 표시하는 입체적 표시 영역인 제2 영역을 포함함-;
    서버로부터 상기 제1 영역과 연관된 제1 코드 및 상기 제2 영역과 연관된 제2 코드를 포함하는 웹 문서를 수신하는 동작;
    상기 제1 코드에 기초하여 상기 제1 영역에 상기 컨텐츠를 표시하는 동작;
    상기 제2 코드에 기초하여 상기 제2 영역에 제1 오브젝트를 표시하는 동작; 및
    상기 제1 오브젝트에 대한 입력이 수신되면, 상기 제1 오브젝트와 연관된 다른 컨텐츠를 상기 제1 영역에 표시하고, 상기 제1 오브젝트와 연관된 제2 오브젝트를 상기 제2 영역에 표시하는 동작을 포함하며,
    상기 컨텐츠와 연관된 제1 오브젝트를 표시하는 동작은,
    상기 제1 오브젝트를 상기 전자 장치에 의해 촬영된 물체에 대응하는 제3 오브젝트와 함께 표시하는 동작을 포함하되, 상기 제1 오브젝트의 크기는 상기 촬영된 물체의 실제 크기와 비례하도록 표시하는 동작을 포함하는, 방법.
  18. 제 17 항에 있어서,
    상기 웹 문서를 파싱함으로써 상기 제1 코드 및 상기 제2 코드를 추출하는 동작을 더 포함하는, 방법.
  19. 제 17 항에 있어서,
    상기 제1 코드와 연관된 자막 파일을 파싱함으로써, 상기 제2 코드를 추출하는 동작을 더 포함하는, 방법.
  20. 제 17 항에 있어서,
    상기 제2 영역에 제1 오브젝트를 표시하는 동작은,
    상기 제2 코드에 포함된 스크립트에 따라 상기 제1 오브젝트를 변경하는 동작을 더 포함하는, 방법.
KR1020160056703A 2016-05-09 2016-05-09 전자 장치 및 전자 장치의 전자 문서 출력 방법 KR102609450B1 (ko)

Priority Applications (2)

Application Number Priority Date Filing Date Title
KR1020160056703A KR102609450B1 (ko) 2016-05-09 2016-05-09 전자 장치 및 전자 장치의 전자 문서 출력 방법
US15/588,971 US10325533B2 (en) 2016-05-09 2017-05-08 Electronic device and method for outputting electronic document in electronic device

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
KR1020160056703A KR102609450B1 (ko) 2016-05-09 2016-05-09 전자 장치 및 전자 장치의 전자 문서 출력 방법

Publications (2)

Publication Number Publication Date
KR20170126362A KR20170126362A (ko) 2017-11-17
KR102609450B1 true KR102609450B1 (ko) 2023-12-04

Family

ID=60243447

Family Applications (1)

Application Number Title Priority Date Filing Date
KR1020160056703A KR102609450B1 (ko) 2016-05-09 2016-05-09 전자 장치 및 전자 장치의 전자 문서 출력 방법

Country Status (2)

Country Link
US (1) US10325533B2 (ko)
KR (1) KR102609450B1 (ko)

Families Citing this family (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
USD851661S1 (en) * 2016-10-04 2019-06-18 Facebook, Inc. Display screen with transitional graphical user interface
US10630797B2 (en) * 2018-01-30 2020-04-21 Akamai Technologies, Inc. Systems and methods for content delivery acceleration of virtual reality and augmented reality web pages
US11595637B2 (en) * 2018-05-14 2023-02-28 Dell Products, L.P. Systems and methods for using peripheral vision in virtual, augmented, and mixed reality (xR) applications
USD891452S1 (en) * 2018-07-27 2020-07-28 Dassault Systemes Americas Corp. Display screen portion with graphical user interface for augmented reality
US11550446B2 (en) * 2020-04-06 2023-01-10 Samsung Electronics Co., Ltd. Systems and methods for viewing webpages in extended reality environments
WO2021206408A1 (en) * 2020-04-06 2021-10-14 Samsung Electronics Co., Ltd. Electronic device and methods for viewing webpages in extended reality environments

Family Cites Families (12)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US7574381B1 (en) 1999-08-06 2009-08-11 Catherine Lin-Hendel System and method for constructing and displaying active virtual reality cyber malls, show rooms, galleries, stores, museums, and objects within
KR20020002686A (ko) * 2000-06-30 2002-01-10 심재윤 3차원 가상현실 홈페이지 운영 방법
US7680694B2 (en) 2004-03-11 2010-03-16 American Express Travel Related Services Company, Inc. Method and apparatus for a user to shop online in a three dimensional virtual reality setting
US8145295B2 (en) * 2006-04-12 2012-03-27 The Invention Science Fund I, Llc Methods and systems for untethered autofluorescent imaging, target ablation, and movement of untethered device in a lumen
US9317110B2 (en) * 2007-05-29 2016-04-19 Cfph, Llc Game with hand motion control
US8803908B2 (en) * 2010-01-15 2014-08-12 Apple Inc. Digital image transitions
US20150309316A1 (en) * 2011-04-06 2015-10-29 Microsoft Technology Licensing, Llc Ar glasses with predictive control of external device based on event input
US20150213649A1 (en) * 2012-07-27 2015-07-30 Nec Solutions Innovators, Ltd. Three-dimensional environment sharing system and three-dimensional environment sharing method
KR102311221B1 (ko) * 2014-04-28 2021-10-13 삼성전자주식회사 오브젝트 운용 방법 및 이를 지원하는 전자 장치
US10750153B2 (en) * 2014-09-22 2020-08-18 Samsung Electronics Company, Ltd. Camera system for three-dimensional video
US9358103B1 (en) * 2015-02-10 2016-06-07 Omega Ophthalmics Llc Prosthetic capsular devices, systems, and methods
US10328342B2 (en) * 2015-09-24 2019-06-25 Intel Corporation Magic wand methods, apparatuses and systems for defining, initiating, and conducting quests

Also Published As

Publication number Publication date
KR20170126362A (ko) 2017-11-17
US10325533B2 (en) 2019-06-18
US20170322911A1 (en) 2017-11-09

Similar Documents

Publication Publication Date Title
KR102425818B1 (ko) 스크린 미러링 서비스 제공장치 및 방법
KR102399049B1 (ko) 전자 장치 및 전자 장치의 이미지 처리 방법
KR102264806B1 (ko) 스크린 미러링 서비스 제공방법 및 장치
KR102609450B1 (ko) 전자 장치 및 전자 장치의 전자 문서 출력 방법
US20170150139A1 (en) Electronic device and method for displaying content according to display mode
KR20180074369A (ko) 3차원 컨텐츠의 썸네일 관리 방법 및 그 장치
KR20180109340A (ko) 전자 장치 및 전자 장치의 화면 공유 방법
KR20160096422A (ko) 화면 표시 방법 및 전자 장치
KR102407765B1 (ko) 전자 장치 및 전자 장치의 파노라마 영상 표시 제어 방법
KR102498815B1 (ko) 전자 장치 및 전자 장치의 비디오 편집 방법
KR102458444B1 (ko) 전자 장치 및 그 동작 방법
KR20170019615A (ko) 전자 기기의 해상도 조정 방법 및 장치
KR102398027B1 (ko) 전자 장치의 동적 프리뷰 디스플레이 방법 및 그 전자 장치
KR102632270B1 (ko) 전자 장치 및 파노라마 영상 표시와 생성 방법
KR102588524B1 (ko) 전자 장치 및 그의 동작 방법
KR20170013623A (ko) 디스플레이를 제어하는 전자 장치 및 방법
KR20180041984A (ko) 이미지를 렌더링 하는 장치 및 방법
KR20180073188A (ko) 전자장치 및 이를 활용한 웹 페이지 표시 방법
KR102451405B1 (ko) 복수의 디스플레이들을 갖는 전자 장치 및 그 동작 방법
KR102651793B1 (ko) 영상 통화를 수행하기 위한 전자 장치 및 컴퓨터 판독 가능한 기록매체
KR102323797B1 (ko) 전자 장치 및 그의 정보 공유 방법
KR20170044469A (ko) 실행 화면 레코딩 방법 및 그 방법을 처리하는 전자 장치
KR102475167B1 (ko) 외부 전자 장치를 통해 어플리케이션을 제공하는 방법 및 장치
KR102568387B1 (ko) 전자 장치 및 그의 데이터 처리 방법
KR20180113109A (ko) 전자 장치 및 전자 장치의 화면 표시 방법

Legal Events

Date Code Title Description
A201 Request for examination
E902 Notification of reason for refusal
E701 Decision to grant or registration of patent right
GRNT Written decision to grant