Service Applications
서비스 어플리케이션은 UI 어플리케이션에 의해 실행될 수 있다. 또한 서비스 어플리케이션은 주건에 따라 실행될 수 있다.
사용자는 task switcher에서 실행되고 있는 서비스 어플리케이션을 체크할 수 있다. 하지만, 사용자가 task switcher를 통해 서비스 어플리케이션을 선택할 경우 어떠한 이벤트도 발생하지 않는다. 메인 메뉴는 서비스 어플리케이션을 위한 아이콘을 포함하지 않는다. 다중 서비스 어플리케이션(Multiple Service Application)은 다른 서비스 혹은 UI 어플리케이션과 동시에 실행된다.
Service Application Fundamentals
모든 서비스 어플리케이션에 필요한 기본적인 기능을 수행하기 위해서, Tizen::App네임스페이스는 여러 기능을 제공한다.
Tizen IDE의 Project Wizard를 사용하여 어플리케이션을 생성하면 Tizen IDE는 자동적으로 다음과 같은 기본적인 코드를 생성해준다.
Inheriting the ServiceApp clasee (ServiceApp 클래스를 상속받은 클래스)
Creating the Application Entry Point (어플리케이션 entry point 생성)
어플리케이션 Life-cycle(생명주기) 관리
어플리케이션 정보 ( GetAppName(), GetAppId() 메소드를 통해 어플리케이션의 정보를 얻을 수 있다)
시스템 이벤트 처리
Inheriting the ServiceApp Class
Tizen::App::ServiceApp클래스는 Tizen 서비스 어플리케이션 프로그램을 정의하는데 필요한 기본적인 기능을 제공한다. 그러므로 모든 타이젠 서비스 어플리케이션은 ServiceApp class를 상속받아야만 한다.
class MyApp : public Tizen::App::ServiceApp
Creating the Application Entry Point
어플리케이션이 실행될때, Tizen IDE는 자동적으로 OspMain() 메소드를 <어플리케이션 이름>Entry.cpp에 생성한다.
int OspMain(int argc, char* pArgv[]) { r = Tizen::App::ServiceApp::Execute(MyApp::CreateInstance, pArgs); }
ServiceApp 클래스에서 파생된 클래스를 선언하고 해당 인스턴스를 생성하는 정적 메서드를 정의해야 한다.
// Declare the method static Tizen::App::ServiceApp* MyApp::CreateInstance(void); // Define the method ServiceApp* MyApp::CreateInstance(void) { return new MyApp; }
Managing the Service Application Life-cycle
어플리케이션의 Life-Cycle(생명주기)는 어플리케이션의 상태변화에 따라 호출되는 이벤트 핸들러의 집합으로 관리된다.
The OnAppInitializing() event handler is called when an application state changes to 'Initializing'. If the OnAppInitializing() event handler returns false, the application is directly terminated.
The OnAppInitialized() event handler is called when the application state changes to 'Running'.
The OnAppTerminating() event handler is called when the application state changes to 'Terminated'.
bool MyApp::OnAppInitializing(AppRegistry& appRegistry) { // Initialize application specific data // The application's permanent data and context can be obtained from the application registry // If this method is successful, return true; otherwise, return false // If this method returns false, the application is terminated // Uncomment the following statement to listen to the screen on/off events // React when the application is in the 'initializing' state return true; } bool MyApp::OnAppInitialized(void) { // React to application initialization return true; } bool MyApp::OnAppWillTerminate(void) { // React to the application termination status return true; } bool MyApp::OnAppTerminating(AppRegistry& appRegistry, bool forcedTermination) { // Deallocate resources allocated by this application for termination // The application's permanent data and context can be saved in the application registry // React when the application is in the 'terminating' state return true; }
'Developer > Tizen' 카테고리의 다른 글
단방향 메세지 포트 통신 처리(Handling Uni-directional Message Port Communication) (0) | 2014.01.13 |
---|---|
예제) MultiProcServiceApp, MultiProcUiApp (0) | 2014.01.12 |
Privilege(권한) (1) | 2013.12.29 |
Privilege(권한) 종류 (0) | 2013.12.29 |
Tizen 화면 가져오는 방법 (0) | 2013.12.28 |