KR20170114625A - 소모 전류를 줄이는 방법 및 전자 장치 - Google Patents

소모 전류를 줄이는 방법 및 전자 장치 Download PDF

Info

Publication number
KR20170114625A
KR20170114625A KR1020160041887A KR20160041887A KR20170114625A KR 20170114625 A KR20170114625 A KR 20170114625A KR 1020160041887 A KR1020160041887 A KR 1020160041887A KR 20160041887 A KR20160041887 A KR 20160041887A KR 20170114625 A KR20170114625 A KR 20170114625A
Authority
KR
South Korea
Prior art keywords
layer
buffer
frame buffer
graphic information
graphic
Prior art date
Application number
KR1020160041887A
Other languages
English (en)
Other versions
KR102491499B1 (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 KR1020160041887A priority Critical patent/KR102491499B1/ko
Priority to PCT/KR2017/002949 priority patent/WO2017175989A1/ko
Priority to US16/086,084 priority patent/US11175717B2/en
Priority to EP17779289.2A priority patent/EP3393111B1/en
Publication of KR20170114625A publication Critical patent/KR20170114625A/ko
Application granted granted Critical
Publication of KR102491499B1 publication Critical patent/KR102491499B1/ko

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F1/00Details not covered by groups G06F3/00 - G06F13/00 and G06F21/00
    • G06F1/26Power supply means, e.g. regulation thereof
    • G06F1/32Means for saving power
    • H04M1/72519
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04MTELEPHONIC COMMUNICATION
    • H04M1/00Substation equipment, e.g. for use by subscribers
    • H04M1/72Mobile telephones; Cordless telephones, i.e. devices for establishing wireless links to base stations without route selection
    • H04M1/724User interfaces specially adapted for cordless or mobile telephones
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F1/00Details not covered by groups G06F3/00 - G06F13/00 and G06F21/00
    • G06F1/26Power supply means, e.g. regulation thereof
    • G06F1/32Means for saving power
    • G06F1/3203Power management, i.e. event-based initiation of a power-saving mode
    • G06F1/3206Monitoring of events, devices or parameters that trigger a change in power modality
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F1/00Details not covered by groups G06F3/00 - G06F13/00 and G06F21/00
    • G06F1/26Power supply means, e.g. regulation thereof
    • G06F1/32Means for saving power
    • G06F1/3203Power management, i.e. event-based initiation of a power-saving mode
    • G06F1/3206Monitoring of events, devices or parameters that trigger a change in power modality
    • G06F1/3215Monitoring of peripheral devices
    • G06F1/3225Monitoring of peripheral devices of memory devices
    • 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/06Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
    • G06F3/0601Interfaces specially adapted for storage systems
    • G06F3/0602Interfaces specially adapted for storage systems specifically adapted to achieve a particular effect
    • G06F3/0625Power saving in storage systems
    • 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
    • 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/1423Digital output to display device ; Cooperation and interconnection of the display device with other functional units controlling a plurality of local displays, e.g. CRT and flat panel display
    • G06F3/1438Digital output to display device ; Cooperation and interconnection of the display device with other functional units controlling a plurality of local displays, e.g. CRT and flat panel display using more than one graphics controller
    • 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
    • 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/36Control arrangements or circuits for visual indicators common to cathode-ray tube indicators and other visual indicators characterised by the display of a graphic pattern, e.g. using an all-points-addressable [APA] memory
    • G09G5/39Control of the bit-mapped memory
    • G09G5/393Arrangements for updating the contents of the bit-mapped memory
    • 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/36Control arrangements or circuits for visual indicators common to cathode-ray tube indicators and other visual indicators characterised by the display of a graphic pattern, e.g. using an all-points-addressable [APA] memory
    • G09G5/39Control of the bit-mapped memory
    • G09G5/395Arrangements specially adapted for transferring the contents of the bit-mapped memory to the screen
    • G09G5/397Arrangements specially adapted for transferring the contents of two or more bit-mapped memories to the screen simultaneously, e.g. for mixing or overlay
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04MTELEPHONIC COMMUNICATION
    • H04M1/00Substation equipment, e.g. for use by subscribers
    • H04M1/72Mobile telephones; Cordless telephones, i.e. devices for establishing wireless links to base stations without route selection
    • H04M1/725Cordless telephones
    • GPHYSICS
    • G09EDUCATION; CRYPTOGRAPHY; DISPLAY; ADVERTISING; SEALS
    • G09GARRANGEMENTS OR CIRCUITS FOR CONTROL OF INDICATING DEVICES USING STATIC MEANS TO PRESENT VARIABLE INFORMATION
    • G09G2340/00Aspects of display data processing
    • G09G2340/04Changes in size, position or resolution of an image
    • G09G2340/0407Resolution change, inclusive of the use of different resolutions for different screen areas
    • G09G2340/0435Change or adaptation of the frame rate of the video stream
    • GPHYSICS
    • G09EDUCATION; CRYPTOGRAPHY; DISPLAY; ADVERTISING; SEALS
    • G09GARRANGEMENTS OR CIRCUITS FOR CONTROL OF INDICATING DEVICES USING STATIC MEANS TO PRESENT VARIABLE INFORMATION
    • G09G2360/00Aspects of the architecture of display systems
    • G09G2360/18Use of a frame buffer in a display terminal, inclusive of the display panel
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04MTELEPHONIC COMMUNICATION
    • H04M2201/00Electronic components, circuits, software, systems or apparatus used in telephone systems
    • H04M2201/34Microprocessors
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04MTELEPHONIC COMMUNICATION
    • H04M2201/00Electronic components, circuits, software, systems or apparatus used in telephone systems
    • H04M2201/38Displays

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • Computer Hardware Design (AREA)
  • Human Computer Interaction (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Signal Processing (AREA)
  • Computer Graphics (AREA)
  • User Interface Of Digital Computer (AREA)
  • Telephone Function (AREA)
  • Controls And Circuits For Display Device (AREA)

Abstract

본 발명의 다양한 실시 예들은 전자 장치에 관한 것으로, 상기 전자 장치는 어플리케이션으로부터 수신한 그래픽 정보를 저장하기 위한 그래픽 버퍼; 디스플레이에 표시하기 위한 그래픽 정보를 저장하기 위한 프레임 버퍼; 및 프로세서를 포함하고, 상기 프로세서는; 제1 레이어로부터 수신한 제1 그래픽 정보를 상기 그래픽 버퍼에 저장하고; 제2 레이어로부터 수신한 제2 그래픽 정보를 상기 프레임 버퍼에 저장하고; 상기 그래픽 버퍼에 저장된 상기 제1 그래픽 정보를 상기 프레임 버퍼에 저장하고; 및 상기 프레임 버퍼에 저장된, 상기 제1 그래픽 정보 및 상기 제2 그래픽 정보를 상기 프로세서와 기능적으로 연결된 디스플레이를 통하여 동시에 표시하도록 설정된 것을 특징으로 할 수 있다. 이 외에도, 명세서를 통해 파악될 수 있는 다른 실시 예들이 가능하다.

Description

소모 전류를 줄이는 방법 및 전자 장치{Device For Reducing Current Consumption and Method Thereof}
본 발명의 다양한 실시 예는, 소모 전류를 줄이는 전자 장치 및 방법에 관한 것이다.
정보 통신 기술의 발전으로 기지국 등의 네트워크 장치가 전국 각지에 설치되었고, 전자 장치는 다른 전자 장치와 네트워크를 통해 데이터를 송수신함으로써, 사용자로 하여금 전국 어디에서나 자유롭게 네트워크를 사용할 수 있다.
다양한 종류의 전자 장치는 최근 디지털 컨버전스(convergence)의 추세에 따라 다양한 기능을 제공하게 되었다. 예를 들어, 스마트폰은 전화를 하는 용도 이외에, 상기 네트워크를 이용하여 인터넷 접속 기능을 지원하고, 음악 또는 비디오의 재생 기능, 이미지 센서를 이용한 사진, 동영상 등의 촬영 기능을 지원한다.
상기와 같은 다양한 기능의 수행을 위해 스마트폰은 전력을 공급하는 배터리를 구비한다. 최근 스마트폰의 슬림화 및 경량화에 따라서 배터리를 효율적으로 이용하는 방안이 고안되고 있다.
상기와 같은 다양한 기능의 수행은 많은 전류를 소모하게 되었고, 심미적 목적으로 인한 배터리 용량의 한계를 극복하기 위해 전류 소모를 줄이는 것은 중요한 문제가 되었다.
본 발명의 다양한 실시 예는 어플리케이션 출력 소모 전류를 줄이는 전자 장치 및 방법을 제공하고자 한다. 다만, 본 발명의 다양한 실시 예가 이루고자 하는 기술적 과제는 상기된 바와 같은 기술적 과제들로 한정되지 않으며, 또 다른 기술적 과제들이 존재할 수 있다.
본 발명의 다양한 실시 예에 따른 전자 장치는 어플리케이션으로부터 수신한 그래픽 정보를 저장하기 위한 그래픽 버퍼; 디스플레이에 표시하기 위한 그래픽 정보를 저장하기 위한 프레임 버퍼; 및 프로세서를 포함하고, 상기 프로세서는; 제1 레이어로부터 수신한 제1 그래픽 정보를 상기 그래픽 버퍼에 저장하고; 제2 레이어로부터 수신한 제2 그래픽 정보를 상기 프레임 버퍼에 저장하고; 상기 그래픽 버퍼에 저장된 상기 제1 그래픽 정보를 상기 프레임 버퍼에 저장하고; 및 상기 프레임 버퍼에 저장된, 상기 제1 그래픽 정보 및 상기 제2 그래픽 정보를 상기 프로세서와 기능적으로 연결된 디스플레이를 통하여 동시에 표시하도록 설정될 수 있다.
본 발명의 다양한 실시 예에 따른 전자 장치에서 수행하는 방법은 제1 레이어로부터 수신한 제1 그래픽 정보를 상기 그래픽 버퍼에 저장하는 동작; 제2 레이어로부터 수신한 제2 그래픽 정보를 상기 프레임 버퍼에 저장하는 동작; 상기 그래픽 버퍼에 저장된 상기 제1 그래픽 정보를 상기 프레임 버퍼에 저장하는 동작; 및 상기 프레임 버퍼에 저장된, 상기 제1 그래픽 정보 및 상기 제2 그래픽 정보를 상기 전자 장치의 디스플레이를 통하여 동시에 표시하는 동작;을 포함 할 수 있다.
본 발명의 다양한 실시 예에 따른 컴퓨터 판독 가능 기록매체는, 제1 레이어로부터 수신한 제1 그래픽 정보를 그래픽 버퍼에 저장하는 동작; 제2 레이어로부터 수신한 제2 그래픽 정보를 프레임 버퍼에 저장하는 동작; 상기 그래픽 버퍼에 저장된 상기 제1 그래픽 정보를 상기 프레임 버퍼에 저장하는 동작; 및 상기 프레임 버퍼에 저장된, 상기 제1 그래픽 정보 및 상기 제2 그래픽 정보를 상기 전자 장치의 디스플레이를 통하여 동시에 표시하는 동작;을 포함하는 방법을 수행하는 프로그램이 기록될 수 있다.
본 발명의 다양한 실시 예에 따른 상기 전자 장치 및 방법은, 타겟 어플리케이션의 이미지 드로잉을 그래픽 버퍼가 아닌 프레임 버퍼에 수행함으로써, 어플리케이션 출력 소모 전류를 줄이는 효과를 제공할 수 있다.
도 1은 본 발명의 다양한 실시 예에 따른, 네트워크 환경 내의 전자 장치를 도시한 도면이다.
도 2는 본 발명의 다양한 실시 예에 따른, 전자 장치의 블록도이다.
도 3은 본 발명의 다양한 실시 예에 따른, 프로그램 모듈의 블록도이다.
도 4는 본 발명의 다양한 실시 예에 따른, 전자 장치의 블록도를 나타낸 도면이다.
도 5는 본 발명의 다양한 실시 예에 따른, 제1 레이어 및 제2 레이어의 상태에 따른 합성 케이스를 나타낸 표이다.
도 6의 (a) 및 도 6의 (b)는 본 발명의 다양한 실시 예에 따른, 다양한 합성 케이스를 시간의 흐름에 따라 나타낸 도면이다.
도 7은 본 발명의 다양한 실시 예에 따른, 전자 장치의 각 구성 및 각 구성을 통해 수행되는 동작을 나타낸 도면이다.
도 8은 본 발명의 다양한 실시 예에 따른, 레이어 선택 모듈이 타겟 레이어를 선정하는 방법을 나타낸 순서도이다.
도 9는 본 발명의 다양한 실시 예에 따른, 레이어 선택 모듈이 타겟 레이어를 선정하는 방법을 나타낸 순서도이다.
도 10은 본 발명의 다양한 실시 예에 따른, 레이어 선택 모듈이 타겟 레이어를 선정하는 방법을 나타낸 순서도이다.
도 11은 본 발명의 다양한 실시 예에 따른, 싱글 윈도우와 멀티 윈도우에 따른 타겟 레이어 선정의 차이를 나타낸 도면이다.
도 12는 본 발명의 다양한 실시 예에 따른, 그래픽 버퍼 또는 프레임 버퍼에 드로잉을 수행하는 방법을 나타낸 도면이다.
도 13은 본 발명의 다양한 실시 예에 따른, 그래픽 버퍼 및/또는 프레임 버퍼에 대해 합성을 수행하는 방법을 나타낸 순서도이다.
도 14는 본 발명의 다양한 실시 예에 따른, 어플리케이션 화면을 출력하는 방법을 나타낸 순서도이다.
이하, 본 문서의 다양한 실시 예가 첨부된 도면을 참조하여 기재된다. 그러나, 이는 본 문서에 기재된 기술을 특정한 실시 형태에 대해 한정하려는 것이 아니며, 본 문서의 실시 예의 다양한 변경(modifications), 균등물(equivalents), 및/또는 대체물(alternatives)을 포함하는 것으로 이해되어야 한다. 도면의 설명과 관련하여, 유사한 구성요소에 대해서는 유사한 참조 부호가 사용될 수 있다.
본 문서에서, "가진다," "가질 수 있다," "포함한다," 또는 "포함할 수 있다" 등의 표현은 해당 특징(예: 수치, 기능, 동작, 또는 부품 등의 구성요소)의 존재를 가리키며, 추가적인 특징의 존재를 배제하지 않는다.
본 문서에서, "A 또는 B," "A 또는/및 B 중 적어도 하나," 또는 "A 또는/및 B 중 하나 또는 그 이상"등의 표현은 함께 나열된 항목들의 모든 가능한 조합을 포함할 수 있다. 예를 들면, "A 또는 B," "A 및 B 중 적어도 하나," 또는 "A 또는 B 중 적어도 하나"는, (1) 적어도 하나의 A를 포함, (2) 적어도 하나의 B를 포함, 또는 (3) 적어도 하나의 A 및 적어도 하나의 B 모두를 포함하는 경우를 모두 지칭할 수 있다.
본 문서에서 사용된 "제1," "제2," "첫째," 또는 "둘째,"등의 표현들은 다양한 구성요소들을, 순서 및/또는 중요도에 상관없이 수식할 수 있고, 한 구성요소를 다른 구성요소와 구분하기 위해 사용될 뿐 해당 구성요소들을 한정하지 않는다. 예를 들면, 제1 사용자 기기와 제2 사용자 기기는, 순서 또는 중요도와 무관하게, 서로 다른 사용자 기기를 나타낼 수 있다. 예를 들면, 본 문서에 기재된 권리 범위를 벗어나지 않으면서 제1 구성요소는 제2 구성요소로 명명될 수 있고, 유사하게 제2 구성요소도 제1 구성요소로 바꾸어 명명될 수 있다.
어떤 구성요소(예: 제1 구성요소)가 다른 구성요소(예: 제2 구성요소)에 "(기능적으로 또는 통신적으로) 연결되어((operatively or communicatively) coupled with/to)" 있다거나 "접속되어(connected to)" 있다고 언급된 때에는, 상기 어떤 구성요소가 상기 다른 구성요소에 직접적으로 연결되거나, 다른 구성요소(예: 제 3 구성요소)를 통하여 연결될 수 있다고 이해되어야 할 것이다. 반면에, 어떤 구성요소(예: 제1 구성요소)가 다른 구성요소(예: 제2 구성요소)에 "직접 연결되어" 있다거나 "직접 접속되어" 있다고 언급된 때에는, 상기 어떤 구성요소와 상기 다른 구성요소 사이에 다른 구성요소(예: 제3 구성요소)가 존재하지 않는 것으로 이해될 수 있다.
본 문서에서 사용된 표현 "~하도록 구성된(또는 설정된)(configured to)"은 상황에 따라, 예를 들면, "~에 적합한(suitable for)," "~하는 능력을 가지는(having the capacity to)," "~하도록 설계된(designed to)," "~하도록 변경된(adapted to)," "~하도록 만들어진(made to)," 또는 "~를 할 수 있는(capable of)"과 바꾸어 사용될 수 있다. 용어 "~하도록 구성된(또는 설정된)"은 하드웨어적으로 "특별히 설계된(specifically designed to)" 것만을 반드시 의미하지 않을 수 있다. 대신, 어떤 상황에서는, "~하도록 구성된 장치"라는 표현은, 그 장치가 다른 장치 또는 부품들과 함께 "~할 수 있는" 것을 의미할 수 있다. 예를 들면, 문구 "A, B, 및 C를 수행하도록 구성된(또는 설정된) 프로세서"는 해당 동작을 수행하기 위한 전용 프로세서(예: 임베디드 프로세서), 또는 메모리 장치에 저장된 하나 이상의 소프트웨어 프로그램들을 실행함으로써, 해당 동작들을 수행할 수 있는 범용 프로세서(generic-purpose processor)(예: CPU 또는 application processor)를 의미할 수 있다.
본 문서에서 사용된 용어들은 단지 특정한 실시 예를 설명하기 위해 사용된 것으로, 다른 실시 예의 범위를 한정하려는 의도가 아닐 수 있다. 단수의 표현은 문맥상 명백하게 다르게 뜻하지 않는 한, 복수의 표현을 포함할 수 있다. 기술적이거나 과학적인 용어를 포함해서 여기서 사용되는 용어들은 본 문서에 기재된 기술 분야에서 통상의 지식을 가진 자에 의해 일반적으로 이해되는 것과 동일한 의미를 가질 수 있다. 본 문서에 사용된 용어들 중 일반적인 사전에 정의된 용어들은, 관련 기술의 문맥상 가지는 의미와 동일 또는 유사한 의미로 해석될 수 있으며, 본 문서에서 명백하게 정의되지 않는 한, 이상적이거나 과도하게 형식적인 의미로 해석되지 않는다. 경우에 따라서, 본 문서에서 정의된 용어일지라도 본 문서의 실시 예들을 배제하도록 해석될 수 없다.
본 문서의 다양한 실시 예들에 따른 전자 장치는, 예를 들면, 스마트폰(smartphone), 태블릿 PC(tablet personal computer), 이동 전화기(mobile phone), 영상 전화기, 전자책 리더기(e-book reader), 데스크탑 PC(desktop personal computer), 랩탑 PC(laptop personal computer), 넷북 컴퓨터(netbook computer), 워크스테이션(workstation), 서버, PDA(personal digital assistant), PMP(portable multimedia player), MP3 플레이어, 모바일 의료기기, 카메라(camera), 또는 웨어러블 장치(wearable device) 중 적어도 하나를 포함할 수 있다. 다양한 실시 예에 따르면, 웨어러블 장치는 액세서리형(예: 시계, 반지, 팔찌, 발찌, 목걸이, 안경, 콘택트 렌즈, 또는 머리 착용형 장치(head-mounted-device(HMD)), 직물 또는 의류 일체형(예: 전자 의복), 신체 부착형(예: 스킨 패드(skin pad) 또는 문신), 또는 생체 이식형(예: implantable circuit) 중 적어도 하나를 포함할 수 있다.
어떤 실시 예들에서, 전자 장치는 가전 제품(home appliance)일 수 있다. 가전 제품은, 예를 들면, 텔레비전, DVD(digital video disk) 플레이어, 오디오, 냉장고, 에어컨, 청소기, 오븐, 전자레인지, 세탁기, 공기 청정기, 셋톱 박스(set-top box), 홈 오토매이션 컨트롤 패널(home automation control panel), 보안 컨트롤 패널(security control panel), TV 박스(예: 삼성 HomeSyncTM, 애플TVTM, 또는 구글 TVTM), 게임 콘솔(예: XboxTM, PlayStationTM), 전자 사전, 전자 키, 캠코더(camcorder), 또는 전자 액자 중 적어도 하나를 포함할 수 있다.
다른 실시 예에서, 전자 장치는, 각종 의료기기(예: 각종 휴대용 의료측정기기(혈당 측정기, 심박 측정기, 혈압 측정기, 또는 체온 측정기 등), MRA(magnetic resonance angiography), MRI(magnetic resonance imaging), CT(computed tomography), 촬영기, 또는 초음파기 등), 네비게이션(navigation) 장치, 위성 항법 시스템(GNSS(global navigation satellite system)), EDR(event data recorder), FDR(flight data recorder), 자동차 인포테인먼트(infotainment) 장치, 선박용 전자 장비(예: 선박용 항법 장치, 자이로 콤파스 등), 항공 전자기기(avionics), 보안 기기, 차량용 헤드 유닛(head unit), 산업용 또는 가정용 로봇, 금융 기관의 ATM(automatic teller's machine), 상점의 POS(point of sales), 또는 사물 인터넷 장치(internet of things)(예: 전구, 각종 센서, 전기 또는 가스 미터기, 스프링클러 장치, 화재경보기, 온도조절기(thermostat), 가로등, 토스터(toaster), 운동기구, 온수탱크, 히터, 보일러 등) 중 적어도 하나를 포함할 수 있다.
어떤 실시 예에 따르면, 전자 장치는 가구(furniture) 또는 건물/구조물의 일부, 전자 보드(electronic board), 전자 사인 수신 장치(electronic signature receiving device), 프로젝터(projector), 또는 각종 계측 기기(예: 수도, 전기, 가스, 또는 전파 계측 기기 등) 중 적어도 하나를 포함할 수 있다. 다양한 실시 예에서, 전자 장치는 전술한 다양한 장치들 중 하나 또는 그 이상의 조합일 수 있다. 어떤 실시 예에 따른 전자 장치는 플렉서블 전자 장치일 수 있다. 또한, 본 문서의 실시 예에 따른 전자 장치는 전술한 기기들에 한정되지 않으며, 기술 발전에 따른 새로운 전자 장치를 포함할 수 있다.
이하, 첨부 도면을 참조하여, 다양한 실시 예에 따른 전자 장치가 설명된다. 본 문서에서, 사용자라는 용어는 전자 장치를 사용하는 사람 또는 전자 장치를 사용하는 장치(예: 인공지능 전자 장치)를 지칭할 수 있다.
이하 첨부 도면에서는, 본 발명의 다양한 실시 예에 따른 전자 장치는 스마트폰인 것을 예로 들어 설명하겠다.
도 1을 참조하여, 다양한 실시 예에서의, 네트워크 환경 내의 전자 장치 100이 기재된다. 전자 장치 100은 버스 110, 프로세서 120, 메모리 130, 입출력 인터페이스 150, 디스플레이 장치 160, 및 통신 인터페이스 170을 포함할 수 있다. 어떤 실시 예에서는, 전자 장치 100은, 구성요소들 중 적어도 하나를 생략하거나 다른 구성요소를 추가적으로 구비할 수 있다.
버스 110은, 예를 들면, 구성요소들 110 내지 170을 서로 연결하고, 구성요소들 간의 통신(예: 제어 메시지 및/또는 데이터)을 전달하는 회로를 포함할 수 있다.
프로세서 120은, 중앙처리장치(central processing unit(CPU)), 어플리케이션 프로세서(application processor(AP)), 또는 커뮤니케이션 프로세서(communication processor(CP)) 중 하나 또는 그 이상을 포함할 수 있다. 프로세서 120은, 예를 들면, 전자 장치 100의 적어도 하나의 다른 구성요소들의 제어 및/또는 통신에 관한 연산이나 데이터 처리를 실행할 수 있다.
메모리 130은, 휘발성 및/또는 비휘발성 메모리를 포함할 수 있다. 메모리 130은, 예를 들면, 전자 장치 100의 적어도 하나의 다른 구성요소에 관계된 명령 또는 데이터를 저장할 수 있다. 한 실시 예에 따르면, 메모리 130은 소프트웨어 및/또는 프로그램 140을 저장할 수 있다. 프로그램 140은, 예를 들면, 커널 141, 미들웨어 143, 어플리케이션 프로그래밍 인터페이스(application programming interface(API)) 145, 및/또는 어플리케이션 프로그램(또는 "어플리케이션") 147 등을 포함할 수 있다. 커널 141, 미들웨어 143, 또는 API 145의 적어도 일부는, 운영 시스템(operating system(OS))으로 지칭될 수 있다.
커널 141은, 예를 들면, 다른 프로그램들(예: 미들웨어 143, API 145, 또는 어플리케이션 프로그램 147)에 구현된 동작 또는 기능을 실행하는 데 사용되는 시스템 리소스들(예: 버스 110, 프로세서 120, 또는 메모리 130 등)을 제어 또는 관리할 수 있다. 또한, 커널 141은 미들웨어 143, API 145, 또는 어플리케이션 프로그램 147에서 전자 장치 100의 개별 구성요소에 접근함으로써, 시스템 리소스들을 제어 또는 관리할 수 있는 인터페이스를 제공할 수 있다.
미들웨어 143은, 예를 들면, API 145 또는 어플리케이션 프로그램 147이 커널 141과 통신하여 데이터를 주고받을 수 있도록 중개 역할을 수행할 수 있다.
또한, 미들웨어 143은 어플리케이션 프로그램 147로부터 수신된 하나 이상의 작업 요청들을 우선 순위에 따라 처리할 수 있다. 예를 들면, 미들웨어 143은 어플리케이션 프로그램 147 중 적어도 하나에 전자 장치 100의 시스템 리소스(예: 버스 110, 프로세서 120, 또는 메모리 130 등)를 사용할 수 있는 우선 순위를 부여할 수 있다. 예컨대, 미들웨어 143은 상기 적어도 하나에 부여된 우선 순위에 따라 상기 하나 이상의 작업 요청들을 처리함으로써, 상기 하나 이상의 작업 요청들에 대한 스케쥴링 또는 로드 밸런싱 등을 수행할 수 있다.
API 145는, 예를 들면, 어플리케이션 147이 커널 141 또는 미들웨어 143에서 제공되는 기능을 제어하기 위한 인터페이스로, 예를 들면, 파일 제어, 창 제어, 영상 처리, 또는 문자 제어 등을 위한 적어도 하나의 인터페이스 또는 함수(예: 명령어)를 포함할 수 있다.
입출력 인터페이스 150은, 예를 들면, 사용자 또는 다른 외부 기기로부터 입력된 명령 또는 데이터를 전자 장치 100의 다른 구성요소(들)에 전달할 수 있는 인터페이스의 역할을 할 수 있다. 또한, 입출력 인터페이스 150은 전자 장치 100의 다른 구성요소(들)로부터 수신된 명령 또는 데이터를 사용자 또는 다른 외부 기기로 출력할 수 있다.
디스플레이 회로 160은, 예를 들면, 액정 디스플레이(liquid crystal display(LCD)), 발광 다이오드(light-emitting diode(LED)) 디스플레이, 유기 발광 다이오드(organic light-emitting diode(OLED)) 디스플레이, 또는 마이크로 전자기계 시스템(microelectromechanical systems(MEMS)) 디스플레이, 또는 전자종이(electronic paper) 디스플레이를 포함할 수 있다. 디스플레이 회로 160은, 예를 들면, 사용자에게 각종 콘텐츠(예: 텍스트, 이미지, 비디오, 아이콘, 또는 심볼 등)을 표시할 수 있다. 디스플레이 회로 160은, 터치 스크린을 포함할 수 있으며, 예를 들면, 전자 펜 또는 사용자의 신체의 일부를 이용한 터치, 제스쳐, 근접, 또는 호버링 입력을 수신할 수 있다.
통신 회로 170은, 예를 들면, 전자 장치 100과 외부 장치(예: 제1 외부 전자 장치 102, 제2 외부 전자 장치 104, 또는 서버 106) 간의 통신을 설정할 수 있다. 예를 들면, 통신 회로 170은 무선 통신 또는 유선 통신을 통해서 네트워크 162에 연결되어 외부 장치(예: 제2 외부 전자 장치 104 또는 서버 106)와 통신할 수 있다.
무선 통신은, 예를 들면, 셀룰러 통신 프로토콜로서, 예를 들면, LTE(long-term evolution), 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) 등 중 적어도 하나를 사용할 수 있다. 또한, 무선 통신은, 예를 들면, 근거리 통신 164를 포함할 수 있다. 근거리 통신 164는, 예를 들면, WiFi(wireless fidelity), 블루투스(Bluetooth), NFC(near field communication), 또는 GNSS(global navigation satellite system) 등 중 적어도 하나를 포함할 수 있다. 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"와 혼용되어 사용(interchangeably used)될 수 있다. 유선 통신은, 예를 들면, USB(universal serial bus), HDMI(high definition multimedia interface), RS-232(recommended standard232), 또는 POTS(plain old telephone service) 등 중 적어도 하나를 포함할 수 있다. 네트워크 162는 통신 네트워크(telecommunications network), 예를 들면, 컴퓨터 네트워크(computer network)(예: LAN 또는 WAN), 인터넷, 또는 전화 망(telephone network) 중 적어도 하나를 포함할 수 있다.
제1 외부 전자 장치 102 및 제2 외부 전자 장치 104 각각은 전자 장치 100과 동일한 또는 다른 종류의 장치일 수 있다. 한 실시 예에 따르면, 서버 106은 하나 또는 그 이상의 서버들의 그룹을 포함할 수 있다. 다양한 실시 예에 따르면, 전자 장치 100에서 실행되는 동작들의 전부 또는 일부는 다른 하나 또는 복수의 전자 장치(예: 제1 외부 전자 장치 102, 제2 외부 전자 장치 104, 또는 서버 106에서 실행될 수 있다. 한 실시 예에 따르면, 전자 장치 100)가 어떤 기능이나 서비스를 자동으로 또는 요청에 의하여 수행해야 할 경우에, 전자 장치 100은 기능 또는 서비스를 자체적으로 실행시키는 대신에 또는 추가적으로, 그와 연관된 적어도 일부 기능을 다른 전자 장치(예: 제1 외부 전자 장치 102, 제2 외부 전자 장치 104, 또는 서버 106)에게 요청할 수 있다. 다른 전자 장치(예: 제1 외부 전자 장치 102, 제2 외부 전자 장치 104, 또는 서버 106)는 요청된 기능 또는 추가 기능을 실행하고, 그 결과를 전자 장치 100로 전달할 수 있다. 전자 장치 100은 수신된 결과를 그대로 또는 추가적으로 처리하여 요청된 기능이나 서비스를 제공할 수 있다. 이를 위하여, 예를 들면, 클라우드 컴퓨팅, 분산 컴퓨팅, 또는 클라이언트-서버 컴퓨팅 기술이 이용될 수 있다.
도 2는 다양한 실시 예에 따른 전자 장치 200의 블록도이다. 전자 장치 200은, 예를 들면, 도 1에 도시된 전자 장치 100의 전체 또는 일부를 포함할 수 있다. 전자 장치 200은 하나 이상의 프로세서(예: AP(application processor)) 210, 통신 회로 220, 가입자 식별 모듈 224, 메모리 230, 센서 회로 240, 입력 장치 250, 디스플레이 회로 260, 인터페이스 270, 오디오 모듈 280, 카메라 모듈 291, 전력 관리 모듈 295, 배터리 296, 인디케이터 297, 및 모터 298을 포함할 수 있다.
프로세서 210은, 예를 들면, 운영 체제 또는 응용 프로그램을 구동하여 프로세서 210에 연결된 다수의 하드웨어 또는 소프트웨어 구성요소들을 제어할 수 있고, 각종 데이터 처리 및 연산을 수행할 수 있다. 프로세서 210은, 예를 들면, SoC(system on chip) 로 구현될 수 있다. 한 실시 예에 따르면, 프로세서 210은 GPU(graphic processing unit) 및/또는 이미지 신호 프로세서(image signal processor)를 더 포함할 수 있다. 프로세서 210은 도 2에 도시된 구성요소들 중 적어도 일부(예: 셀룰러 모듈 221)를 포함할 수도 있다. 프로세서 210은 다른 구성요소들(예: 비휘발성 메모리) 중 적어도 하나로부터 수신된 명령 또는 데이터를 휘발성 메모리에 로드(load)하여 처리하고, 다양한 데이터를 비휘발성 메모리에 저장(store)할 수 있다.
통신 회로 220은, 도 1의 통신 회로 170과 동일 또는 유사한 구성을 가질 수 있다. 통신 회로 220은, 예를 들면, 셀룰러 모듈 221, WiFi 모듈 223, 블루투스 모듈 225, GNSS 모듈 227(예: GPS 모듈, Glonass 모듈, Beidou 모듈, 또는 Galileo 모듈), NFC 모듈 228 및 RF(radio frequency) 모듈 229를 포함할 수 있다.
셀룰러 모듈 221은, 예를 들면, 통신망을 통해서 음성 통화, 영상 통화, 문자 서비스, 또는 인터넷 서비스 등을 제공할 수 있다. 한 실시 예에 따르면, 셀룰러 모듈 221은 가입자 식별 모듈(예: SIM 카드) 224를 이용하여 통신 네트워크 내에서 전자 장치 200의 구별 및 인증을 수행할 수 있다. 한 실시 예에 따르면, 셀룰러 모듈 221은 프로세서 210이 제공할 수 있는 기능 중 적어도 일부 기능을 수행할 수 있다. 한 실시 예에 따르면, 셀룰러 모듈 221은 커뮤니케이션 프로세서(CP: communication processor)를 포함할 수 있다.
WiFi 모듈 223, 블루투스 모듈 225, GNSS 모듈 227 또는 NFC 모듈 228 각각은, 예를 들면, 해당하는 모듈을 통해서 송수신되는 데이터를 처리하기 위한 프로세서를 포함할 수 있다. 어떤 실시 예에 따르면, 셀룰러 모듈 221, WiFi 모듈 223, 블루투스 모듈 225, GNSS 모듈 227 또는 NFC 모듈 228 중 적어도 일부(예: 두 개 이상)는 하나의 integrated chip(IC) 또는 IC 패키지 내에 포함될 수 있다.
RF 모듈 229는, 예를 들면, 통신 신호(예: RF 신호)를 송수신할 수 있다. RF 모듈 229는, 예를 들면, 트랜시버(transceiver), PAM(power amp module), 주파수 필터(frequency filter), LNA(low noise amplifier), 또는 안테나 등을 포함할 수 있다. 다른 실시 예에 따르면, 셀룰러 모듈 221, WiFi 모듈 223, 블루투스 모듈 225, GNSS 모듈 227 또는 NFC 모듈 228 중 적어도 하나는 별개의 RF 모듈을 통하여 RF 신호를 송수신할 수 있다.
가입자 식별 모듈 224는, 예를 들면, 가입자 식별 모듈을 포함하는 카드 및/또는 내장 SIM(embedded SIM)을 포함할 수 있으며, 고유한 식별 정보(예: ICCID(integrated circuit card identifier)) 또는 가입자 정보(예: IMSI(international mobile subscriber identity))를 포함할 수 있다.
메모리 230(예: 메모리 130)은, 예를 들면, 내장 메모리 232 또는 외장 메모리 234를 포함할 수 있다. 내장 메모리 232는, 예를 들면, 휘발성 메모리(예: DRAM(dynamic RAM), SRAM(static RAM), 또는 SDRAM(synchronous dynamic RAM) 등), 비휘발성 메모리(non-volatile Memory)(예: OTPROM(one time programmable ROM), PROM(programmable ROM), EPROM(erasable and programmable ROM), EEPROM(electrically erasable and programmable ROM), mask ROM, flash ROM, 플래시 메모리(예: NAND flash 또는 NOR flash 등), 하드 드라이브, 또는 솔리드 스테이트 드라이브(solid state drive(SSD)) 중 적어도 하나를 포함할 수 있다.
외장 메모리 234는 플래시 드라이브(flash drive), 예를 들면, CF(compact flash), SD(secure digital), Micro-SD(micro secure digital), Mini-SD(mini secure digital), xD(extreme digital), MMC(multi-media card) 또는 메모리 스틱(memory stick) 등을 더 포함할 수 있다. 외장 메모리 234는 다양한 인터페이스를 통하여 전자 장치 200과 기능적으로 및/또는 물리적으로 연결될 수 있다.
센서 회로 240은, 예를 들면, 물리량을 계측하거나 전자 장치 200의 작동 상태를 감지하여, 계측 또는 감지된 정보를 전기 신호로 변환할 수 있다. 센서 회로 240은, 예를 들면, 제스처 센서 240A, 자이로 센서 240B, 기압 센서 240C, 마그네틱 센서 240D, 가속도 센서 240E, 그립 센서 240F, 근접 센서 240G, 컬러(color) 센서 240H(예: RGB(red, green, blue) 센서), 생체 센서 240I, 온/습도 센서 240J, 조도 센서 240K, 또는 UV(ultra violet) 센서 240M 중의 적어도 하나를 포함할 수 있다. 추가적으로 또는 대체적으로(additionally or alternatively), 센서 회로 240은, 예를 들면, 후각 센서(E-nose sensor), EMG 센서(electromyography sensor), EEG 센서(electroencephalogram sensor), ECG 센서(electrocardiogram sensor), IR(infrared) 센서, 홍채 센서 및/또는 지문 센서를 포함할 수 있다. 센서 회로 240은 그 안에 속한 적어도 하나 이상의 센서들을 제어하기 위한 제어 회로를 더 포함할 수 있다. 어떤 실시 예에서는, 전자 장치 200은 프로세서 210의 일부로서 또는 별도로, 센서 회로 240을 제어하도록 구성된 프로세서를 더 포함하여, 프로세서 210이 슬립(sleep) 상태에 있는 동안, 센서 회로 240을 제어할 수 있다.
입력 장치 250은, 예를 들면, 터치 패널(touch panel) 252, (디지털) 펜 센서(pen sensor) 254, 키(key) 256, 또는 초음파(ultrasonic) 입력 장치 258을 포함할 수 있다. 터치 패널 252는, 예를 들면, 정전식, 감압식, 적외선 방식, 또는 초음파 방식 중 적어도 하나의 방식을 사용할 수 있다. 또한, 터치 패널 252는 제어 회로를 더 포함할 수도 있다. 터치 패널 252는 택타일 레이어(tactile layer)를 더 포함하여, 사용자에게 촉각 반응을 제공할 수 있다.
(디지털) 펜 센서 254는, 예를 들면, 터치 패널의 일부이거나, 별도의 인식용 쉬트(sheet)를 포함할 수 있다. 키 256은, 예를 들면, 물리적인 버튼, 광학식 키, 또는 키패드를 포함할 수 있다. 초음파 입력 장치 258은 마이크(예: 마이크 288)를 통해, 입력 도구에서 발생된 초음파를 감지하여, 상기 감지된 초음파에 대응하는 데이터를 확인할 수 있다.
디스플레이 회로 260(예: 디스플레이 회로 160)은 패널 262, 홀로그램 장치 264, 또는 프로젝터 266을 포함할 수 있다. 패널 262는, 도 1의 디스플레이 회로 160과 동일 또는 유사한 구성을 포함할 수 있다. 패널 262는, 예를 들면, 유연하게(flexible), 투명하게(transparent), 또는 착용할 수 있게(wearable) 구현될 수 있다. 패널 262는 터치 패널 252와 하나의 모듈로 구성될 수도 있다. 홀로그램 장치 264는 빛의 간섭을 이용하여 입체 영상을 허공에 보여줄 수 있다. 프로젝터 266은 스크린에 빛을 투사하여 영상을 표시할 수 있다. 스크린은, 예를 들면, 전자 장치 200의 내부 또는 외부에 위치할 수 있다. 한 실시 예에 따르면, 디스플레이 회로 260은 패널 262, 홀로그램 장치 264, 또는 프로젝터 266을 제어하기 위한 제어 회로를 더 포함할 수 있다.
인터페이스 270은, 예를 들면, HDMI(high-definition multimedia interface) 272, USB(universal serial bus) 274, 광 인터페이스(optical interface) 276, 또는 D-sub(D-subminiature) 278을 포함할 수 있다. 인터페이스 270은, 예를 들면, 도 1에 도시된 입출력 인터페이스 150에 포함될 수 있다. 추가적으로 또는 대체적으로(additionally and alternatively), 인터페이스 270은, 예를 들면, MHL(mobile high-definition link) 인터페이스, SD(secure digital) 카드/MMC(multi-media card) 인터페이스, 또는 IrDA(infrared data association) 규격 인터페이스를 포함할 수 있다.
오디오 회로 280은, 예를 들면, 소리(sound)와 전기 신호를 쌍방향으로 변환시킬 수 있다. 오디오 회로 280의 적어도 일부 구성요소는, 예를 들면, 도 1에 도시된 입출력 인터페이스 150에 포함될 수 있다. 오디오 회로 280은, 예를 들면, 스피커 282, 리시버 284, 이어폰 286, 또는 마이크 288 등을 통해 입력 또는 출력되는 소리 정보를 처리할 수 있다.
카메라 모듈 291은, 예를 들면, 정지 영상 및 동영상을 촬영할 수 있는 장치로서, 한 실시 예에 따르면, 하나 이상의 이미지 센서(예: 전면 센서 또는 후면 센서), 렌즈, ISP(image signal processor), 또는 플래시(flash)(예: LED 또는 xenon lamp 등)를 포함할 수 있다.
전력 관리 모듈 295는, 예를 들면, 전자 장치 200의 전력을 관리할 수 있다. 한 실시 예에 따르면, 전력 관리 모듈 295는 PMIC(power management integrated circuit), 충전 IC(charger integrated circuit), 또는 배터리 또는 연료 게이지(battery or fuel gauge)를 포함할 수 있다. PMIC는, 유선 및/또는 무선 충전 방식을 가질 수 있다. 무선 충전 방식은, 예를 들면, 자기공명 방식, 자기유도 방식 또는 전자기파 방식 등을 포함하며, 무선 충전을 위한 부가적인 회로, 예를 들면, 코일 루프, 공진 회로, 또는 정류기 등을 더 포함할 수 있다. 배터리 게이지는, 예를 들면, 배터리 296의 잔량, 충전 중 전압, 전류, 또는 온도를 측정할 수 있다. 배터리 296은, 예를 들면, 충전식 전지(rechargeable battery) 및/또는 태양 전지(solar battery)를 포함할 수 있다.
인디케이터 297은 전자 장치 200 또는 그 일부(예: 프로세서 210)의 특정 상태, 예를 들면, 부팅 상태, 메시지 상태 또는 충전 상태 등을 표시할 수 있다. 모터 298은 전기적 신호를 기계적 진동으로 변환할 수 있고, 진동(vibration), 또는 햅틱(haptic) 효과 등을 발생시킬 수 있다. 도시되지는 않았으나, 전자 장치 200은 모바일 TV 지원을 위한 처리 장치(예: GPU)를 포함할 수 있다. 모바일 TV 지원을 위한 처리 장치는, 예를 들면, DMB(digital multimedia broadcasting), DVB(digital video broadcasting), 또는 미디어플로(mediaFloTM) 등의 규격에 따른 미디어 데이터를 처리할 수 있다.
본 문서에서 기술된 구성요소들 각각은 하나 또는 그 이상의 부품(component)으로 구성될 수 있으며, 해당 구성요소의 명칭은 전자 장치의 종류에 따라서 달라질 수 있다. 다양한 실시 예에서, 전자 장치는 본 문서에서 기술된 구성요소 중 적어도 하나를 포함하여 구성될 수 있으며, 일부 구성요소가 생략되거나 또는 추가적인 다른 구성요소를 더 포함할 수 있다. 또한, 다양한 실시 예에 따른 전자 장치의 구성요소들 중 일부가 결합되어 하나의 개체(entity)로 구성됨으로써, 결합되기 이전의 해당 구성요소들의 기능을 동일하게 수행할 수 있다.
도 3은 다양한 실시 예에 따른 프로그램 모듈의 블록도이다. 한 실시 예에 따르면, 프로그램 모듈 310(예: 프로그램 140)은 전자 장치(예: 전자 장치 100)에 관련된 자원을 제어하는 운영 체제(operating system(OS)) 및/또는 운영 체제 상에서 구동되는 다양한 어플리케이션(예: 어플리케이션 프로그램 147)을 포함할 수 있다. 운영 체제는, 예를 들면, 안드로이드(android), iOS, 윈도우즈(windows), 심비안(symbian), 타이젠(tizen), 또는 바다(bada) 등이 될 수 있다.
프로그램 모듈 310은 커널 320, 미들웨어 330, 어플리케이션 프로그래밍 인터페이스(application programming interface (API)) 360, 및/또는 어플리케이션 370을 포함할 수 있다. 프로그램 모듈 310의 적어도 일부는 전자 장치 상에 프리로드(preload) 되거나, 다른 전자 장치(예: 제1 외부 전자 장치 102, 제2 외부 전자 장치 104, 서버 106 등)로부터 다운로드(download) 가능하다.
커널 320(예: 커널 141)은, 예를 들면, 시스템 리소스 매니저 321 및/또는 디바이스 드라이버 323을 포함할 수 있다. 시스템 리소스 매니저 321은 시스템 리소스의 제어, 할당, 또는 회수 등을 수행할 수 있다. 한 실시 예에 따르면, 시스템 리소스 매니저 321은 프로세스 관리부, 메모리 관리부, 또는 파일 시스템 관리부 등을 포함할 수 있다. 디바이스 드라이버 323은, 예를 들면, 디스플레이 드라이버, 카메라 드라이버, 블루투스 드라이버, 공유 메모리 드라이버, USB 드라이버, 키패드 드라이버, WiFi 드라이버, 오디오 드라이버, 또는 IPC(inter-process communication) 드라이버를 포함할 수 있다.
미들웨어 330은, 예를 들면, 어플리케이션 370이 공통적으로 필요로 하는 기능을 제공하거나, 어플리케이션 370이 전자 장치 내부의 제한된 시스템 자원을 효율적으로 사용할 수 있도록 API 360을 통해 다양한 기능들을 어플리케이션 370으로 제공할 수 있다. 한 실시 예에 따르면, 미들웨어 330(예: 미들웨어 143)은 런타임 라이브러리 335, 어플리케이션 매니저(application manager) 341, 윈도우 매니저(window manager) 342, 멀티미디어 매니저(multimedia manager) 343, 리소스 매니저(resource manager) 344, 파워 매니저(power manager) 345, 데이터베이스 매니저(database manager) 346, 패키지 매니저(package manager) 347, 연결 매니저(connectivity manager) 348, 통지 매니저(notification manager) 349, 위치 매니저(location manager) 350, 그래픽 매니저(graphic manager) 351, 또는 보안 매니저(security manager) 352 중 적어도 하나를 포함할 수 있다.
런타임 라이브러리 335는, 예를 들면, 어플리케이션 370이 실행되는 동안에 프로그래밍 언어를 통해 새로운 기능을 추가하기 위해 컴파일러가 사용하는 라이브러리 모듈을 포함할 수 있다. 런타임 라이브러리 335는 입출력 관리, 메모리 관리, 또는 산술 함수에 대한 기능 등을 수행할 수 있다.
어플리케이션 매니저 341은, 예를 들면, 어플리케이션 370 중 적어도 하나의 어플리케이션의 생명 주기(life cycle)를 관리할 수 있다. 윈도우 매니저 342는 화면에서 사용하는 GUI 자원을 관리할 수 있다. 멀티미디어 매니저 343은 다양한 미디어 파일들의 재생에 필요한 포맷을 파악하고, 해당 포맷에 맞는 코덱(codec)을 이용하여 미디어 파일의 인코딩(encoding) 또는 디코딩(decoding)을 수행할 수 있다. 리소스 매니저 344는 어플리케이션 370 중 적어도 어느 하나의 어플리케이션의 소스 코드, 메모리 또는 저장 공간 등의 자원을 관리할 수 있다.
파워 매니저 345는, 예를 들면, 바이오스(BIOS: basic input/output system) 등과 함께 동작하여 배터리(battery) 또는 전원을 관리하고, 전자 장치의 동작에 필요한 전력 정보 등을 제공할 수 있다. 데이터베이스 매니저 346은 어플리케이션 370 중 적어도 하나의 어플리케이션에서 사용할 데이터베이스를 생성, 검색, 또는 변경할 수 있다. 패키지 매니저 347은 패키지 파일의 형태로 배포되는 어플리케이션의 설치 또는 업데이트를 관리할 수 있다.
연결 매니저 348은, 예를 들면, WiFi 또는 블루투스 등의 무선 연결을 관리할 수 있다. 통지 매니저 349는 도착 메시지, 약속, 근접성 알림 등의 사건(event)을 사용자에게 방해되지 않는 방식으로 표시 또는 통지할 수 있다. 위치 매니저 350은 전자 장치의 위치 정보를 관리할 수 있다. 그래픽 매니저 351은 사용자에게 제공될 그래픽 효과 또는 이와 관련된 사용자 인터페이스를 관리할 수 있다. 보안 매니저 352는 시스템 보안 또는 사용자 인증 등에 필요한 제반 보안 기능을 제공할 수 있다. 한 실시 예에 따르면, 전자 장치(예: 전자 장치 100)가 전화 기능을 포함한 경우, 미들웨어 330은 전자 장치의 음성 또는 영상 통화 기능을 관리하기 위한 통화 매니저(telephony manager)를 더 포함할 수 있다.
미들웨어 330은 전술한 구성요소들의 다양한 기능의 조합을 형성하는 미들웨어 모듈을 포함할 수 있다. 미들웨어 330은 차별화된 기능을 제공하기 위해 운영 체제의 종류 별로 특화된 모듈을 제공할 수 있다. 또한, 미들웨어 330은 동적으로 기존의 구성요소를 일부 삭제하거나 새로운 구성요소들을 추가할 수 있다.
API 360(예: API 145)은, 예를 들면, API 프로그래밍 함수들의 집합으로, 운영 체제에 따라 다른 구성으로 제공될 수 있다. 예를 들면, 안드로이드 또는 iOS의 경우, 플랫폼 별로 하나의 API 셋을 제공할 수 있으며, 타이젠(tizen)의 경우, 플랫폼 별로 두 개 이상의 API 셋을 제공할 수 있다.
어플리케이션 370(예: 어플리케이션 프로그램 147)은, 예를 들면, 홈 371, 다이얼러 372, SMS/MMS 373, IM(instant message) 374, 브라우저 375, 카메라 376, 알람 377, 컨택트 378, 음성 다이얼 379, 이메일 380, 달력 381, 미디어 플레이어 382, 앨범 383, 또는 시계 384, 건강 관리(health care)(예: 운동량 또는 혈당 등을 측정), 또는 환경 정보 제공(예: 기압, 습도, 또는 온도 정보 등을 제공) 등의 기능을 수행할 수 있는 하나 이상의 어플리케이션을 포함할 수 있다.
한 실시 예에 따르면, 어플리케이션 370은 전자 장치(예: 전자 장치 100)와 다른 전자 장치(예: 제1 외부 전자 장치 102 및 제2 외부 전자 장치 104) 사이의 정보 교환을 지원하는 어플리케이션(이하, 설명의 편의 상, "정보 교환 어플리케이션")을 포함할 수 있다. 정보 교환 어플리케이션은, 예를 들면, 외부 전자 장치에 특정 정보를 전달하기 위한 알림 전달(notification relay) 어플리케이션, 또는 외부 전자 장치를 관리하기 위한 장치 관리(device management) 어플리케이션을 포함할 수 있다.
예를 들면, 알림 전달 어플리케이션은 전자 장치의 다른 어플리케이션(예: SMS/MMS 어플리케이션, 이메일 어플리케이션, 건강 관리 어플리케이션, 또는 환경 정보 어플리케이션 등)에서 발생된 알림 정보를 다른 전자 장치(예: 제1 외부 전자 장치 102 및 제2 외부 전자 장치 104)로 전달하는 기능을 포함할 수 있다. 또한, 알림 전달 어플리케이션은, 예를 들면, 외부 전자 장치로부터 알림 정보를 수신하여 사용자에게 제공할 수 있다.
장치 관리 어플리케이션은, 예를 들면, 전자 장치와 통신하는 다른 전자 장치(예: 제1 외부 전자 장치 102 및 제2 외부 전자 장치 104)의 적어도 하나의 기능(예: 외부 전자 장치 자체(또는, 일부 구성 부품)의 턴-온/턴-오프 또는 디스플레이의 밝기(또는, 해상도) 조절), 외부 전자 장치에서 동작하는 어플리케이션 또는 외부 전자 장치에서 제공되는 서비스(예: 통화 서비스 또는 메시지 서비스 등)를 관리(예: 설치, 삭제, 또는 업데이트)할 수 있다.
한 실시 예에 따르면, 어플리케이션 370은 다른 전자 장치(예: 제1 외부 전자 장치 102 및 제2 외부 전자 장치 104)의 속성(에 따라 지정된 어플리케이션(예: 모바일 의료 기기의 건강 관리 어플리케이션 등)을 포함할 수 있다. 한 실시 예에 따르면, 어플리케이션 370은 외부 전자 장치(예: 제1 외부 전자 장치 102, 제2 외부 전자 장치 104, 또는 서버 106)로부터 수신된 어플리케이션을 포함할 수 있다. 한 실시 예에 따르면, 어플리케이션 370은 프리로드 어플리케이션(preloaded application) 또는 서버로부터 다운로드 가능한 제3자 어플리케이션(third party application)을 포함할 수 있다. 도시된 실시 예에 따른 프로그램 모듈 310의 구성요소들의 명칭은 운영 체제의 종류에 따라서 달라질 수 있다.
다양한 실시 예에 따르면, 프로그램 모듈 310의 적어도 일부는 소프트웨어, 펌웨어, 하드웨어, 또는 이들 중 적어도 둘 이상의 조합으로 구현될 수 있다. 프로그램 모듈 310의 적어도 일부는, 예를 들면, 프로세서(예: 프로세서 210)에 의해 구현(implement)(예: 실행)될 수 있다. 프로그램 모듈 310의 적어도 일부는 하나 이상의 기능을 수행하기 위한, 예를 들면, 모듈, 프로그램, 루틴, 명령어 세트(sets of instructions) 또는 프로세스 등을 포함할 수 있다.
도 4는 본 발명의 다양한 실시 예에 따른, 전자 장치의 블록도를 나타낸 도면이다.
도 4를 참조하면, 전자 장치는 하나 이상의 어플리케이션(예를 들어 제1 어플리케이션(404), 제2 어플리케이션(405)), 복수의 레이어(예를 들어, 제1 레이어(401), 제2 레이어(402), 및 제3 레이어(403) 등), 윈도우 컴포지터(windows compositor)(410), 디스플레이 컨트롤러(420), 및 디스플레이 패널(430)을 포함할 수 있다. 본 발명의 다양한 실시 예에 따르면, 제1 레이어(401)는 제1 어플리케이션(404)에 포함되거나 또는 제1 어플리케이션(404)에 대응되어 생성된 것일 수 있고, 제2 레이어(402) 및 제3 레이어(403)는 제2 어플리케이션(405)에 포함되거나 또는 제2 어플리케이션(405)에 대응되어 생성된 것일 수 있다. 일 실시 예에 따르면 레이어(예를 들어, 제1 레이어(401) 내지 제3 레이어(403))는 어플리케이션(예를 들어, 제1 어플리케이션(404) 및 제2 어플리케이션(405)) 외부(예: 윈도우 컴포지터(410))에 포함될 수도 있다. 윈도우 컴포지터(410)는 버퍼 관리 모듈(buffer managing module)(412), 레이어 선택 모듈(layer select module)(414), 합성 모듈(composition module)(416) 및 레이어 관리 모듈(layer manager module)(418)을 포함할 수 있다. 본 발명의 다양한 실시 예에 따르면, 상기 복수의 어플리케이션(404, 405), 복수의 레이어(401, 402, 403), 윈도우 컴포지터(410), 디스플레이 컨트롤러(420), 및 디스플레이 패널(430)은 프로세서(예: 도 1의 프로세서(120))에 의해 동작될 수 있다.
본 발명의 다양한 실시 예에 따르면, 프레임워크(또는, 운영체제)의 종류에 따라, 윈도우 컴포지터(410)는 합성 모듈(416)을 의미하는 용어로 사용될 수도 있다. 예를 들어, 버퍼 관리 모듈(412), 또는 레이어 선택 모듈(414) 은 윈도우 컴포지터(410) 외부에 배치될 수 있다. 다양한 실시예에 따르면, 상기 복수의 모듈들(410, 412, 414, 416, 418)은 하나 또는 그 이상의 모듈로 통합 또는 분할되어 구현될 수도 있다. 예를 들어 합성 모듈(416)과 레이어 관리 모듈(418)은 하나의 모듈(예: surface flinger)로 구현될 수 있다.
종래 전자 장치는 적어도 하나의 어플리케이션이 그래픽 버퍼에 생성한(드로잉한) 복수의 이미지(또는, 그래픽 정보)들을 합성 모듈을 사용하여 하나의 이미지로 합성하고 합성된 이미지를 메모리의 지정된(specified) 영역(예: 프레임 버퍼)에 저장할 수 있다. 이 때 합성 모듈이 수행하는 합성은, 그래픽 버퍼에 저장된 이미지를 프레임 버퍼로 복사(copy)하는 동작을 의미할 수 있다. 전자 장치는 상기 지정된 영역에 저장된 이미지를 디스플레이 컨트롤러를 통해 디스플레이 패널에 출력할 수 있다.
전자 장치에 의해 어플리케이션(예: 제1 어플리케이션(404) 또는 제2 어플리케이션(405))이 실행되는 경우, 어플리케이션은 프레임워크 (예: 윈도우 컴포지터(410))에 어플리케이션 이미지를 드로잉(drawing)할 화면의 일부 영역을 요청할 수 있다. 프레임워크(예: 윈도우 컴포지터(410))는 각 어플리케이션들 요청에 대응하여 화면의 일부 영역을 할당하고, 할당된 영역에 대한 정보(예: 레이어)를 관리할 수 있다.
레이어는 어플리케이션에 대응하는 화면 영역(예: 레이어 영역 또는 서피스 영역)을 관리하는 정보이다. 예를 들어, 레이어는 지정된(specified) 자료구조에 대응하는 객체 또는 인스턴스로서, 어플리케이션 요청에 의해 생성되고 삭제될 수 있다. 실시예에서, 레이어는 어플리케이션이 이미지를 드로잉할 그래픽 버퍼의 주소, 프레임 영역(프레임 버퍼의 전체 영역에서 레이어가 차지하는 위치) 정보, 알파(alpha) 정보, z 정보 등을 포함할 수 있다. 본 명세서에서 사용되는 레이어라는 용어는 특정한 용어로 한정되지는 않으며, 레이어 대신 다른 용어(예를 들어, surface, window 등) 사용될 수도 있다. 도 4는, 일 실시 예로서, 제1 어플리케이션에 대응되어 생성된 제1 레이어(401)와 제2 어플리케이션에 대응되어 생성된 제2 레이어(402) 및 제3 레이어(403)를 나타내고 있다. 도 4에서는 어플리케이션들의 내부에 각 레이어들을 배치하였으나, 다양한 실시 예에 따르면, 레이어의 실체는 윈도우 컴포지터(410) 등 다른 모듈에 위치할 수 있다.
레이어 관리 모듈(418)(예를 들어, 프로세서)은 어플리케이션들에 의해 생성된 적어도 하나의 레이어를 관리할 수 있다. 예를 들어, 레이어 관리 모듈(418)은 어플리케이션들의 요청에 따라 레이어를 생성 또는 삭제할 수 있으며, 적어도 하나의 레이어를 리스트로 관리할 수 있다.
일 실시 예에 따르면, 어플리케이션이 실행되는 경우 레이어 관리 모듈(418)(예를 들어, 상기 프로세서)는 상기 어플리케이션에 대응하는 적어도 하나의 레이어를 생성할 수 있다. 일 실시 예에 따르면, 어플리케이션이 화면 구성을 변경하는 경우, 레이어 관리 모듈(418)은 화면 구성의 변경에 대응하여 레이어의 정보를 변경할 수 있다. 예를 들어, 지도 어플리케이션의 경우, 레이어 관리 모듈(418)은 지도 데이터를 제공하는 레이어, 및 상기 지도 어플리케이션에 이용되는 메뉴 레이어를 생성할 수 있다. 또한, 상기 레이어 관리 모듈(418)는 상기 지도 어플리케이션과 함께 디스플레이 패널(430)에 표시되는 상태바(status bar) 레이어를 생성할 수 있다. 또한, 상기 레이어 관리 모듈(418)은 어플리케이션 실행 중에 노티(notification)가 발생한 경우, 상기 노티에 대한 레이어를 더 생성할 수 있다.
본 발명의 다양한 실시 예에 따르면, 상기 어플리케이션은 어플리케이션 아이콘을 통해 실행되는 어플리케이션뿐만 아니라 어플리케이션 아이콘이 포함된 런처(laucher) 어플리케이션을 포함할 수도 있다. 상기 런처 어플리케이션의 실행 중에, 상기 레이어 관리 모듈(418)은 런처 레이어, 월페이퍼 레이어, 및 상태바(status bar) 레이어를 생성할 수 있다.
본 발명의 다양한 실시 예에 따르면, 어플리케이션(또는, 레이어)는 버퍼 관리 모듈(412)로 버퍼를 요청하고, 버퍼를 할당 받을 수 있다. 예를 들어, 어플리케이션(또는, 레이어)는 버퍼 관리 모듈(412)로부터 dequeueBuffer 방법으로 버퍼를 할당 받을 수 있다. 상기 버퍼는 버퍼 관리 모듈(412)이 커널(예를 들어, 도 3의 커널(320))로부터 할당 받은 것일 수 있다. 상기 버퍼는 각각의 레이어 별로 할당될 수 있다. 예를 들어, 제2 어플리케이션(405)의 제2 레이어(402)에 대응되는 버퍼와 제2 어플리케이션(405)의 제3 레이어(403)에 대응되는 버퍼는 별도로 할당될 수 있다.
본 발명의 다양한 실시 예에 따르면, 버퍼 관리 모듈(412)은 레이어에 대한 버퍼가 요청(dequeue)되면, 버퍼가 요청된 레이어가 타겟 레이어인지 확인할 수 있다. 타겟 레이어는, 예를 들어, 그래픽 버퍼를 통하지 않고 프레임 버퍼로 바로 전달될 이미지와 관련된 레이어일 수 있다. 레이어가 타겟 레이어인지 또는 타겟 레이어가 아닌지는 레이어 선택 모듈(414)에 의해 결정될 수 있다. 본 발명의 다양한 실시 예에 따르면, 레이어 선택 모듈(414)은 레이어 관리 모듈(418)에 의해 관리되는 레이어가 타겟 레이어인지 또는 타겟 레이어가 아닌지 결정할 수 있다. 일 실시 예에 따르면, 레이어 선택 모듈(414)은 이미지(예: 어플리케이션이 버퍼에 드로잉한 이미지)의 업데이트 빈도, 이미지 사이즈, 요청된 버퍼 사이즈, 기 설정된 타겟 레이어 리스트에 포함되는지 여부, 레이어(또는, 레이어와 관련된 이미지)가 서로 겹치는지 여부 및 z-order 중 적어도 하나에 기초하여 타겟 레이어를 결정할 수 있다. 예를 들어, 레이어 선택 모듈(414)은 이미지 업데이트 빈도가 지정된 조건 이상이거나, 요청된 버퍼 사이즈가 프레임 버퍼 사이즈 이하이거나, 이미지 사이즈가 지정된 사이즈 이상이거나, 다른 레이어(또는, 이미지)와 겹치지 않거나, 또는 z-order가 가장 낮은 레이어를 타겟 레이어로 결정할 수 있다. 레이어 선택 모듈(414)은 레이어가 타겟 레이어인지 여부를 지정된 주기에 따라 반복적으로 판단할 수 있다. 즉, 특정 레이어가 타겟 레이어인지 여부는 시간의 흐름에 따라 변경될 수 있다. 예를 들어, 타겟 레이어가 아니라고 판단된 레이어의 업데이트 빈도가 지정된 조건 이상이 되면 타겟 레이어라고 판단될 수 있다. 다양한 실시 예에 따르면, 레이어 선택 모듈(414)은 상술한 정책들에 따라 0 개 또는 1개 이상의 타겟 레이어를 선택할 수 있으며, 타겟 레이어로 선택되지 않은 레이어들은 비 타겟 레이어로 구분될 수 있다.
일 실시 예에 따르면, 버퍼 관리 모듈(412)은 레이어가 타겟 레이어이면 프레임 버퍼의 적어도 일부 영역을 레이어에 할당하고, 레이어가 타겟 레이어가 아니면 버퍼 관리 모듈(412)에서 생성한(예를 들어, 버퍼큐에서 할당받은)그래픽 버퍼를 레이어에 할당할 수 있다. 즉, 어플리케이션 또는 레이어가 그래픽 버퍼를 요청하더라도 레이어가 타겟 레이어이면 프레임 버퍼가 할당될 수 있다.
일 실시 예에 따르면, 버퍼 관리 모듈(412)은 그래픽 버퍼를 생성하고 관리할 수 있다. 어플리케이션 또는 레이어가 버퍼 관리 모듈(412)에 버퍼를 요청(dequeue) 할 수 있다. 버퍼 관리 모듈(412)은 버퍼가 요청된 레이어가 타겟 레이어가 아니면 레이어에 그래픽 버퍼를 생성(또는 할당)해 줄 수 있다. 버퍼 관리 모듈(412)은 다중 버퍼링(예: 더블 버퍼, 트리플 버퍼) 방식에 따라, 하나의 레이어에 대해 복수의 그래픽 버퍼를 할당할 수 있다. 그리고 vsync 주기에 따라, 예를 들어 flip 방식으로, 하나의 레이어에 할당된 복수의 버퍼를 서로 번갈아 사용할 수 있다.
어플리케이션은 레이어에 할당된 버퍼(예: 그래픽 버퍼 또는 프레임 버퍼)에 이미지를 드로잉할 수 있다. 드로잉이란, 예를 들어, 버퍼에 이미지 데이터가 전달(또는, 라이팅(write))되는 동작일 수 있다. 상기 이미지는 어플리케이션이 디스플레이 패널(430)을 통해 제공하고자 하는 이미지일 수 있다. 일 실시 예에 따르면, 상기 이미지는 전체 프레임 영역 중 레이어가 차지하는 영역의 좌표에 따라 버퍼에 드로잉될 수 있다. 예를 들어, 특정 레이어의 프레임 영역이 800 * 1280의 해상도를 기준으로 x start = 0, x end = 800, y start = 25, y end = 1280의 좌표를 갖고 있다면, 어플리케이션은 할당된 버퍼에 해당 좌표에 표시될 최종 이미지를 드로잉할 수 있다.
어플리케이션(또는 레이어)은 상기 이미지를 드로잉한 버퍼에 대한 정보(예: 좌표 정보)를 버퍼 관리 모듈(412)로 전송할 수 있다. 버퍼 관리 모듈(412)은 버퍼 영역에 드로잉된 이미지를 합성(composition) 대기 상태로 보관할 수 있다. 어플리케이션 또는 레이어는 버퍼 관리 모듈(412)로 출력 요청(queue) 할 수 있다. 버퍼 관리 모듈(412)은 상기 그래픽 버퍼 출력 요청에 대응하여 해당 그래픽 버퍼를 합성 대기 상태로 관리할 수 있다.
합성 모듈(416)은 각각의 레이어에 대해 어플리케이션(또는, 레이어)이 최종적으로 생성한 이미지 관련 정보가 저장된 그래픽 버퍼의 주소, 프레임 영역(프레임 버퍼의 전체 영역에서 레이어 영역이 차지하는 위치) 등을 통합적으로 관리할 수 있다.
합성 모듈(416)은 프레임 레이트가 60Hz 일 경우 16.6ms 마다 생성되는 vsync에 의해 트리거되어, 버퍼 관리 모듈(412)에 합성 대기 상태의 그래픽 버퍼가 있는지 여부를 확인할 수 있다. 만일, 합성 대기 상태의 그래픽 버퍼가 없을 경우 합성 모듈(416)은 다음 vsync까지 sleep 상태로 들어가고, 합성 대기 상태의 그래픽 버퍼가 있을 경우 합성을 수행할 수 있다. 합성 모듈(416)에서는 합성을 수행하기 위해 2D 혹은 3D 그래픽 라이브러리를 이용할 수 있다. 상기 그래픽 라이브러리는, 예를 들어, OpenGL ES, Direct3D, 및 Stage3D 등을 포함할 수 있다. 발명의 한 실시예에서, 합성 모듈(416)은 GPU를 사용하여 합성을 수행할 수 있다.
합성 모듈(416)은 (예를 들어, dequeueBuffer 방법을 통해) 버퍼 관리 모듈(412)로부터 프레임 버퍼를 할당 받을 수 있다. 합성 모듈(416)은 할당 받은 프레임 버퍼에 이미지를 합성할 수 있다. 합성 모듈(416)의 동작은 타겟 레이어의 유무에 따라 달라질 수 있다. 타겟 레이어가 있는 경우, 합성 모듈(416)은 적어도 하나 이상의 비(non)타겟 레이어가 이미지를 드로잉한 그래픽 버퍼를 상기 타겟 레이어가 이미지를 드로잉한 프레임 버퍼에 (예를 들어, 메모리 카피 방식으로) 합성할 수 있다. 이 경우, 상기 타겟 레이어는 그래픽 버퍼를 할당 받은 바가 없으므로, 합성 모듈(416)은 상기 타겟 레이어에 대한 그래픽 버퍼의 합성을 스킵할 수 있다. 타겟 레이어가 없는 경우, 합성 모듈(416)은 합성 대기 상태의 각 비타겟 레이어가 이미지를 드로잉한 그래픽 버퍼를 프레임 버퍼에 합성할 수 있다.
합성 모듈(416)은 합성이 완료된 프레임 버퍼에 대한 정보를 디스플레이 컨트롤러(420)에 전송할 수 있다. 디스플레이 컨트롤러(420)는 상기 전송 받은 프레임 버퍼를 제1 프레임 버퍼로 설정하고, 기존에 제공되던 프레임 버퍼를 제2 프레임 버퍼로 설정할 수 있다. 본 발명의 다양한 실시 예에 따르면, 디스플레이 컨트롤러(420)는 상기 언급한 바와 같이 2개의 버퍼를 이용하는 더블 버퍼링(double buffering) 기술뿐만 아니라, 3개의 버퍼를 이용하는 트리플 버퍼링(triple buffering) 기술 또는 4개 이상의 버퍼를 이용하는 기술을 이용할 수도 있다.
디스플레이 컨트롤러(420)는 매 vsync 마다 프레임 버퍼에 있는 이미지를 DMA로 fetch 하여, 물리적으로 연결된 디스플레이 패널(430)으로 전송할 수 있다. 디스플레이 컨트롤러(420)와 디스플레이 패널(430)을 물리적으로 연결하는 인터페이스는, 예를 들어, MIPI-DSI, HDMI, 및 eDP (embedded Display Port) 등을 포함할 수 있다. 디스플레이 컨트롤러(420)는 각 인터페이스의 프로토콜에 맞게 프레임 버퍼의 이미지를 패키징하여 디스플레이 패널(430)로 전송할 수 있다.
GPU 합성은 소모전류를 증가시키고, 전체 그래픽 성능을 저하시킬 수 있는 바, 타겟 레이어를 그래픽 버퍼에 드로잉한 후 프레임 버퍼로 합성하는 것은 상기 문제를 야기할 수 있다. 따라서, 본 발명의 다양한 실시 예는 상기 문제를 해결하기 위해 상기 타겟 레이어를 처음부터 프레임 버퍼에 드로잉을 함으로써 GPU 합성을 최소화할 수 있다.
도 5는 본 발명의 다양한 실시 예에 따른, 제1 레이어 및 제2 레이어의 상태에 따른 합성 케이스를 나타낸 표이다.
전술한 바에 따르면, 합성 모듈(416)은 디스플레이의 vsync 주기에 따라 트리거되어, 버퍼 관리 모듈(412)에 합성 대기 상태의 그래픽 버퍼가 있는지 여부를 확인할 수 있다. 만일, 합성 대기 상태의 그래픽 버퍼가 없을 경우 합성 모듈(416)은 합성을 수행하지 않고, 합성 대기 상태의 그래픽 버퍼가 있을 경우 합성을 수행할 수 있다.
도 5를 참조하면, 제1 레이어(401) 및 제2 레이어(402)의 상태(또는, 레이어에 대응하는 버퍼의 상태)는 Drawing, Queued, 또는 No change 중 하나일 수 있다. 예를 들어, Drawing 상태는 어플리케이션 또는 레이어가 버퍼에 이미지를 드로잉하는 상태일 수 있다. 또한, Queued 상태는 어플리케이션 또는 레이어가 버퍼에 드로잉을 완료한 상태(드로잉을 완료한 버퍼의 합성 대기 상태)일 수 있다. 또한, No change 상태는 이미지의 변화가 없는 상태일 수 있다.
본 발명의 다양한 실시 예에 따르면, 제1 레이어(401)는 타겟 레이어이고, 제2 레이어(402)는 비타겟 레이어일 수 있다. 제1 레이어(401)는 Queued 상태이고, 제2 레이어(402)도 Queued 상태인 경우, 제1 합성 케이스가 적용될 수 있다. 즉, 제1 레이어(401)는 프레임 버퍼를 할당 받아 이미지 드로잉을 완료하고, 제2 레이어(402)는 그래픽 버퍼를 할당 받아 이미지 드로잉을 완료한 상태일 수 있다. 제1 레이어(401)는 Queued 상태이고, 제2 레이어(402)는 No change 또는 Drawing 상태인 경우, 제2 합성 케이스가 적용될 수 있다. 제1 레이어(401)는 No change 상태이고, 제2 레이어(402)는 Queued 상태인 경우, 제3 합성 케이스가 적용될 수 있다. 제1 레이어(401)는 Drawing 상태이고, 제2 레이어(402)는 Queued 상태인 경우, 제4 합성 케이스가 적용될 수 있다. 또한, 제1 레이어(401)는 No change 상태이고, 제2 레이어(402)는 No change 또는 Drawing 상태인 경우, 합성을 수행하지 않을 수 있다. 나아가, 제1 레이어(401)는 Drawing 상태이고, 제2 레이어(402)는 No change 또는 Drawing 상태인 경우, 합성을 수행하지 않을 수 있다. 도 5에 도시된 다양한 합성 케이스에 대해서는 도 6을 참조하여 구체적으로 설명하기로 한다.
상술한 실시 예에 따르면, 레이어 선택 모듈(414)은 이미지 업데이트 빈도가 높은 레이어를 타겟 레이어로 선택하고, 이미지 업데이트 빈도가 낮은 레이어를 비 타겟 레이어로 선택할 수 있다. 즉, 타겟 레이어인 제1 레이어는 상대적으로 Queued 상태가 자주 되고, 비 타겟 레이어인 제2 레이어는 상대적으로 Queued 상태가 적게 될 수 있다. 일 실시 예에 따르면, 제1 레이어 및 제2 레이어가 모두 Queued 상태가 되는 제1 합성 케이스의 발생 빈도는 제2 합성 케이스 대비 상대적으로 낮을 수 있다. 그리고 제1 레이어는 합성을 수행할 필요가 없는 상태(No change 또는 Drawing 상태)인데, 제2 레이어만 합성이 필요한 Queued 상태가 되는 제3 합성케이스의 발생 빈도 또한, 제2 합성 케이스 대비 상대적으로 낮을 수 있다. 그리고 제1 레이어만 Queued 상태가 되는 제2 합성 케이스의 발생 빈도는 제1 또는 제3 합성케이스 대비 상대적으로 높을 수 있다.
종래 에는, 제1 레이어(401) 또는 제2 레이어(402) 중 어느 하나라도 Queued 상태가 되면, 합성 모듈(416)은 그래픽 라이브러리(419)를 사용하여 복수의 레이어 버퍼들의 합성 동작을 수행하였다. 본 발명의 실시 예에 따르면, 타겟 레이어로 선정된 제1 레이어(401)가 Queued 상태가 되더라도, 비 타겟 레이어인 제2 레이어(402)가 합성이 필요하지 않은 No change 또는 Drawing 상태라면, 합성 모듈(416)은 제1 레이어(401)에 대해 그래픽 라이브러리(419)를 사용한 합성 동작을 수행하지 않을 수 있다. 예를 들어, 비타겟 레이어와 타겟 레이어의 프레임 영역이 겹치지 않는 경우에는, 합성 모듈(416)은 그래픽 라이브러리(419)를 사용한 합성 동작을 수행하지 않더라도, 어플리케이션이 타겟 레이어에 대응하는 이미지를 프레임 버퍼에 드로잉함으로써 최종 이미지가 생성할 수 있다. 다만, 비타겟 레이어와 타겟 레이어의 프레임 영역이 겹치는 경우에는, 어플리케이션이 드로잉한 이미지에 의해 비타겟 레이어의 프레임 영역이 변경될 수 있으므로, 비타겟 레이어의 합성이 필요하지 않은 상태라고 하더라도 합성 모듈(416)에 의한 합성이 수행될 수 있다.
도 5에 도시된 각각의 레이어는 다중 버퍼링 방식에 따라 복수의 버퍼(예: 두 개 또는 세 개)를 할당 받을 수 있으며, 도 5에 도시된 버퍼의 상태는 각각의 레이어에 할당된 복수의 버퍼 중 현재 사용되는 또는 사용될 버퍼의 상태를 나타낼 수 있다.
도 6의 (a) 및 도 6의 (b)는 본 발명의 다양한 실시 예에 따른, 다양한 합성 케이스를 시간의 흐름에 따라 나타낸 도면이다.
도 6의 (a) 및 도 6의 (b)를 참조하면, 합성 모듈(630)(예를 들어, 도 4의 합성 모듈(416))은 상태바(status bar) 레이어(610) 및 지도(maps) 레이어(620) 각각에서 드로잉한 이미지를 프레임 버퍼에 합성할 수 있다. 본 발명의 다양한 실시 예에 따르면, 상태바 레이어(610)는 비타겟 레이어(예: 도 5의 제2 레이어)이고, 지도 레이어(620)는 타겟 레이어(예: 도 5의 제1 레이어)일 수 있다.
도 6의 (a)의 time 1(t1)은 도 5의 제1 합성 케이스에 대응될 수 있다. 제1 합성 케이스는 타겟 레이어(예: 지도 레이어(620)) 및 비타겟 레이어(예: 상태바 레이어(610)) 각각이 자신에게 할당된 버퍼에 드로잉을 완료하고 해당 버퍼를 버퍼 관리 모듈에 돌려준 Queued 상태일 수 있다. 예를 들어, 상태바 레이어(610)는 제1 상태바 이미지(611)를 제1 그래픽 버퍼(graphic buffer 0)에 드로잉 완료(queued)한 상태일 수 있다. 또한, 지도 레이어(620)는 제1 지도 이미지(621)를 제1 프레임 버퍼(frame buffer 0)에 드로잉 완료(queued)한 상태일 수 있다. 합성 모듈(630)은 제1 지도 이미지(621)가 드로잉된 제1 프레임 버퍼(frame buffer 0)에 제1 상태바 이미지(611)를 합성시켜 제1 합성 이미지(631)를 생성할 수 있다.
도 6의 (a)의 time 2(t2)은 도 5의 제2 합성 케이스에 대응될 수 있다. 제2 합성 케이스는 타겟 레이어(예: 지도 레이어(620))는 드로잉을 완료한 상태이고, 비타겟 레이어(예: 상태바 레이어(610))는 이미지 업데이트가 없어 드로잉을 수행하지 않거나 드로잉을 수행하는 상태일 수 있다. 예를 들어, 상태바 레이어(610)는 제2 그래픽 버퍼(graphic buffer 1)에 제2 상태바 이미지(613)의 드로잉을 수행(dequeued)하는 상태이고, 지도 레이어(620)는 제2 프레임 버퍼(frame buffer 1)에 제2 지도 이미지(623)의 드로잉을 완료(queued)한 상태일 수 있다. 즉, time 1(t1)과 time 2(t2) 사이에 상태바 이미지 및 지도 이미지에 대한 업데이트가 발생하였고, time 2(t2)에 상태바 레이어(610)는 제2 그래픽 버퍼(graphic buffer 1)에 제2 상태바 이미지(613)의 드로잉을 수행하는 중이고, 지도 레이어(620)는 제2 프레임 버퍼(frame buffer 1)에 제2 지도 이미지(623)의 드로잉을 완료한 상태일 수 있다. 합성 모듈(630)은 제2 그래픽 버퍼(graphic buffer 1)에 제2 상태바 이미지(613)가 드로잉 중인 상태에서는 제2 상태바 이미지(613)를 합성할 수 없으므로, 제2 지도 이미지(623)가 드로잉된 제2 프레임 버퍼(frame buffer 1)에 제1 그래픽 버퍼(graphic buffer 0)에 드로잉된 제1 상태바 이미지(611)를 합성시켜 제2 합성 이미지(633)를 생성할 수 있다. 본 발명의 다양한 실시 예에 따르면, 타겟 레이어는 업데이트 빈도에 의해 결정될 수 있으므로 사용자의 일반적인 사용환경에서는 타겟 레이어에 대해서만 이미지 업데이트가 완료되는 제2 합성 케이스가 가장 빈번하게 발생할 수 있다.
제2 합성 케이스에 따르면, 제2 지도 이미지(623)는 프레임 버퍼에만 생성되는 것으로서, 제2 합성 이미지(633)의 생성 과정에서 제1 그래픽 버퍼(graphic buffer 0)에 드로잉된 제1 상태바 이미지(611)에 대해서만 이미지의 복사가 수행될 수 있다. 즉, 가장 빈번하게 발생할 수 있는 제2 합성 케이스에서 메모리 카피를 최소화 함으로써 소모 전류를 감소시키고 그래픽 성능을 향상시킬 수 있다.
도 6의 (b)의 time 3(t3)은 도 5의 제3 합성 케이스에 대응될 수 있다. 제3 합성 케이스는 타겟 레이어(예: 지도 레이어(620))는 이미지 업데이트가 없어 드로잉을 수행하지 않는 상태이고, 비타겟 레이어(예: 상태바 레이어(610))는 드로잉을 완료한 상태일 수 있다. 예를 들어, 상태바 레이어(610)는 제2 그래픽 버퍼(graphic buffer 1)에 제2 상태바 이미지(613)의 드로잉을 완료(queued)한 상태이고, 지도 레이어(620)는 이미지 업데이트가 없는 상태일 수 있다. 즉, 상태바 레이어(610)는 time 1(t1)와 time 2(t2)사이에 발생한 상태바 이미지의 업데이트에 따라 time 2(t2)와 time 3(t3) 사이에 제2 그래픽 버퍼(graphic buffer 1)에 제2 상태바 이미지(613)의 드로잉을 완료할 수 있다. 합성 모듈(630)은 제2 프레임 버퍼(frame buffer 1)에 드로잉된 제2 지도 이미지(623)를 제3 프레임 버퍼(frame buffer 2)에 복사하고, 제2 지도 이미지(623)가 드로잉된 제3 프레임 버퍼(frame buffer 2)에 제2 그래픽 버퍼(graphic buffer 1)에 드로잉된 제2 상태바 이미지(613)를 합성시켜 제3 합성 이미지(635)를 생성할 수 있다.
도 6의 (b)의 time 4(t4)은 도 5의 제4 합성 케이스에 대응될 수 있다. 제4 합성 케이스는 타겟 레이어(예: 지도 레이어(620))는 드로잉을 수행하는 상태이고, 비타겟 레이어(예: 상태바 레이어(610))는 드로잉을 완료한 상태일 수 있다. 예를 들어, 상태바 레이어(610)는 제3 그래픽 버퍼(graphic buffer 2)에 제3 상태바 이미지(615)의 드로잉을 완료한 상태이고, 지도 레이어(620)는 제1 프레임 버퍼(frame buffer 0)에 제3 지도 이미지(625)의 드로잉을 수행하는 상태일 수 있다. 즉, time 1(t3)과 time 4(t2) 사이에 상태바 이미지 및 지도 이미지에 대한 업데이트가 발생하였고, time 4(t4)에 상태바 레이어(610)는 제3 그래픽 버퍼(graphic buffer 2)에 제3 상태바 이미지(615)의 드로잉을 완료한 상태이고, 지도 레이어(620)는 제1 프레임 버퍼(frame buffer 0)에 제3 지도 이미지(625)의 드로잉을 수행하는 상태일 수 있다. 합성 모듈(630)은 제3 프레임 버퍼(frame buffer 2)에 드로잉된 제2 지도 이미지(623)를 제2 프레임 버퍼(frame buffer 1)에 복사하고, 제2 지도 이미지(623)가 드로잉된 제2 프레임 버퍼(frame buffer 1)에 제3 그래픽 버퍼(graphic buffer 2)에 드로잉된 제3 상태바 이미지(615)를 합성시켜 제4 합성 이미지(637)를 생성할 수 있다.
도 6의 (a) 및 도 6의 (b)를 참조하여 설명한 실시 예에서는 트리플 버퍼 방식에서의 동작을 설명하였으나 본 발명은 레이어에 할당된 버퍼의 개수에는 제한이 없으며 더블 버퍼 방식 또는 하나의 레이어에 네 개 이상의 버퍼가 할당되는 방식에서도 본 발명이 적용될 수 있다.
도 7은 본 발명의 다양한 실시 예에 따른, 전자 장치의 각 구성 및 각 구성을 통해 수행되는 동작을 나타낸 도면이다.
동작 710에서, 레이어 선택 모듈(414)은 적어도 하나의 어플리케이션(예: 도 4의 제1 어플리케이션(404) 및 제2 어플리케이션(405))에 대응되어 생성된 복수의 레이어(예: 도 4의 제1 레이어(401) 내지 제3 레이어(403) 중 타겟 레이어를 선택할 수 있다.
본 발명의 다양한 실시 예에 따르면, 동작 710은 레이어 관리 모듈(418)이 관리하는 레이어 리스트의 정보 변경에 따라 수행될 수 있다. 예를 들어, 어플리케이션들이 화면 구성을 변경할 경우, 레이어 관리 모듈(418)은 화면 구성의 변경에 대응하여 레이어의 정보를 변경할 수 있다. 이에 따라 레이어 선택 모듈(414)은 타겟 레이어를 설정(또는, 재설정) 또는 해제할 수 있다.
동작 720에서, 적어도 하나의 어플리케이션(또는 레이어)은 버퍼 관리 모듈(412)에 버퍼 할당을 요청할 수 있다. 예를 들어, 어플리케이션(또는 레이어)는 dequeueBuffer 호출 방식으로 버퍼 관리 모듈(412)에 버퍼 할당을 요청할 수 있다.
동작 730에서, 버퍼 관리 모듈(412)은 상기 동작 720에 대응하여 타겟 레이어에는 프레임 버퍼의 일부 영역을 할당할 수 있고, 비타겟 레이어에는 그래픽 버퍼를 할당할 수 있다. 버퍼 관리 모듈(412)은 상기 버퍼를 요청한 어플리케이션(또는 레이어)에, 예를 들어, dequeueBuffer 호출에 대한 응답으로 그래픽 버퍼 또는 프레임 버퍼의 정보를 전달할 수 있다.
동작 740에서 어플리케이션(예: 도 4의 제1 어플리케이션(404) 및 제2 어플리케이션(405))은 각각 730 동작에 의해 주소가 수신된 버퍼에 이미지를 드로잉할 수 있다.
동작 750에서, 어플리케이션은 각각 동작 740에서 드로잉한 이미지(또는, 이미지가 드로잉된 버퍼의 주소)를 버퍼 관리 모듈(412)를 통해 합성 모듈(416)에게 전송할 수 있다. 예를 들어, 어플리케이션(또는 레이어)는 queueBuffer 호출 방식으로 버퍼 관리 모듈(412)에 버퍼를 전달할 수 있다. 이에 따라, 버퍼 관리 모듈(412) 및 합성 모듈(416)은 해당 버퍼가 합성 대기 상태가 되었다고 판단할 수 있다.
동작 760에서, 합성 모듈(416)은 프레임 버퍼에 그래픽 버퍼를 메모리 카피하여 이미지를 합성할 수 있다. 합성 모듈(416)은 그래픽 라이브러리(419)를 이용하여 수행될 수 있다. 이 경우, 그래픽 라이브러리(419)는 GPU를 이용할 수도 있다. 동작 760의 합성은, 예를 들어, GPU 합성일 수 있다.
본 발명의 다양한 실시 예에 따르면, 타겟 레이어는 업데이트 빈도에 의해 결정될 수 있으므로 사용자의 일반적인 사용 환경에서는 타겟 레이어에 대해서만 이미지 업데이트가 완료되는 합성 케이스(예: 도 5의 제2 합성 케이스)가 가장 빈번하게 발생할 수 있다. 타겟 레이어에 대응하는 이미지는 프레임 버퍼에만 생성되는 것으로서 이미지 합성 과정에서 메모리 카피를 최소화 함으로써 소모 전류를 감소시키고 그래픽 성능을 향상시킬 수 있다.
동작 770에서, 합성 모듈(416)은 디스플레이 컨트롤러(420)에게 동작 760에서 합성된 이미지(또는, 프레임 버퍼의 주소)를 전송할 수 있다. 동작 770의 전송은 둘 이상의 버퍼를 이용하는 Flip 방식일 수 있다.
동작 780에서 디스플레이 컨트롤러(420)는 동작 770에서 전송 받은 이미지를 디스플레이 패널(430)을 통해 제공할 수 있다.
도 8은 본 발명의 다양한 실시 예에 따른, 레이어 선택 모듈이 타겟 레이어를 선정하는 방법을 나타낸 순서도이다.
동작 810에서 레이어 관리 모듈(418)은 실행되고 있는 어플리케이션에 대응하는 복수의 레이어의 정보를 획득할 수 있다. 레이어 선택 모듈(414)은 레이어 관리 모듈(418)이 관리하는 복수의 레이어의 정보를 참조할 수 있다.
동작 820에서 레이어 선택 모듈(414)은 레이어 관리 모듈(418)로부터 레이어 정보를 참조하여 프레임 영역의 크기를 판단할 수 있다. 만일 프레임 영역의 크기가 임계값 이상인 경우, 동작 820이 수행된 후 동작 830으로 진행될 수 있고, 그렇지 않은 경우, 동작 860으로 진행될 수 있다. 일 실시 예에 따르면, 레이어 선택 모듈(414)은 복수의 레이어 중 타겟 레이어를 선택할 때, 프레임 영역의 크기에 기반하여 타겟 레이어를 선택할 수 있다. 예를 들어, 레이어 선택 모듈(414)은 화면에 실행되고 있는 복수의 레이어 중 화면 영역이 가장 큰 레이어를 타겟 레이어로 선택할 수 있다.
동작 830에서 레이어 선택 모듈(414)은 복수의 레이어 중 적어도 하나의 레이어의 업데이트 빈도를 모니터링 할 수 있다. 예를 들어, 레이어 선택 모듈(414)는 버퍼 관리 모듈(412)에 queueBuffer(750)가 발생하는 빈도를 측정하는 방식으로 레이어의 업데이트 빈도를 알 수 있다. 일 실시 예에따르면, 레이어 선택 모듈(414)은 임계값 이상의 프레임 영역을 갖는 레이어에 대한 업데이트 빈도를 모니터링할 수 있다.
동작 850에서 레이어 선택 모듈(414)은 타겟 레이어를 선택할 수 있다. 일 실시 예에 따르면, 레이어 선택 모듈(414)은 임계값 이상의 프레임 영역을 갖는 레이어 중 업데이트 빈도가 상대적으로 높은 레이어를 타겟 레이어로 선정할 수 있다. 일 실시 예에 따르면, 타겟 레이어를 선택하는 과정에서 동작 820은 생략될 수 있다. 즉, 레이어 선택 모듈(414)은 프레임 영역의 크기에 관계없이 업데이트 빈도에 기초하여 타겟 레이어를 선택할 수 있다. 예를 들어, 레이어 선택 모듈(414)은 업데이트 빈도가 가장 높은 레이어를 타겟 레이어로 선택할 수 있다.
동작 840의 판단 결과, 업데이트 빈도가 상대적으로 낮은 레이어에 대해서는 동작 830으로 진행되어 레이어 선택 모듈(414)이 주기적으로 업데이트 빈도를 모니터링할 수 있다.
동작 860에서 레이어 관리 모듈(418)은 레이어 정보가 변경되었는지 여부를 판단할 수 있다. 상기 레이어 정보가 변경되는 경우는, 예를 들어, 다른 어플리케이션이 실행되거나, 노티가 발생하거나, 실행 중인 어플리케이션을 종료하거나, 홈 화면으로 이동하는 등의 경우가 있을 수 있다. 일 실시 예에 따르면, 동작 860에서 레이어 정보 변경이 발생한 경우, 810 내지 850의 과정을 반복하여 새로운 타겟 레이어를 선택하거나 선택하지 않을 수 있다. 일 실시 예에 따르면 도 8의 과정에서 타겟 레이어가 결정되지 못하는 경우, 레이어 관리 모듈(418)에 속한 모든 레이어는 비 타겟 레이어로서 동작할 수 있다.
도 9는 본 발명의 다양한 실시 예에 따른, 레이어 선택 모듈이 타겟 레이어를 선정하는 방법을 나타낸 순서도이다.
동작 910에서 레이어 선택 모듈(414)은 실행되고 있는 어플리케이션에 대응하는 복수의 레이어의 정보를 획득할 수 있다.
동작 920에서 레이어 선택 모듈(414)은 레이어간 프레임 영역이 겹치는지 여부를 판단할 수 있다. 프레임 영역이 겹치는 경우 동작 920이 수행된 후 동작 980으로 진행될 수 있고, 그렇지 않은 경우 동작 930으로 진행될 수 있다.
동작 930에서 레이어 선택 모듈(414)은 어플리케이션(또는, 레이어)이 요청한 버퍼(예: 그래픽 버퍼)의 사이즈와 프레임 버퍼의 사이즈를 비교할 수 있다. 예를 들어, 레이어 선택 모듈(414)은 요청된 그래픽 버퍼 및 프레임 버퍼 각각에서 이미지를 드로잉할 수 있는 영역의 크기를 비교할 수 있다. 일 실시 예에 따르면, 그래픽 버퍼의 사이즈가 프레임 버퍼의 사이즈 이하이면, 동작 940으로 진행될 수 있고, 그렇지 않은 경우, 동작 980으로 진행될 수 있다. 어플리케이션이 요청한 그래픽 버퍼의 사이즈가 프레임 버퍼보다 큰 경우에는 프레임 버퍼에 이미지를 모두 드로잉할 수 없는 문제가 발생할 수 있다. 다른 실시 예에 따르면, 레이어 선택 모듈(414) 그래픽 버퍼의 사이즈와 프레임 버퍼의 사이즈가 동일한 경우에 동작 940으로 진행될 수 있고, 그렇지 않은 경우, 동작 980으로 진행될 수 있다. 크기가 다른 경우, offset을 맞춰야하는 문제가 발생하기 때문에 합성이 용이하지 않을 수 있다.
동작 940에서 레이어 선택 모듈(414)은 프레임 영역의 크기를 판단할 수 있다. 만일 프레임 영역의 크기가 임계값 이상인 경우, 동작 940은 동작 950으로 진행될 수 있고, 그렇지 않은 경우, 동작 940은 동작 980으로 진행될 수 있다.
동작 950에서 레이어 선택 모듈(414)은 임계값 이상의 프레임 영역을 갖는 레이어에 대한 업데이트 빈도를 모니터링할 수 있다.
동작 960에서 레이어 선택 모듈(414)은 동작 1240에서 임계값 이상의 프레임 영역을 갖는 레이어 중 업데이트 빈도가 상대적으로 높은 레이어를 동작 970에서 타겟 레이어로 선정할 수 있다.
동작 960의 판단 결과, 업데이트 빈도가 상대적으로 낮은 레이어에 대해서는 동작 950으로 진행되어 레이어 선택 모듈(414)이 주기적으로 업데이트 빈도를 모니터링할 수 있다.
동작 980에서 레이어 선택 모듈(414)은 레이어 정보가 변경되었는지 여부를 판단할 수 있다. 상기 레이어 정보가 변경되는 경우는, 예를 들어, 다른 어플리케이션이 실행되거나, 노티가 발생하거나, 실행 중인 어플리케이션을 종료하거나, 홈 화면으로 이동하는 등의 경우가 있을 수 있다.
일 실시 예에 따르면, 타겟 레이어를 선택하는 과정에서 동작 920 및 동작 930 중 하나는 생략될 수 있다. 즉, 레이어 선택 모듈(414)은 프레임 영역이 겹치는지 여부 또는, 그래픽 버퍼 및 프레임 버퍼의 크기에 관계없이 타겟 레이어를 선택할 수 있다.
도 10은 본 발명의 다양한 실시 예에 따른, 레이어 선택 모듈이 타겟 레이어를 선정하는 방법을 나타낸 순서도이다.
동작 1010에서 윈도우 컴포지터(410)(예:레이어 선택 모듈(414))은 실행되고 있는 어플리케이션에 대응하는 복수의 레이어의 정보를 획득할 수 있다.
동작 1020에서 레이어 선택 모듈(414)은 복수의 레이어 중 기설정된 타겟 레이어 리스트에 포함된 레이어가 있는지 판단할 수 있다. 상기 타겟 레이어 리스트에 포함된 레이어는 동작 1030에서 타겟 레이어로 선정될 수 있다. 상기 타겟 레이어 리스트에 포함된 레이어가 없는 경우, 동작 1040으로 진행될 수 있다. 예를 들어, 다양한 실시예에 따르면, 웹브라우저 어플리케이션의 적어도 일부 화면(예: 웹 브라우징 화면)에 대응되는 레이어, 지도 어플리케이션의 적어도 일부 화면(예: 지도 화면)에 대응되는 레이어, 동영상 플레이어의 적어도 일부 화면(예: 동영상 화면)에 대응되는 레이어, 카메라 어플리케이션의 프리뷰 화면에 대응되는 레이어 등이 상기 기설정된 타겟 레이어 리스트에 포함될 수 있다. 다양한 실시예에 따르면, 화면의 statusbar 화면 영역에 대응되는 레이어는 상기 기설정된 타겟 레이어 리스트에 포함되지 않을 수 있다.
동작 1040에서 윈도우 컴포지터(410)(예:레이어 선택 모듈(414))은 레이어 정보가 변경되었는지 여부를 판단할 수 있다. 상기 레이어 정보가 변경되는 경우는, 예를 들어, 다른 어플리케이션이 실행되거나, 노티가 발생하거나, 실행 중인 어플리케이션을 종료하거나, 홈 화면으로 이동하는 등의 경우가 있을 수 있다.
도 11은 본 발명의 다양한 실시 예에 따른, 싱글 윈도우와 멀티 윈도우에 따른 타겟 레이어 선정의 차이를 나타낸 도면이다.
도 11의 왼쪽에 도시된 도면 1110을 참조하면, 전자 장치는 상태바(1112)와 싱글 윈도우(1114), 예를 들어, 하나의 어플리케이션 실행화면을 디스플레이할 수 있다.
도 11의 오른쪽에 도시된 도면 1120을 참조하면, 전자 장치는 상태바(1122)와 멀티 윈도우(제1 멀티 윈도우(1124), 제2 멀티 윈도우(1126)), 예를 들어, 제1 어플리케이션 실행화면 및 제2 어플리케이션 실행화면을 디스플레이할 수 있다.
도면 1110에서 레이어 선택 모듈(414)는 싱글 윈도우(1114)의 레이어 크기가 상태바(1112)의 레이어 크기보다 크고 임계값 이상의 크기인 바, 싱글 윈도우(1114)의 레이어를 타겟 레이어로 선정할 수 있다.
도면 1120에서 제1 멀티 윈도우(1124) 및 제2 멀티 윈도우(1126)의 레이어 크기가 상태바(1112)의 레이어 크기보다 크고 임계값 이상의 크기인 바, 레이어 선택 모듈(예: 도 4의 414)는 제1 멀티 윈도우(1124) 및 제2 멀티 윈도우(1126)의 레이어 중 기설정된 타겟 레이어 리스트에 포함된 레이어가 있는지, 또는 각레이어의 업데이트 빈도를 모니터링하여 하나의 레이어를 타겟 레이어로 선정할 수 있다.
도 12는 본 발명의 다양한 실시 예에 따른, 그래픽 버퍼 또는 프레임 버퍼에 드로잉을 수행하는 방법을 나타낸 도면이다.
동작 1210에서 어플리케이션은 윈도우 컴포지터(410)에 어플리케이션의 레이어(예: 도 4의 제1 레이어(401), 제2 레이어(402) 또는 제3 레이어(403))에 대응하는 그래픽 버퍼를 요청할 수 있다.
동작 1220에서 윈도우 컴포지터(410)(예: 버퍼 관리 모듈(412))는 동작 1210에서 그래픽 버퍼를 요청한 레이어가 타겟 레이어인지 여부를 판단할 수 있다. 만일 레이어가 비타겟 레이어인 경우 윈도우 컴포지터(410)(예: 버퍼 관리 모듈(412))는, 동작 1230에서, 레이어에게 그래픽 버퍼를 할당할 수 있다. 만일 레이어가 타겟 레이어인 경우 윈도우 컴포지터(410)(예: 버퍼 관리 모듈(412))는, 동작 1235에서, 레이어에게 프레임 버퍼를 할당할 수 있다.
동작 1240에서 어플리케이션은 동작 1230 또는 동작 1235에서 할당 받은 버퍼(그래픽 버퍼 또는 프레임 버퍼)에 드로잉을 수행할 수 있다.
동작 1250에서 어플리케이션은, 예를 들어, 버퍼 관리 모듈(412)에 버퍼를 queueBuffer 호출 방식으로, 윈도우 컴포지터(410)에 버퍼에 드로잉이 완료되었음을 알릴 수 있다. 버퍼 관리 모듈(412)는 동작 1240에서 드로잉이 수행된 버퍼를 합성 대기 상태로 보관할 수 있다.
도 13은 본 발명의 다양한 실시 예에 따른, 그래픽 버퍼 및/또는 프레임 버퍼에 대해 합성을 수행하는 방법을 나타낸 순서도이다.
동작 1310에서 합성 모듈(416)은 전자 장치에서 수행되는 모든 레이어들을 나타낸 레이어 리스트를 조회할 수 있다.
동작 1320에서 합성 모듈(416)은 상기 레이어 리스트에 포함된 레이어 중 레이어 선택 모듈(414)에서 타겟 레이어로 선정된 레이어가 있는지 여부를 판단할 수 있다. 타겟 레이어가 없는 경우 동작 1330으로 진행될 수 있다. 타겟 레이어가 있는 경우 동작 1340으로 진행될 수 있다.
동작 1330에서 합성 모듈(416)은 프레임 버퍼를, 예를 들어, 블랙으로 초기화(클리어)할 수 있다. 타겟 레이어가 있는 경우에는, 상기 타겟 레이어가 프레임 버퍼에 드로잉을 수행했기 때문에 동작 1330을 수행하지 않는다.
동작 1340에서 합성 모듈(416)은, 예를 들어, z-order 순서에 따라서 합성을 위해 순차적으로 하나의 레이어를 선택할 수 있다.
동작 1350에서 합성 모듈(416)은 동작 1340에서 선택된 레이어가 타겟 레이어인지 여부를 판단할 수 있다. 동작 1340에서 선택된 레이어가 비타겟 레이어인 경우, 동작 1360으로 진행될 수 있다.
동작 1360에서 합성 모듈(416)은 동작 1340에서 선택된 레이어의 이미지를 프레임 버퍼에 합성시킬 수 있다. 동작 1340에서 선택된 레이어가 타겟 레이어인 경우에는, 상기 타겟 레이어가 프레임 버퍼에 드로잉을 수행했기 때문에 동작 1360을 수행하지 않는다.
동작 1370에서 합성 모듈(416)은 동작 1310에서 조회된 리스트 모두에 대해 합성이 수행되었는지 판단할 수 있다. 만일, 모든 레이어에 대해 합성이 수행되었다면 동작 1380에서 합성 모듈(416)은 디스플레이 컨트롤러(420)에게 프레임 버퍼를 전달 할 수 있다.
만일, 모든 레이어에 대해 합성이 수행되지 않았다면, 동작 1340으로 진행되고, 합성 모듈(416)은 아직 합성이 수행되지 않은 레이어에 대해 합성을 수행할 수 있다.
도 14는 본 발명의 다양한 실시 예에 따른, 어플리케이션 화면을 출력하는 방법을 나타낸 순서도이다.
동작 1410에서 윈도우 컴포지터(410)(예:레이어 선택 모듈(414))는 실행 중인 어플리케이션에 대응하는 적어도 하나의 레이어에 대한 정보를 획득할 수 있다.
동작 1420에서 레이어 선택 모듈(414)은 상기 실행 중인 어플리케이션에 대응하는 적어도 하나의 레이어 중 타겟 레이어를 선택할 수 있다. 일 실시 예에 따르면, 타겟 레이어는, 레이어가 사용할 그래픽 버퍼를 할당받을 때, 프레임 버퍼와 별도인 메모리 공간을 할당받지 않고, 프레임 버퍼로 할당된 메모리 공간의 적어도 일부 영역을 할당받는 레이어를 의미일 수 있다.
일 실시 예에 따르면, 발명의 다양한 구현 방법에서, 프로그램 코드는 타겟 레이어와 비타겟 레이어를 명시적으로 구분하여 작성되지 않을 수 있다. 그러나, 각 레이어들은 버퍼를 할당받는 방법에 따라 개념적으로 타겟 레이어와 비타겟 레이어를 사용한 것으로 이해될 수 있다.
동작 1430에서 버퍼 관리 모듈(412)은 각 어플리케이션의 레이어에게 프레임 버퍼 또는 그래픽 버퍼를 할당할 수 있다. 예를 들어, 동작 1420에서 타겟 레이어로 선택된 레이어에게는 프레임 버퍼가 할당될 수 있고, 비타겟 레이어에게는 그래픽 버퍼가 할당될 수 있다.
동작 1440에서 각 레이어는 동작 1430에서 할당 받은 버퍼에 이미지를 드로잉할 수 있다.
동작 1450에서 합성 모듈(416)은 이미지가 드로잉된 그래픽 버퍼들을 이미지가 드로잉된 프레임 버퍼에 메모리카피 형식으로 합성을 수행할 수 있다.
동작 1460에서 합성 모듈(416)은 디스플레이 컨트롤러(420)을 통해 디스플레이 패널(430)에 프레임 버퍼의 이미지를 출력할 수 있다.
본 문서에서 사용된 용어 "모듈"은, 예를 들면, 하드웨어, 소프트웨어 또는 펌웨어(firmware) 중 하나 또는 둘 이상의 조합을 포함하는 단위(unit)를 의미할 수 있다. "모듈"은, 예를 들면, 유닛(unit), 로직(logic), 논리 블록(logical block), 부품(component), 또는 회로(circuit) 등의 용어와 바꾸어 사용(interchangeably use)될 수 있다. "모듈"은, 일체로 구성된 부품의 최소 단위 또는 그 일부가 될 수 있다. "모듈"은 하나 또는 그 이상의 기능을 수행하는 최소 단위 또는 그 일부가 될 수도 있다. "모듈"은 기계적으로 또는 전자적으로 구현될 수 있다. 예를 들면,"모듈"은, 알려졌거나 앞으로 개발될, 어떤 동작들을 수행하는 ASIC(application-specific integrated circuit) 칩, FPGAs(field-programmable gate arrays) 또는 프로그램 가능 논리 장치(programmable-logic device) 중 적어도 하나를 포함할 수 있다.
다양한 실시 예에 따른 장치(예: 모듈들 또는 그 기능들) 또는 방법(예: 동작들)의 적어도 일부는, 예컨대, 프로그램 모듈의 형태로 컴퓨터로 읽을 수 있는 저장매체(computer-readable storage media)에 저장된 명령어로 구현될 수 있다. 상기 명령어가 프로세서(예: 프로세서 120)에 의해 실행될 경우, 상기 하나 이상의 프로세서가 상기 명령어에 해당하는 기능을 수행할 수 있다. 컴퓨터로 읽을 수 있는 저장매체는, 예를 들면, 메모리 130이 될 수 있다.
컴퓨터로 판독 가능한 기록 매체는, 하드디스크, 플로피디스크, 마그네틱 매체(magnetic media)(예: 자기테이프), 광기록 매체(optical media)(예: CD-ROM(compact disc read only memory), DVD(digital versatile disc), 자기-광 매체(magneto-optical media)(예: 플롭티컬 디스크(floptical disk)), 하드웨어 장치(예: ROM(read only memory), RAM(random access memory), 또는 플래시 메모리 등) 등을 포함할 수 있다. 또한, 프로그램 명령에는 컴파일러에 의해 만들어지는 것과 같은 기계어 코드뿐만 아니라 인터프리터 등을 사용해서 컴퓨터에 의해서 실행될 수 있는 고급 언어 코드를 포함할 수 있다. 상술한 하드웨어 장치는 다양한 실시 예의 동작을 수행하기 위해 하나 이상의 소프트웨어 모듈로서 작동하도록 구성될 수 있으며, 그 역도 마찬가지다.
다양한 실시 예에 따른 모듈 또는 프로그램 모듈은 전술한 구성요소들 중 적어도 하나 이상을 포함하거나, 일부가 생략되거나, 또는 추가적인 다른 구성요소를 더 포함할 수 있다. 다양한 실시 예에 따른 모듈, 프로그램 모듈 또는 다른 구성요소에 의해 수행되는 동작들은 순차적, 병렬적, 반복적 또는 휴리스틱(heuristic)한 방법으로 실행될 수 있다. 또한, 일부 동작은 다른 순서로 실행되거나, 생략되거나, 또는 다른 동작이 추가될 수 있다. 그리고 본 문서에 개시된 실시 예는 개시된, 기술 내용의 설명 및 이해를 위해 제시된 것이며, 본 문서에서 기재된 기술의 범위를 한정하는 것은 아니다. 따라서, 본 문서의 범위는, 본 문서의 기술적 사상에 근거한 모든 변경 또는 다양한 다른 실시 예를 포함하는 것으로 해석되어야 한다.

Claims (20)

  1. 어플리케이션으로부터 수신한 그래픽 정보를 저장하기 위한 그래픽 버퍼;
    디스플레이에 표시하기 위한 그래픽 정보를 저장하기 위한 프레임 버퍼; 및
    프로세서;를 포함하고, 상기 프로세서는,
    제1 레이어로부터 수신한 제1 그래픽 정보를 상기 그래픽 버퍼에 저장하고;
    제2 레이어로부터 수신한 제2 그래픽 정보를 상기 프레임 버퍼에 저장하고;
    상기 그래픽 버퍼에 저장된 상기 제1 그래픽 정보를 상기 프레임 버퍼에 저장하고; 및
    상기 프레임 버퍼에 저장된, 상기 제1 그래픽 정보 및 상기 제2 그래픽 정보를 상기 프로세서와 기능적으로 연결된 디스플레이를 통하여 동시에 표시하도록 설정된 전자 장치.
  2. 제1항에 있어서,
    상기 프로세서는,
    상기 제2 그래픽 정보의 갱신 빈도가 지정된 값 이상이면 상기 제2 그래픽 정보를 상기 프레임 버퍼에 저장하는 동작을 수행하도록 설정된 전자 장치.
  3. 제1항에 있어서,
    상기 프로세서는,
    상기 제2 레이어의 이미지 사이즈가 지정된 사이즈 이상이면 상기 제2 그래픽 정보를 상기 프레임 버퍼에 저장하는 동작을 수행하도록 설정된 전자 장치.
  4. 제1항에 있어서,
    상기 프로세서는,
    상기 제2 레이어에 대응하여 요청된 버퍼의 사이즈가 상기 프레임 버퍼의 사이즈 이하이면 상기 제2 그래픽 정보를 상기 프레임 버퍼에 저장하는 동작을 수행하도록 설정된 전자 장치.
  5. 제1항에 있어서,
    상기 프로세서는,
    상기 제1 그래픽 정보의 이미지와 상기 제2 그래픽 정보의 이미지가 서로 겹치는 영역이 존재하지 않으면 상기 제2 그래픽 정보를 상기 프레임 버퍼에 저장하는 동작을 수행하도록 설정된 전자 장치.
  6. 제1항에 있어서,
    상기 프로세서는,
    상기 제2 레이어가 기설정된 타겟 레이어 리스트에 포함되어있으면 상기 제2 그래픽 정보를 상기 프레임 버퍼에 저장하는 동작을 수행하도록 설정된 전자 장치.
  7. 제1항에 있어서,
    상기 프로세서는,
    상기 프레임 버퍼에 저장된 상기 제1 그래픽 정보를 상기 디스플레이의 제1 영역에 표시하고; 및
    상기 프레임 버퍼에 저장된 상기 제2 그래픽 정보를 상기 디스플레이의 제2 영역에 표시하도록 설정된 전자 장치.
  8. 제1항에 있어서,
    상기 프로세서는,
    상기 제2 레이어로부터 수신한 상기 제2 그래픽 정보를 상기 그래픽 버퍼 또는 다른 그래픽 버퍼를 거치지 않고 상기 프레임 버퍼에 저장하도록 설정된 전자 장치.
  9. 제1항에 있어서,
    상기 제1 레이어 및 상기 제2 레이어는 상기 프로세서에서 실행된 하나의 어플리케이션에 대응하도록 설정된 전자 장치.
  10. 제1 항에 있어서,
    상기 제1 레이어 및 상기 제2 레이어는 각각 상기 프로세서에서 실행된 서로 다른 어플리케이션에 대응하도록 설정된 전자 장치.
  11. 제1항에 있어서,
    상기 프로세서는,
    상기 제1 레이어로부터 수신한 상기 제1 그래픽 정보를 상기 그래픽 버퍼에 저장할지, 또는 상기 제2 레이어로부터 수신한 상기 제2 그래픽 정보를 상기 프레임 버퍼에 저장할지 여부를 확인하도록 설정된 전자 장치.
  12. 제11항에 있어서,
    상기 프로세서는,
    새로운 어플리케이션의 실행에 기초하여 상기 제1 레이어로부터 수신한 상기 제1 그래픽 정보를 상기 그래픽 버퍼에 저장할지, 또는 상기 제2 레이어로부터 수신한 상기 제2 그래픽 정보를 상기 프레임 버퍼에 저장할지 여부를 재결정하도록 설정된 전자 장치.
  13. 제12항에 있어서,
    상기 프로세서는,
    제3 레이어의 추가에 기초하여, 상기 제3 레이어로부터 수신한 제3 그래픽 정보를 상기 그래픽 버퍼에 저장할지, 또는 상기 프레임 버퍼에 저장할지 여부를 결정하도록 설정된 전자 장치.
  14. 전자 장치에서 수행하는 방법에 있어서,
    제1 레이어로부터 수신한 제1 그래픽 정보를 그래픽 버퍼에 저장하는 동작;
    제2 레이어로부터 수신한 제2 그래픽 정보를 프레임 버퍼에 저장하는 동작;
    상기 그래픽 버퍼에 저장된 상기 제1 그래픽 정보를 상기 프레임 버퍼에 저장하는 동작; 및
    상기 프레임 버퍼에 저장된, 상기 제1 그래픽 정보 및 상기 제2 그래픽 정보를 상기 전자 장치의 디스플레이를 통하여 동시에 표시하는 동작;을 포함하는 방법.
  15. 제14항에 있어서,
    상기 제2 그래픽 정보를 프레임 버퍼에 저장하는 동작은,
    상기 제2 그래픽 정보의 갱신 빈도를 확인하는 동작; 및
    상기 갱신 빈도가 지정된 값 이상이면 상기 제2 그래픽 정보를 상기 프레임 버퍼에 저장하는 동작;을 포함하는 방법.
  16. 제14항에 있어서,
    상기 제2 그래픽 정보를 프레임 버퍼에 저장하는 동작은,
    상기 제2 그래픽 정보의 이미지 사이즈를 확인하는 동작; 및
    상기 제2 그래픽 정보의 이미지 사이즈가 지정된 사이즈 이상이면 상기 제2 그래픽 정보를 상기 프레임 버퍼에 저장하는 동작;을 포함하는 방법.
  17. 제14항에 있어서,
    상기 제2 그래픽 정보를 프레임 버퍼에 저장하는 동작은,
    상기 제2 레이어에 대응하여 요청된 버퍼의 사이즈와 상기 프레임 버퍼의 사이즈를 비교하는 동작; 및
    상기 제2 레이어에 대응하여 요청된 버퍼의 사이즈가 상기 프레임 버퍼의 사이즈 이하이면 상기 제2 그래픽 정보를 상기 프레임 버퍼에 저장하는 동작;을 포함하는 방법.
  18. 제14항에 있어서,
    상기 제2 그래픽 정보를 프레임 버퍼에 저장하는 동작은,
    상기 제1 그래픽 정보의 이미지와 상기 제2 그래픽 정보의 이미지가 서로 겹치는 영역이 존재하는지 판단하는 동작; 및
    상기 겹치는 영역이 존재하지 않으면 상기 제2 그래픽 정보를 상기 프레임 버퍼에 저장하는 동작;을 포함하는 방법.
  19. 제14항에 있어서,
    상기 제2 그래픽 정보를 프레임 버퍼에 저장하는 동작은,
    상기 제2 레이어가 기설정된 타겟 레이어 리스트에 포함되어있는지 확인하는 동작; 및
    상기 제2 레이어가 기설정된 타겟 레이어 리스트에 포함되어 있으면 상기 제2 그래픽 정보를 상기 프레임 버퍼에 저장하는 동작;을 포함하는 방법.
  20. 제1 레이어로부터 수신한 제1 그래픽 정보를 그래픽 버퍼에 저장하는 동작;
    제2 레이어로부터 수신한 제2 그래픽 정보를 프레임 버퍼에 저장하는 동작;
    상기 그래픽 버퍼에 저장된 상기 제1 그래픽 정보를 상기 프레임 버퍼에 저장하는 동작; 및
    상기 프레임 버퍼에 저장된, 상기 제1 그래픽 정보 및 상기 제2 그래픽 정보를 디스플레이를 통하여 동시에 표시하는 동작;을 포함하는 방법을 수행하는 프로그램이 기록된 컴퓨터 판독 가능 기록매체.
KR1020160041887A 2016-04-05 2016-04-05 소모 전류를 줄이는 방법 및 전자 장치 KR102491499B1 (ko)

Priority Applications (4)

Application Number Priority Date Filing Date Title
KR1020160041887A KR102491499B1 (ko) 2016-04-05 2016-04-05 소모 전류를 줄이는 방법 및 전자 장치
PCT/KR2017/002949 WO2017175989A1 (ko) 2016-04-05 2017-03-17 소모 전류를 줄이는 방법 및 전자 장치
US16/086,084 US11175717B2 (en) 2016-04-05 2017-03-17 Method for reducing current consumption, and electronic device
EP17779289.2A EP3393111B1 (en) 2016-04-05 2017-03-17 Method for reducing current consumption, and electronic device

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
KR1020160041887A KR102491499B1 (ko) 2016-04-05 2016-04-05 소모 전류를 줄이는 방법 및 전자 장치

Publications (2)

Publication Number Publication Date
KR20170114625A true KR20170114625A (ko) 2017-10-16
KR102491499B1 KR102491499B1 (ko) 2023-01-25

Family

ID=60001314

Family Applications (1)

Application Number Title Priority Date Filing Date
KR1020160041887A KR102491499B1 (ko) 2016-04-05 2016-04-05 소모 전류를 줄이는 방법 및 전자 장치

Country Status (4)

Country Link
US (1) US11175717B2 (ko)
EP (1) EP3393111B1 (ko)
KR (1) KR102491499B1 (ko)
WO (1) WO2017175989A1 (ko)

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN114153304A (zh) * 2021-11-23 2022-03-08 联想(北京)有限公司 一种控制方法、设备及存储介质

Families Citing this family (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2020177074A (ja) * 2019-04-16 2020-10-29 株式会社デンソー 車両用装置、車両用装置の制御方法
CN115145513A (zh) * 2021-03-31 2022-10-04 华为技术有限公司 一种投屏方法、系统及相关装置

Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20100058229A1 (en) * 2008-09-02 2010-03-04 Palm, Inc. Compositing Windowing System
US20150100884A1 (en) * 2013-10-08 2015-04-09 Nvidia Corporation Hardware overlay assignment

Family Cites Families (11)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US7274370B2 (en) 2003-12-18 2007-09-25 Apple Inc. Composite graphics rendered using multiple frame buffers
US7535478B2 (en) 2003-12-24 2009-05-19 Intel Corporation Method and apparatus to communicate graphics overlay information to display modules
JP4522404B2 (ja) * 2004-04-22 2010-08-11 富士通セミコンダクター株式会社 画像処理装置
US7652678B2 (en) 2004-06-25 2010-01-26 Apple Inc. Partial display updates in a windowing system using a programmable graphics processing unit
US8130226B2 (en) 2006-08-04 2012-03-06 Apple Inc. Framework for graphics animation and compositing operations
US20080284798A1 (en) 2007-05-07 2008-11-20 Qualcomm Incorporated Post-render graphics overlays
US8477143B2 (en) 2008-03-04 2013-07-02 Apple Inc. Buffers for display acceleration
US8274501B2 (en) 2008-11-18 2012-09-25 Intel Corporation Techniques to control self refresh display functionality
KR20100117709A (ko) * 2009-04-27 2010-11-04 이노디지털 주식회사 그래픽 사용자 인터페이스 및 표시 방법
US8760459B2 (en) * 2009-12-30 2014-06-24 Intel Corporation Display data management techniques
US9195426B2 (en) * 2013-09-20 2015-11-24 Arm Limited Method and apparatus for generating an output surface from one or more input surfaces in data processing systems

Patent Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20100058229A1 (en) * 2008-09-02 2010-03-04 Palm, Inc. Compositing Windowing System
US20150100884A1 (en) * 2013-10-08 2015-04-09 Nvidia Corporation Hardware overlay assignment

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN114153304A (zh) * 2021-11-23 2022-03-08 联想(北京)有限公司 一种控制方法、设备及存储介质

Also Published As

Publication number Publication date
EP3393111A1 (en) 2018-10-24
US11175717B2 (en) 2021-11-16
KR102491499B1 (ko) 2023-01-25
EP3393111B1 (en) 2020-06-17
US20200293104A1 (en) 2020-09-17
EP3393111A4 (en) 2019-01-09
WO2017175989A1 (ko) 2017-10-12

Similar Documents

Publication Publication Date Title
KR102488333B1 (ko) 그래픽 데이터를 합성하는 전자 장치 및 방법
CN107257954B (zh) 用于提供屏幕镜像服务的设备和方法
EP3337169B1 (en) Method and device for adjusting resolution of electronic device
KR20170116883A (ko) 플렉서블 디바이스 및 그 동작 방법
KR20180014494A (ko) 화면 제어 방법 및 이를 지원하는 전자 장치
KR20160101600A (ko) 스크린 미러링 서비스 제공방법 및 장치
KR20170071960A (ko) 전자 장치의 사용자 인터페이스 제공 방법 및 장치
KR102458444B1 (ko) 전자 장치 및 그 동작 방법
US10705681B2 (en) Electronic device and display method for selecting an area of an icon
US10853015B2 (en) Electronic device and control method therefor
EP3107087A2 (en) Device for controlling multiple areas of display independently and method thereof
KR20170030349A (ko) 입력의 압력을 감지하는 전자 장치 및 그 동작 방법
KR20170009008A (ko) 이미지를 표시하는 전자 장치 및 그 제어 방법
KR20160125783A (ko) 컨텐츠를 표시하기 위한 방법 및 전자 장치
KR20160057822A (ko) 디스플레이를 제어하기 위한 방법 및 그 전자 장치
KR20180019907A (ko) 전자 장치 및 그의 운용 제공 방법
KR20170105863A (ko) 전자 장치 및 전자 장치의 디스플레이 제어 방법
KR20170052003A (ko) 복수의 디스플레이들을 갖는 전자 장치 및 그 동작 방법
EP3393111B1 (en) Method for reducing current consumption, and electronic device
KR20170041467A (ko) 전자 장치에서 실행된 어플리케이션을 제어하는 웨어러블 전자 장치 및 방법
KR20160137258A (ko) 전자 장치 및 그의 화면 표시 방법
KR20170055283A (ko) 외부 전자 장치를 통해 어플리케이션을 제공하는 방법 및 장치
KR20170044469A (ko) 실행 화면 레코딩 방법 및 그 방법을 처리하는 전자 장치
KR102589496B1 (ko) 화면 표시 방법 및 이를 지원하는 전자 장치
KR20160109466A (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