Tizen.Applications.AppControl/a>/ninstance is set to <code>AppControlOperations.Default<\/code>, the\napplication ID must be set. Otherwise the\n<code>ArgumentException<\/code> occurs.<\/li>\n<\/ul>\n<div class=\"md-alert md-alert-note\">\n<span><svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\"><path d=\"M0 8a8 8 0 1 1 16 0A8 8 0 0 1 0 8Zm8-6.5a6.5 6.5 0 1 0 0 13 6.5 6.5 0 0 0 0-13ZM6.5 7.75A.75.75 0 0 1 7.25 7h1a.75.75 0 0 1 .75.75v2.75h.25a.75.75 0 0 1 0 1.5h-2a.75.75 0 0 1 0-1.5h.25v-2h-.25a.75.75 0 0 1-.75-.75ZM8 6a1 1 0 1 1 0-2 1 1 0 0 1 0 2Z\"\/><\/svg>Note<\/span>\n<p>Be careful when using the explicit launch, because if the\ntarget application does not exist on the device, you need to handle\nthe <code>AppNotFoundException<\/code>. If you want to launch any application\nthat supports a certain operation, use the implicit launch.<\/p>\n<\/div>\n<\/li>\n<li>\n<p>Implicit launch<\/p>\n<p>Implicit launch means that you launch any application which matches\nthe operation, URI (or scheme), or MIME type you need. When you\n<a href=https://samsungtizenos.com/"#implicit\">request an implicit launch<\/a>:<\/p>\n<ul>\n<li>To determine which application can be launched, the application\nlauncher framework compares the operation, URI, and MIME\ntype conditions.<\/li>\n<li>The application launcher framework iterates the application\ncontrols of all applications on the device to <a href=https://samsungtizenos.com/"#resolution\">find the\napplications that match<\/a> the given conditions.<\/li>\n<li>If only 1 application is matched for the given conditions, that\napplication is launched. If multiple matching applications are\nfound, the application selector is shown and the user can select\nthe proper application.<\/li>\n<\/ul>\n<\/li>\n<\/ul>\n<p><a name=\"request\"><\/a><\/p>\n<h2 id=\"content-launch-requests\"><a href=https://samsungtizenos.com/"#content-launch-requests\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Launch requests<\/h2>\n<p>To launch an application with the application control, you must create a\nlaunch request. You must create an instance of the\n<a href=https://samsungtizenos.com/"//application//dotnet//api//TizenFX//latest//api//Tizen.Applications.AppControl.md/">Tizen.Applications.AppControl/a>/nclass, and add the conditions for selecting the application to be\nlaunched. You can add the following information to the instance:<\/p>\n<ul>\n<li>\n<p><code>Operation<\/code>: Action to be performed by the launched application.<\/p>\n<div class=\"md-alert md-alert-note\">\n<span><svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\"><path d=\"M0 8a8 8 0 1 1 16 0A8 8 0 0 1 0 8Zm8-6.5a6.5 6.5 0 1 0 0 13 6.5 6.5 0 0 0 0-13ZM6.5 7.75A.75.75 0 0 1 7.25 7h1a.75.75 0 0 1 .75.75v2.75h.25a.75.75 0 0 1 0 1.5h-2a.75.75 0 0 1 0-1.5h.25v-2h-.25a.75.75 0 0 1-.75-.75ZM8 6a1 1 0 1 1 0-2 1 1 0 0 1 0 2Z\"\/><\/svg>Note<\/span>\n<p>The operation name format is\n<code>http:\/\/tizen.org\/appcontrol\/operation\/<verb><\/code>. You can also use an\ninstance of the\n<a href=https://samsungtizenos.com/"//application//dotnet//api//TizenFX//latest//api//Tizen.Applications.AppControlOperations.md/">Tizen.Applications.AppControlOperations/a> class.<\/p>\n<\/div>\n<p>The operation is mandatory information for sending the\nlaunch request.<\/p>\n<\/li>\n<li>\n<p><code>Uri<\/code>: Data itself to be performed.<\/p>\n<\/li>\n<li>\n<p><code>Mime<\/code>: Specific type of the URI.<\/p>\n<\/li>\n<li>\n<p><code>ApplicationId<\/code>: ID of the application to be launched.<\/p>\n<\/li>\n<li>\n<p><code>ExtraData<\/code>: Key-value pairs to <a href=https://samsungtizenos.com/"#use\">provide additional information for\nthe launch request and launch result<\/a>.<\/p>\n<\/li>\n<\/ul>\n<p><a name=\"explicit\"><\/a><\/p>\n<h3 id=\"content-explicit-launch-request\"><a href=https://samsungtizenos.com/"#content-explicit-launch-request\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Explicit launch request<\/h3>\n<p>The following example shows how to create an explicit launch request\nwhich launches an application explicitly by setting the <code>ApplicationId<\/code>\nproperty of the\n<a href=https://samsungtizenos.com/"//application//dotnet//api//TizenFX//latest//api//Tizen.Applications.AppControl.md/">Tizen.Applications.AppControl/a>/nclass instance:<\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">AppControl<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">appcontrol<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">new<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">AppControl<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">();<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">appcontrol.Operation <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> AppControlOperations.Default;<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">appcontrol.ApplicationId <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">"org.tizen.TestApp"<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">;<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">AppControl.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">SendLaunchRequest<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(appcontrol);<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<p>If you want to launch an AppControl asynchronously, use SendLaunchRequestAsync().<\/p>\n<p><a name=\"implicit\"><\/a><\/p>\n<h3 id=\"content-implicit-launch-request\"><a href=https://samsungtizenos.com/"#content-implicit-launch-request\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Implicit launch request<\/h3>\n<p>The following examples show how to create an implicit launch request:<\/p>\n<ul>\n<li>\n<p>To launch a camera application with a specific operation and MIME\ntype, use the following code:<\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">AppControl<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">appcontrol<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">new<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">AppControl<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">();<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">appcontrol.Operation <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> AppControlOperations.CreateContent;<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">appcontrol.Mime <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">"image\/jpg"<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">;<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">AppControl.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">SendLaunchRequest<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(appcontrol);<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<\/li>\n<li>\n<p>To launch a viewer application with a specific operation, URI, and\nMIME type, use the following code:<\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">AppControl<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">appcontrol<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">new<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">AppControl<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">();<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">appcontrol.Operation <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> AppControlOperations.View;<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">appcontrol.Mime <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">"image\/*"<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">;<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">appcontrol.Uri <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">"file:\/\/\/home\/myhome\/Photos\/1_photo.jpg"<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">;<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">AppControl.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">SendLaunchRequest<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(appcontrol);<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<\/li>\n<\/ul>\n<p><a name=\"resolution\"><\/a><\/p>\n<h3 id=\"content-determine-the-application-for-an-implicit-launch-request\"><a href=https://samsungtizenos.com/"#content-determine-the-application-for-an-implicit-launch-request\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Determine the application for an implicit launch request<\/h3>\n<p>In the case of an implicit launch, the platform determines which\napplication to launch by "resolving the application control". This means\nthat the platform considers the given conditions (operation, URI, and\nMIME type) in the launch request, searches the filters (installed\napplications with available application controls) on the device, and\nattempts to find a match.<\/p>\n<p>The launch request conditions are matched to the available filters using\nthe following logic:<\/p>\n<ol>\n<li>\n<p>The operation value is matched first. An exact match is required for\nthe value in both the launch request and the filters.<\/p>\n<p>If multiple matching filters with identical operations are\navailable, the URI and MIME types in the matching filters\nare compared.<\/p>\n<\/li>\n<li>\n<p>If the launch request has URI or MIME types as a condition, the\ncomparison is done only among the filters that have URI or\nMIME types. For example, if the launch request has a URI, but a\nfilter does not, that filter is not added to the result even if the\noperations are the same. Similarly, if the launch request has MIME\ntypes, it is not compared to the filters that have no MIME types.<\/p>\n<p>An exception is applied to the URIs with a "file" scheme for\nthe value. If the launch request URI contains an existing file path\nand no MIME types are supplied, the filters that have the MIME type\nof the given file path are also added to the results.<\/p>\n<div class=\"md-alert md-alert-note\">\n<span><svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\"><path d=\"M0 8a8 8 0 1 1 16 0A8 8 0 0 1 0 8Zm8-6.5a6.5 6.5 0 1 0 0 13 6.5 6.5 0 0 0 0-13ZM6.5 7.75A.75.75 0 0 1 7.25 7h1a.75.75 0 0 1 .75.75v2.75h.25a.75.75 0 0 1 0 1.5h-2a.75.75 0 0 1 0-1.5h.25v-2h-.25a.75.75 0 0 1-.75-.75ZM8 6a1 1 0 1 1 0-2 1 1 0 0 1 0 2Z\"\/><\/svg>Note<\/span>\n<p>A filter (application) that expects to match with any form\nof URI and any type of MIME must use <code>'*'<\/code> and <code>*\/*<\/code> in their\napplication control information in the <code>tizen-manifest.xml<\/code> file,\ninstead of leaving the value to <code>NULL<\/code>. Otherwise, the application\nis discarded by the platform when the application control\nis resolved.<\/p>\n<\/div>\n<\/li>\n<li>\n<p>Unlike the operation, the URI and MIME types support wildcards on\nthe filters. Detailed conditions for matches are described below:<\/p>\n<ul>\n<li>The URI match can be an exact, partial (scheme), or pattern\nmatch according to the value in the filters. URI filters are\nmatched with the launch request if:\n<ul>\n<li>Both URIs are exactly the same.<\/li>\n<li>Launch request URI passes the test with a <code>glob()<\/code>-like\nfunction with the filter URI.<\/li>\n<li>Scheme and host part of the URI in the launch request and\nfilters are the same.<\/li>\n<li>Scheme part of the URI in the launch request and filters is\nthe same.<\/li>\n<\/ul>\n<\/li>\n<li>The MIME type match can be an exact or pattern match according\nto the value in the filters. MIME type filters are matched with\nthe launch request if:\n<ul>\n<li>Both MIME types are exactly the same.<\/li>\n<li>MIME type in the launch request and filters has the same\ntype and '*' for the subtype.<\/li>\n<li>The filters have <code>*\/*<\/code> for the MIME type.<\/li>\n<\/ul>\n<\/li>\n<\/ul>\n<\/li>\n<\/ol>\n<p>The following examples show different scenarios for the results of resolving the application control:<\/p>\n<ul>\n<li>\n<p>Operation provided:<\/p>\n<ul>\n<li>Request:\n<ul>\n<li>Operation: <code>http:\/\/tizen.org\/appcontrol\/operation\/view<\/code><\/li>\n<li>URI: <code>NULL<\/code><\/li>\n<li>MIME: <code>NULL<\/code><\/li>\n<\/ul>\n<\/li>\n<li>Result (the reason for the failure is marked in <strong>bold<\/strong>):<\/li>\n<\/ul>\n<p><strong>Table: Scenario when only the operation is provided<\/strong><\/p>\n<div class=\"overflow-auto grid table-fixed\" data-table-container=\"data-table-container\"><table>\n<thead>\n<tr>\n<th>Filter ID<\/th>\n<th>Operation<\/th>\n<th>URI<\/th>\n<th>MIME<\/th>\n<th>Result<\/th>\n<\/tr>\n<\/thead>\n<tbody>\n<tr>\n<td>1<\/td>\n<td><code>http:\/\/tizen.org\/appcontrol\/operation\/view<\/code><\/td>\n<td><code>NULL<\/code><\/td>\n<td><code>NULL<\/code><\/td>\n<td>Pass<\/td>\n<\/tr>\n<tr>\n<td>2<\/td>\n<td><strong><code>http:\/\/tizen.org\/appcontrol\/operation\/default<\/code><\/strong><\/td>\n<td><code>NULL<\/code><\/td>\n<td><code>NULL<\/code><\/td>\n<td>Fail<\/td>\n<\/tr>\n<tr>\n<td>3<\/td>\n<td><code>http:\/\/tizen.org\/appcontrol\/operation\/view<\/code><\/td>\n<td><strong><code>file<\/code><\/strong><\/td>\n<td><code>NULL<\/code><\/td>\n<td>Fail<\/td>\n<\/tr>\n<\/tbody>\n<\/table><\/div>\n<\/li>\n<li>\n<p>Operation and URI provided:<\/p>\n<ul>\n<li>Request:\n<ul>\n<li>Operation: <code>http:\/\/tizen.org\/appcontrol\/operation\/view<\/code><\/li>\n<li>URI: <code>file:\/\/\/usr\/share\/icons\/calendar.png<\/code><\/li>\n<li>MIME: <code>NULL<\/code><\/li>\n<\/ul>\n<\/li>\n<li>Result (the reason for the failure is marked in <strong>bold<\/strong>):<\/li>\n<\/ul>\n<p><strong>Table: Scenario when the operation and URI are provided<\/strong><\/p>\n<div class=\"overflow-auto grid table-fixed\" data-table-container=\"data-table-container\"><table>\n<thead>\n<tr>\n<th>Filter ID<\/th>\n<th>Operation<\/th>\n<th>URI<\/th>\n<th>MIME<\/th>\n<th>Result<\/th>\n<\/tr>\n<\/thead>\n<tbody>\n<tr>\n<td>1<\/td>\n<td><code>http:\/\/tizen.org\/appcontrol\/operation\/view<\/code><\/td>\n<td><strong><code>NULL<\/code><\/strong><\/td>\n<td><code>NULL<\/code><\/td>\n<td>Fail<\/td>\n<\/tr>\n<tr>\n<td>2<\/td>\n<td><code>http:\/\/tizen.org\/appcontrol\/operation\/view<\/code><\/td>\n<td><code>file:\/\/\/usr\/share\/icons\/calendar.png<\/code><\/td>\n<td><code>*\/*<\/code><\/td>\n<td>Pass<\/td>\n<\/tr>\n<tr>\n<td>3<\/td>\n<td><code>http:\/\/tizen.org\/appcontrol\/operation\/view<\/code><\/td>\n<td><code>file:\/\/\/*<\/code><\/td>\n<td><code>*\/*<\/code><\/td>\n<td>Pass<\/td>\n<\/tr>\n<tr>\n<td>4<\/td>\n<td><code>http:\/\/tizen.org\/appcontrol\/operation\/view<\/code><\/td>\n<td><code>file<\/code><\/td>\n<td><code>*\/*<\/code><\/td>\n<td>Pass<\/td>\n<\/tr>\n<tr>\n<td>5<\/td>\n<td><code>http:\/\/tizen.org\/appcontrol\/operation\/view<\/code><\/td>\n<td><strong><code>http<\/code><\/strong><\/td>\n<td><code>*\/*<\/code><\/td>\n<td>Fail<\/td>\n<\/tr>\n<tr>\n<td>6<\/td>\n<td><code>http:\/\/tizen.org\/appcontrol\/operation\/view<\/code><\/td>\n<td><code>NULL<\/code><\/td>\n<td><code>image\/png<\/code><\/td>\n<td>Pass<\/td>\n<\/tr>\n<tr>\n<td>7<\/td>\n<td><code>http:\/\/tizen.org\/appcontrol\/operation\/view<\/code><\/td>\n<td><code>NULL<\/code><\/td>\n<td><strong><code>image\/jpg<\/code><\/strong><\/td>\n<td>Fail<\/td>\n<\/tr>\n<\/tbody>\n<\/table><\/div>\n<\/li>\n<li>\n<p>Operation and MIME type provided:<\/p>\n<ul>\n<li>Request:\n<ul>\n<li>Operation: <code>http:\/\/tizen.org\/appcontrol\/operation\/view<\/code><\/li>\n<li>URI: <code>NULL<\/code><\/li>\n<li>MIME: <code>image\/png<\/code><\/li>\n<\/ul>\n<\/li>\n<li>Result (the reason for the failure is marked in <strong>bold<\/strong>):<\/li>\n<\/ul>\n<p><strong>Table: Scenario when the operation and MIME type are provided<\/strong><\/p>\n<div class=\"overflow-auto grid table-fixed\" data-table-container=\"data-table-container\"><table>\n<thead>\n<tr>\n<th>Filter ID<\/th>\n<th>Operation<\/th>\n<th>URI<\/th>\n<th>MIME<\/th>\n<th>Result<\/th>\n<\/tr>\n<\/thead>\n<tbody>\n<tr>\n<td>1<\/td>\n<td><code>http:\/\/tizen.org\/appcontrol\/operation\/view<\/code><\/td>\n<td><code>NULL<\/code><\/td>\n<td><code>image\/png<\/code><\/td>\n<td>Pass<\/td>\n<\/tr>\n<tr>\n<td>2<\/td>\n<td><code>http:\/\/tizen.org\/appcontrol\/operation\/view<\/code><\/td>\n<td><code>NULL<\/code><\/td>\n<td><code>image\/*<\/code><\/td>\n<td>Pass<\/td>\n<\/tr>\n<tr>\n<td>3<\/td>\n<td><code>http:\/\/tizen.org\/appcontrol\/operation\/view<\/code><\/td>\n<td><code>NULL<\/code><\/td>\n<td><code>*\/*<\/code><\/td>\n<td>Pass<\/td>\n<\/tr>\n<tr>\n<td>4<\/td>\n<td><code>http:\/\/tizen.org\/appcontrol\/operation\/view<\/code><\/td>\n<td><code>file:\/\/\/usr\/share\/icons\/calendar.png<\/code><\/td>\n<td><strong><code>NULL<\/code><\/strong><\/td>\n<td>Fail<\/td>\n<\/tr>\n<tr>\n<td>5<\/td>\n<td><code>http:\/\/tizen.org\/appcontrol\/operation\/view<\/code><\/td>\n<td><code>NULL<\/code><\/td>\n<td><strong><code>image\/jpg<\/code><\/strong><\/td>\n<td>Fail<\/td>\n<\/tr>\n<tr>\n<td>6<\/td>\n<td><code>http:\/\/tizen.org\/appcontrol\/operation\/view<\/code><\/td>\n<td><code>NULL<\/code><\/td>\n<td><strong><code>video\/*<\/code><\/strong><\/td>\n<td>Fail<\/td>\n<\/tr>\n<tr>\n<td>7<\/td>\n<td><code>http:\/\/tizen.org\/appcontrol\/operation\/view<\/code><\/td>\n<td><strong><code>http:\/\/tizen.org\/favorites.png<\/code><\/strong><\/td>\n<td><code>image\/png<\/code><\/td>\n<td>Fail<\/td>\n<\/tr>\n<\/tbody>\n<\/table><\/div>\n<\/li>\n<li>\n<p>Operation, URI, and MIME type provided:<\/p>\n<ul>\n<li>Request:\n<ul>\n<li>Operation: <code>http:\/\/tizen.org\/appcontrol\/operation\/view<\/code><\/li>\n<li>URI: <code>http:\/\/www.tizen.org\/favorites.png<\/code><\/li>\n<li>MIME: <code>image\/png<\/code><\/li>\n<\/ul>\n<\/li>\n<li>Result (the reason for the failure is marked in <strong>bold<\/strong>):<\/li>\n<\/ul>\n<p><strong>Table: Scenario when the operation, URI, and MIME type are provided<\/strong><\/p>\n<div class=\"overflow-auto grid table-fixed\" data-table-container=\"data-table-container\"><table>\n<thead>\n<tr>\n<th>Filter ID<\/th>\n<th>Operation<\/th>\n<th>URI<\/th>\n<th>MIME<\/th>\n<th>Result<\/th>\n<\/tr>\n<\/thead>\n<tbody>\n<tr>\n<td>1<\/td>\n<td><code>http:\/\/tizen.org\/appcontrol\/operation\/view<\/code><\/td>\n<td><code>http:\/\/www.tizen.org\/favorites.png<\/code><\/td>\n<td><code>image\/png<\/code><\/td>\n<td>Pass<\/td>\n<\/tr>\n<tr>\n<td>2<\/td>\n<td><code>http:\/\/tizen.org\/appcontrol\/operation\/view<\/code><\/td>\n<td><code>http:\/\/www.tizen.org\/favorites.png<\/code><\/td>\n<td><strong><code>NULL<\/code><\/strong><\/td>\n<td>Fail<\/td>\n<\/tr>\n<tr>\n<td>3<\/td>\n<td><code>http:\/\/tizen.org\/appcontrol\/operation\/view<\/code><\/td>\n<td><code>http:\/\/www.tizen.org\/*<\/code><\/td>\n<td><code>image\/png<\/code><\/td>\n<td>Pass<\/td>\n<\/tr>\n<tr>\n<td>4<\/td>\n<td><code>http:\/\/tizen.org\/appcontrol\/operation\/view<\/code><\/td>\n<td><code>http<\/code><\/td>\n<td><code>image\/png<\/code><\/td>\n<td>Pass<\/td>\n<\/tr>\n<tr>\n<td>5<\/td>\n<td><code>http:\/\/tizen.org\/appcontrol\/operation\/view<\/code><\/td>\n<td><strong><code>NULL<\/code><\/strong><\/td>\n<td><code>image\/png<\/code><\/td>\n<td>Fail<\/td>\n<\/tr>\n<tr>\n<td>6<\/td>\n<td><code>http:\/\/tizen.org\/appcontrol\/operation\/view<\/code><\/td>\n<td><code>*<\/code><\/td>\n<td><code>*\/*<\/code><\/td>\n<td>Pass<\/td>\n<\/tr>\n<\/tbody>\n<\/table><\/div>\n<\/li>\n<\/ul>\n<p><a name=\"process\"><\/a><\/p>\n<h2 id=\"content-launch-process\"><a href=https://samsungtizenos.com/"#content-launch-process\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Launch process<\/h2>\n<p>Regardless of the launch request type, when the application launcher\nframework has received and resolved a launch request, it starts the\napplication by creating a new process and calling the entry point of the\napplication:<\/p>\n<ol>\n<li>\n<p>Like a conventional C# application, the main method of the\napplication is its entry point. In a Tizen .NET application, the\nmain task is to hand over control to the application framework by\ncalling the <code>Run()<\/code> method:<\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">class<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">App<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> : <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">NUIApplication<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">{<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">protected<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">override<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">void<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">OnCreate<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">()<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> {<\/span><\/span>\n<span class=\"line\"><span style=\"color:#6A737D;--shiki-dark:#6A737D\"> \/\/\/ Hook to take necessary actions before main event loop starts; this<\/span><\/span>\n<span class=\"line\"><span style=\"color:#6A737D;--shiki-dark:#6A737D\"> \/\/\/ usually means initializing the UI<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">base<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">OnCreate<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">();<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> }<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">protected<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">override<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">void<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">OnAppControlReceived<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">AppControlReceivedEventArgs<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">e<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">)<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> {<\/span><\/span>\n<span class=\"line\"><span style=\"color:#6A737D;--shiki-dark:#6A737D\"> \/\/\/ Handle the launch request, show the user the task requested through the<\/span><\/span>\n<span class=\"line\"><span style=\"color:#6A737D;--shiki-dark:#6A737D\"> \/\/\/ "AppControlReceivedEventArgs" parameter<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">base<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">OnAppControlReceived<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(e);<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> }<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">protected<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">override<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">void<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">OnPause<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">()<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> {<\/span><\/span>\n<span class=\"line\"><span style=\"color:#6A737D;--shiki-dark:#6A737D\"> \/\/\/ Take necessary actions when application becomes invisible<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">base<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">OnPause<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">();<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> }<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">protected<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">override<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">void<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">OnResume<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">()<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> {<\/span><\/span>\n<span class=\"line\"><span style=\"color:#6A737D;--shiki-dark:#6A737D\"> \/\/\/ Take necessary actions when application becomes visible<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">base<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">OnResume<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">();<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> }<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">protected<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">override<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">void<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">OnTerminate<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">()<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> {<\/span><\/span>\n<span class=\"line\"><span style=\"color:#6A737D;--shiki-dark:#6A737D\"> \/\/\/ Release all resources<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">base<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">OnTerminate<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">();<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> }<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">static<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">void<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Main<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(<\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">string<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">[] <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">args<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">)<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> {<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">App<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">app<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">new<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">App<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">();<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> app.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Run<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(args);<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> }<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">}<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<\/li>\n<li>\n<p>The <code>Run()<\/code> method initializes the application and starts the\nmain loop.<\/p>\n<p>It takes a parameter and uses it to initialize the application. The\n<code>args<\/code> parameter contains the values from the application framework,\nand you must never change their values.<\/p>\n<\/li>\n<li>\n<p>When the <code>Run()<\/code> method is first invoked, the application moves from\nthe ready state to the created state, and must initialize itself.\nDuring this transition, the application framework calls the\napplication's <code>OnCreate()<\/code> state transition method just before the\napplication enters the main loop. Within the method, you must\ninitialize the application resources and create the main window.<\/p>\n<\/li>\n<li>\n<p>Just after the application enters the main loop, the application\nframework calls the application's <code>OnAppControlReceived()<\/code> method.<\/p>\n<p>The reason the application was launched is contained in an instance\nof the\n<a href=https://samsungtizenos.com/"//application//dotnet//api//TizenFX//latest//api//Tizen.Applications.ReceivedAppControl.md/">Tizen.Applications.ReceivedAppControl/a>/nclass, which is derived from the\n<a href=https://samsungtizenos.com/"//application//dotnet//api//TizenFX//latest//api//Tizen.Applications.AppControl.md/">Tizen.Applications.AppControl/a> class.\nThe application is always responsible for checking the content of\nthe <code>Tizen.Applications.ReceivedAppControl<\/code> instance and\nresponding appropriately. The content of the\n<code>Tizen.Applications.ReceivedAppControl<\/code> instance can be empty if\nthe application is launched by the user from the launcher.<\/p>\n<p>If the application wants to return the result of the application\ncontrol operation to the application that originally sent the launch\nrequest, the result can be sent with the <code>ReplyToLaunchRequest()<\/code>\nmethod of the <code>Tizen.Applications.ReceivedAppControl<\/code> class:<\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">protected<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">override<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">void<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">OnAppControlReceived<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">AppControlReceivedEventArgs<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">e<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">)<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">{<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">ReceivedAppControl<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">receivedAppControl<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> e.ReceivedAppControl;<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">if<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> (receivedAppControl.IsReplyRequest)<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> {<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">AppControl<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">replyRequest<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">new<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">AppControl<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">();<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#6A737D;--shiki-dark:#6A737D\"> \/\/\/ Send reply to the caller app<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> receivedAppControl.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">ReplyToLaunchRequest<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(replyRequest, AppControlReplyResult.Succeeded);<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> }<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">base<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">OnAppControlReceived<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(e);<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">}<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<\/li>\n<\/ol>\n<p><a name=\"results\"><\/a><\/p>\n<h2 id=\"content-launch-results\"><a href=https://samsungtizenos.com/"#content-launch-results\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Launch results<\/h2>\n<p>After the requested application (callee) has been launched and the\nlaunched application has performed the requested operation, the results\nof the operation are delivered back to the application that sent the\noriginal launch request (caller).<\/p>\n<p>The following code example requests the launch of another application\nand sets the <code>AppControlReplyCallback()<\/code> method to get the launch\nresult:<\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">public<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">void<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">LaunchRequestResultTest<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">()<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">{<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">string<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">MyAppId<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">"org.tizen.MyApp"<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">;<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">AppControl<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">appCtrl<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">new<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">AppControl<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">();<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> appCtrl.Operation <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> AppControlOperations.Default;<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> appCtrl.ApplicationId <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> MyAppId;<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#6A737D;--shiki-dark:#6A737D\"> \/\/\/ Set method to get the launch result<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> AppControl.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">SendLaunchRequest<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(appCtrl, AppControlReplyCallback);<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">}<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<p>The results are delivered in an instance of the\n<a href=https://samsungtizenos.com/"//application//dotnet//api//TizenFX//latest//api//Tizen.Applications.AppControl.md/">Tizen.Applications.AppControl/a>/ninstance with extra data. For some cases, the\n<a href=https://samsungtizenos.com/"//application//dotnet//api//TizenFX//latest//api//Tizen.Applications.AppControlData.md/">Tizen.Applications.AppControlData/a>/nprovides predefined extra data keys. If the key you need is not\npredefined, you can create your own key. However, the customized key\nmust be shared between the caller and callee applications.<\/p>\n<p>The following example shows how you can retrieve the results of the\nlaunch request and requested operation by implementing the\n<code>AppControlReplyCallback()<\/code> method:<\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#6A737D;--shiki-dark:#6A737D\">\/\/\/ Method for getting the result<\/span><\/span>\n<span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">static<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">void<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">AppControlReplyCallback<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Tizen<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Applications<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">AppControl<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">launchRequest<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">, <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Tizen<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Applications<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">AppControl<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">replyRequest<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">, <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">AppControlReplyResult<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">result<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">)<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">{<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">string<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">callerAppId<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">;<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">string<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">selected<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">;<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">if<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> (result <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">>=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> AppControlReplyResult.Succeeded)<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> {<\/span><\/span>\n<span class=\"line\"><span style=\"color:#6A737D;--shiki-dark:#6A737D\"> \/\/\/ Get the value of ExtraData sent by callee<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> callerAppId <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> replyRequest.ExtraData.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Get<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"><<\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">string<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">>(<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">"CallerApplicationId"<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">);<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> selected <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> replyRequest.ExtraData.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Get<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"><<\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">string<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">>(AppControlData.Selected);<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> }<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">}<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<p><a name=\"export_appcontrol\"><\/a><\/p>\n<h2 id=\"content-application-control-export\"><a href=https://samsungtizenos.com/"#content-application-control-export\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Application control export<\/h2>\n<p>You can allow other applications to launch your application and use your\napplication features through application controls by exporting your\napplication control functionalities. To allow other applications to\nlaunch your application implicitly without the application ID, specify\nyour application control information in Visual Studio.<\/p>\n<p><strong>Figure: Exporting app control<\/strong><\/p>\n<p><img src=https://samsungtizenos.com/"media//app_control_exporting_appcontrol.png/" alt=\"Exporting app control\" \/><\/p>\n<p>The operation, URI, and MIME type information are used when <a href=https://samsungtizenos.com/"#resolution\">resolving\nthe application control<\/a>. The operation information is\nmandatory, while the URI or MIME type information is optional. Any\napplication requesting a launch of your application must either specify\nyour application ID (for an explicit launch) or have the same operation\nvalue and applicable URI and MIME type information (for an implicit\nlaunch).\nYou can define privileges to restrict your application from launching. To launch\nyour application, the caller application must request for launch permission\nby defining privileges in the <code>tizen-manifest.xml<\/code> file.<\/p>\n<div class=\"md-alert md-alert-note\">\n<span><svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\"><path d=\"M0 8a8 8 0 1 1 16 0A8 8 0 0 1 0 8Zm8-6.5a6.5 6.5 0 1 0 0 13 6.5 6.5 0 0 0 0-13ZM6.5 7.75A.75.75 0 0 1 7.25 7h1a.75.75 0 0 1 .75.75v2.75h.25a.75.75 0 0 1 0 1.5h-2a.75.75 0 0 1 0-1.5h.25v-2h-.25a.75.75 0 0 1-.75-.75ZM8 6a1 1 0 1 1 0-2 1 1 0 0 1 0 2Z\"\/><\/svg>Note<\/span>\n<p>The URI or MIME type can contain wildcards, such as '*', to\nmatch against given conditions in the application control:<\/p>\n<ul>\n<li>In the MIME type, you can use two types of wildcards: <code>image\/*<\/code> and\n<code>*\/*<\/code>.<\/li>\n<li>In the URI, a more complex pattern of wildcards with similar\nsemantics as the standard <code>glob()<\/code> function is available: '*'\nmatches an arbitrary, possibly empty, string, and '?' matches an\narbitrary character. Unlike in the <code>glob()<\/code> function, the '\/'\ncharacter can be matched by the wildcards. There are no [...]\ncharacter ranges, and the wildcards '*' and '?' cannot be escaped\nto include them literally in a pattern.<\/li>\n<\/ul>\n<\/div>\n<p><a name=\"group\"><\/a><\/p>\n<h2 id=\"content-application-group-management\"><a href=https://samsungtizenos.com/"#content-application-group-management\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Application group management<\/h2>\n<p>You can <a href=https://samsungtizenos.com/"#mode\">define the application launch mode<\/a> and group your applications into entities that can be managed together.<\/p>\n<p>The main application group features include the following:<\/p>\n<ul>\n<li>\n<p>Defining the application launch mode<\/p>\n<p>When an application is launched through an application control, its\nlaunch mode defines its behavior:<\/p>\n<ul>\n<li>The single launch mode means that the application is launched as\na main application (in a new group).<\/li>\n<li>The caller launch mode means that the application is launched as\na sub application belonging to the same group as the caller\napplication that is causing the application to be launched.<\/li>\n<\/ul>\n<p>You can set the application launch mode <a href=https://samsungtizenos.com/"..//vstools//tools//manifest-editor.md#launch_mode\">in the manifest\nfile<\/a>\nusing the <code>launch_mode<\/code> attribute of the <code><ui-application><\/code> element.\nIf the launch mode is set to <code>caller<\/code>, the application that calls\nthe application control can define the launch mode for the called\napplication using the <code>LaunchMode<\/code> property. However, if the called\napplication has set its launch mode in its manifest file to\n<code>single<\/code>, that setting overrides the caller application's launch\nmode request.<\/p>\n<\/li>\n<li>\n<p>Managing the application group<\/p>\n<p>Applications in the same group act as if they are in 1 stack. For\nexample, if application A wants to send an email using email\napplication B, application A can launch email application B,\nmaking email application B a sub application in the same group\nas application A. When both applications are running, and the\nuser presses the home button, both applications are hidden. When the\nuser later resumes the caller application (application A), the email\napplication B is shown on top of the caller application.<\/p>\n<p>If an application is launched in a group, it can be terminated by\nthe main (first) application in the group. If the main application\nis terminated or killed, the sub applications in the group are\nterminated automatically (they can be terminated by the framework\neven if they are hidden).<\/p>\n<p><strong>Figure: Group behavior<\/strong><\/p>\n<p><img src=https://samsungtizenos.com/"media//app_control_app_group_behavior.png/" alt=\"Group behavior\" \/><\/p>\n<\/li>\n<\/ul>\n<h2 id=\"content-prerequisites\"><a href=https://samsungtizenos.com/"#content-prerequisites\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Prerequisites<\/h2>\n<p>To enable your application to use the application control functionality, follow these steps:<\/p>\n<ol>\n<li>\n<p>To use application controls, the application has to request\npermission by adding the following privilege to the\n<code>tizen-manifest.xml<\/code> file:<\/p>\n<code class=\"language-XML\"><privileges>\n <privilege>http:\/\/tizen.org\/privilege\/appmanager.launch<\/privilege>\n<\/privileges>\n<\/code>\n<\/li>\n<li>\n<p>To use the methods and data types of the\n<a href=https://samsungtizenos.com/"//application//dotnet//api//TizenFX//latest//api//Tizen.Applications.md/">Tizen.Applications/a>/nnamespace, include it in your application:<\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">using<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Tizen<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Applications<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">;<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<\/li>\n<\/ol>\n<p><a name=\"use\"><\/a><\/p>\n<h2 id=\"content-launch-applications-using-extra-data\"><a href=https://samsungtizenos.com/"#content-launch-applications-using-extra-data\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Launch applications using extra data<\/h2>\n<p>To run a specific application control with some preconfigured parameters, follow these steps:<\/p>\n<ol>\n<li>\n<p>Prepare the application control:<\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">AppControl<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">appControl<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">new<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">AppControl<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">();<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<\/li>\n<li>\n<p>When the instance of the\n<a href=https://samsungtizenos.com/"//application//dotnet//api//TizenFX//latest//api//Tizen.Applications.AppControl.md/">Tizen.Applications.AppControl/a>/nclass is created, set the operation and MIME type. In this example,\nthe application control launches an application that has the\n<code>AppControlOperations.View<\/code> operation and the <code>image\/jpeg<\/code>\nMIME type.<\/p>\n<p>The <code>Operation<\/code> property is mandatory information for the\nlaunch request. If the operation is not specified,\n<code>AppControlOperations.Default<\/code> is used for the launch request:<\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">appControl.Operation <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> AppControlOperations.View;<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">appControl.Mime <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">"image\/jpeg"<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">;<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<\/li>\n<li>\n<p>Add extra data to the <code>Tizen.Applications.AppControl<\/code> instance by\nusing the <code>ExtraData<\/code> property and the <code>Add()<\/code> method of the\n<a href=https://samsungtizenos.com/"//application//dotnet//api//TizenFX//latest//api//Tizen.Applications.AppControl.ExtraDataCollection.md/">Tizen.Applications.AppControl.ExtraDataCollection/a> class.\nIn the following example, a message is added as extra data:<\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">appControl.ExtraData.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Add<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">"MyKey"<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">, <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">"My Message"<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">);<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<\/li>\n<li>\n<p>Launch the <code>Tizen.Applications.AppControl<\/code> instance with the\n<code>SendLaunchRequest()<\/code> method:<\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">AppControl.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">SendLaunchRequest<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(appControl, AppControlReplyCallback);<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<\/li>\n<li>\n<p>In the launched application, read the extra data added to the\napplication control by using the <code>ExtraData<\/code> property of the\n<a href=https://samsungtizenos.com/"//application//dotnet//api//TizenFX//latest//api//Tizen.Applications.ReceivedAppControl.md/">Tizen.Applications.ReceivedAppControl/a>/nclass instance and the <code>Get()<\/code> method of the\n<code>Tizen.Applications.ExtraDataCollection<\/code> class. The same property\nand method can be used in the original application to read the reply\nmessage, when the application control reply is returned:<\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#6A737D;--shiki-dark:#6A737D\">\/\/\/ Callee application<\/span><\/span>\n<span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">protected<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">override<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">void<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">OnAppControlReceived<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">AppControlReceivedEventArgs<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">e<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">)<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">{<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">string<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">message<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">;<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">ReceivedAppControl<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">receivedAppControl<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> e.ReceivedAppControl;<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#6A737D;--shiki-dark:#6A737D\"> \/\/\/ Get ExtraData coming from caller application<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> message <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> receivedAppControl.ExtraData.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Get<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"><<\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">string<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">>(<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">"MyKey"<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">);<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">if<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> (receivedAppControl.IsReplyRequest)<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> {<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">AppControl<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">replyRequest<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">new<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">AppControl<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">();<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> replyRequest.ExtraData.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Add<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">"ReplyKey"<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">, <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">"Reply message"<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">);<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#6A737D;--shiki-dark:#6A737D\"> \/\/\/ Send reply to the caller application<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> receivedAppControl.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">ReplyToLaunchRequest<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(replyRequest, AppControlReplyResult.Succeeded);<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> }<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">base<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">OnAppControlReceived<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(e);<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">}<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#6A737D;--shiki-dark:#6A737D\">\/\/\/ Caller application<\/span><\/span>\n<span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">static<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">void<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">AppControlReplyCallback<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Tizen<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Applications<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">AppControl<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">launchRequest<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">, <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Tizen<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Applications<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">AppControl<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">replyRequest<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">, <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">AppControlReplyResult<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">result<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">)<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">{<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">string<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">receivedMessage<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">;<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">if<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(result <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">>=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> AppControlReplyResult.Succeeded)<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> {<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> receivedMessage <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> replyRequest.ExtraData.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Get<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"><<\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">string<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">>(<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">"ReplyKey"<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">);<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> }<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">}<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<\/li>\n<\/ol>\n<p><a name=\"mode\"><\/a><\/p>\n<h2 id=\"content-control-the-launch-mode\"><a href=https://samsungtizenos.com/"#content-control-the-launch-mode\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Control the launch mode<\/h2>\n<p>The following code sets the application control in the caller application to launch a sub application within the same group:<\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">AppControl<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">appControl<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">new<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">AppControl<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">();<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">appControl.ApplicationId <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">"org.tizen.TestApp"<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">;<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">appControl.LaunchMode <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> AppControlLaunchMode.Group;<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">AppControl.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">SendLaunchRequest<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(appControl);<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<h2 id=\"content-related-information\"><a href=https://samsungtizenos.com/"#content-related-information\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Related information<\/h2>\n<ul>\n<li>Dependencies\n<ul>\n<li>Tizen 4.0 and Higher<\/li>\n<\/ul>\n<\/li>\n<li>API References\n<ul>\n<li><a href=https://samsungtizenos.com/"//application//dotnet//api//TizenFX//latest//api//Tizen.Applications.AppControl/">Tizen.Applications.AppControl/a> class<\/li>\n<li><a href=https://samsungtizenos.com/"//application//dotnet//api//TizenFX//latest//api//Tizen.Applications.AppControlOperations/">Tizen.Applications.AppControlOperations/a> class<\/li>\n<li><a href=https://samsungtizenos.com/"//application//dotnet//api//TizenFX//latest//api//Tizen.Applications.ReceivedAppControl/">Tizen.Applications.ReceivedAppControl/a> class<\/li>\n<li><a href=https://samsungtizenos.com/"//application//dotnet//api//TizenFX//latest//api//Tizen.Applications.AppControlData/">Tizen.Applications.AppControlData/a> class<\/li>\n<\/ul>\n<\/li>\n<\/ul>\n","table_of_content":"<ul class=\"table-of-contents\">\n<li><a href=https://samsungtizenos.com/"#content-launch-types\">Launch types<\/a><\/li>\n<li><a href=https://samsungtizenos.com/"#content-launch-requests\">Launch requests<\/a><\/li>\n<li><a href=https://samsungtizenos.com/"#content-explicit-launch-request\">Explicit launch request<\/a><\/li>\n<li><a href=https://samsungtizenos.com/"#content-implicit-launch-request\">Implicit launch request<\/a><\/li>\n<li><a href=https://samsungtizenos.com/"#content-determine-the-application-for-an-implicit-launch-request\">Determine the application for an implicit launch request<\/a><\/li>\n<li><a href=https://samsungtizenos.com/"#content-launch-process\">Launch process<\/a><\/li>\n<li><a href=https://samsungtizenos.com/"#content-launch-results\">Launch results<\/a><\/li>\n<li><a href=https://samsungtizenos.com/"#content-application-control-export\">Application control export<\/a><\/li>\n<li><a href=https://samsungtizenos.com/"#content-application-group-management\">Application group management<\/a><\/li>\n<li><a href=https://samsungtizenos.com/"#content-prerequisites\">Prerequisites<\/a><\/li>\n<li><a href=https://samsungtizenos.com/"#content-launch-applications-using-extra-data\">Launch applications using extra data<\/a><\/li>\n<li><a href=https://samsungtizenos.com/"#content-control-the-launch-mode\">Control the launch mode<\/a><\/li>\n<li><a href=https://samsungtizenos.com/"#content-related-information\">Related information<\/a><\/li>\n<\/ul>\n","title":"Application Controls","raw":null},{"class":"App\\Services\\Documentation\\Data\\RenderedMarkdown","s":"wrbl"}]},"memo":{"id":"sDt5WYjkMNhDYnxwCqUJ","name":"documentation::article","path":"docs\/application\/dotnet\/guides\/exchange-data-between-apps\/app-controls","method":"GET","release":"a-a-a","children":[],"scripts":[],"assets":[],"lazyLoaded":false,"lazyIsolated":true,"errors":[],"locale":"en","islands":[]},"checksum":"643d6faf673d00a6b56e17986d7291b78335f02a8e2da69a9689e5501cce73a3"}" wire:effects="[]" wire:id="sDt5WYjkMNhDYnxwCqUJ" wire:name="documentation::article" x-init="$wire.__lazyLoad('{"data":{"forMount":[{"markdown":[{"body":"<h1 id=\"content-application-controls\"><a href=\"#content-application-controls\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Application Controls<\/h1><div data-knowledge-base-metadata><\/div>\n<p>An application control (app control) is a way of sharing an\napplication's functionality with other applications. Using another\napplication's features through application controls reduces the time and\neffort needed to develop your application.<\/p>\n<p>An application can be launched by the user from the launcher or by\nanother application through the application control. The application\ncontrol launch request describes either an action to be performed by\nother applications, or the results of that action. The application can\nalso receive results from the launched application through an\napplication control reply.<\/p>\n<p>The main application control features are described below:<\/p>\n<ul>\n<li>\n<p>Requesting application launches<\/p>\n<p>You can <a href=\"#request\">create application control launch requests<\/a> to\nask the platform to launch an application to perform a specific task\nfor you.<\/p>\n<p>You can use different <a href=\"#launch\">launch types<\/a> (implicit or\nexplicit), depending on whether you know the exact application you\nwant to launch. When you make an implicit launch request, the\nplatform uses the conditions in the launch request to determine\nwhich application can be launched to handle the requested task.<\/p>\n<\/li>\n<li>\n<p>Launching an application due to a launch request<\/p>\n<p>After the platform has found the correct application to launch, the\napplication is activated through the <a href=\"#process\">launch process<\/a>, and\ncan perform the task the original application has requested. After\nthe task is completed, the launched application can send the results\nback to the original application.<\/p>\n<\/li>\n<li>\n<p>Handling application control launch results<\/p>\n<p>When the launched application is finished with its task and has sent\nback the results, you can <a href=\"#results\">receive those results<\/a> in your\napplication and handle them accordingly.<\/p>\n<\/li>\n<li>\n<p>Exporting application controls<\/p>\n<p>You can <a href=\"#export_appcontrol\">allow other applications to launch your application and use\nyour functionalities<\/a> by exporting your\napplication features as application controls.<\/p>\n<\/li>\n<li>\n<p>Controlling application groups through the launch mode<\/p>\n<p>You can <a href=\"#group\">set the launch mode<\/a> when launching an application\nthrough an application control. The launch mode determines whether\nthe application is launched in its own group, or as a sub\napplication within an existing group.<\/p>\n<\/li>\n<\/ul>\n<p><a name=\"launch\"><\/a><\/p>\n<h2 id=\"content-launch-types\"><a href=\"#content-launch-types\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Launch types<\/h2>\n<p>To launch an application using application control, use the 2 different launch types described below:<\/p>\n<ul>\n<li>\n<p>Explicit launch<\/p>\n<p>Explicit launch means that you launch a specific application with\nthe application ID. When you <a href=\"#explicit\">request an explicit\nlaunch<\/a>:<\/p>\n<ul>\n<li>If the underlying application launcher framework finds an\napplication matched with the given application ID in the\ninstalled application list, it launches the application in a\nnew process. If the matched application is not found, the\n<code>AppNotFoundException<\/code> occurs. Additional information (such as\noperation, URI, or MIME type) is not used to select an\napplication for an explicit launch.<\/li>\n<li>If the <code>Operation<\/code> property of a\n<a href=\"\/application\/dotnet\/api\/TizenFX\/latest\/api\/Tizen.Applications.AppControl.md\">Tizen.Applications.AppControl<\/a>\ninstance is set to <code>AppControlOperations.Default<\/code>, the\napplication ID must be set. Otherwise the\n<code>ArgumentException<\/code> occurs.<\/li>\n<\/ul>\n<div class=\"md-alert md-alert-note\">\n<span><svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\"><path d=\"M0 8a8 8 0 1 1 16 0A8 8 0 0 1 0 8Zm8-6.5a6.5 6.5 0 1 0 0 13 6.5 6.5 0 0 0 0-13ZM6.5 7.75A.75.75 0 0 1 7.25 7h1a.75.75 0 0 1 .75.75v2.75h.25a.75.75 0 0 1 0 1.5h-2a.75.75 0 0 1 0-1.5h.25v-2h-.25a.75.75 0 0 1-.75-.75ZM8 6a1 1 0 1 1 0-2 1 1 0 0 1 0 2Z\"\/><\/svg>Note<\/span>\n<p>Be careful when using the explicit launch, because if the\ntarget application does not exist on the device, you need to handle\nthe <code>AppNotFoundException<\/code>. If you want to launch any application\nthat supports a certain operation, use the implicit launch.<\/p>\n<\/div>\n<\/li>\n<li>\n<p>Implicit launch<\/p>\n<p>Implicit launch means that you launch any application which matches\nthe operation, URI (or scheme), or MIME type you need. When you\n<a href=\"#implicit\">request an implicit launch<\/a>:<\/p>\n<ul>\n<li>To determine which application can be launched, the application\nlauncher framework compares the operation, URI, and MIME\ntype conditions.<\/li>\n<li>The application launcher framework iterates the application\ncontrols of all applications on the device to <a href=\"#resolution\">find the\napplications that match<\/a> the given conditions.<\/li>\n<li>If only 1 application is matched for the given conditions, that\napplication is launched. If multiple matching applications are\nfound, the application selector is shown and the user can select\nthe proper application.<\/li>\n<\/ul>\n<\/li>\n<\/ul>\n<p><a name=\"request\"><\/a><\/p>\n<h2 id=\"content-launch-requests\"><a href=\"#content-launch-requests\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Launch requests<\/h2>\n<p>To launch an application with the application control, you must create a\nlaunch request. You must create an instance of the\n<a href=\"\/application\/dotnet\/api\/TizenFX\/latest\/api\/Tizen.Applications.AppControl.md\">Tizen.Applications.AppControl<\/a>\nclass, and add the conditions for selecting the application to be\nlaunched. You can add the following information to the instance:<\/p>\n<ul>\n<li>\n<p><code>Operation<\/code>: Action to be performed by the launched application.<\/p>\n<div class=\"md-alert md-alert-note\">\n<span><svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\"><path d=\"M0 8a8 8 0 1 1 16 0A8 8 0 0 1 0 8Zm8-6.5a6.5 6.5 0 1 0 0 13 6.5 6.5 0 0 0 0-13ZM6.5 7.75A.75.75 0 0 1 7.25 7h1a.75.75 0 0 1 .75.75v2.75h.25a.75.75 0 0 1 0 1.5h-2a.75.75 0 0 1 0-1.5h.25v-2h-.25a.75.75 0 0 1-.75-.75ZM8 6a1 1 0 1 1 0-2 1 1 0 0 1 0 2Z\"\/><\/svg>Note<\/span>\n<p>The operation name format is\n<code>http:\/\/tizen.org\/appcontrol\/operation\/&lt;verb&gt;<\/code>. You can also use an\ninstance of the\n<a href=\"\/application\/dotnet\/api\/TizenFX\/latest\/api\/Tizen.Applications.AppControlOperations.md\">Tizen.Applications.AppControlOperations<\/a> class.<\/p>\n<\/div>\n<p>The operation is mandatory information for sending the\nlaunch request.<\/p>\n<\/li>\n<li>\n<p><code>Uri<\/code>: Data itself to be performed.<\/p>\n<\/li>\n<li>\n<p><code>Mime<\/code>: Specific type of the URI.<\/p>\n<\/li>\n<li>\n<p><code>ApplicationId<\/code>: ID of the application to be launched.<\/p>\n<\/li>\n<li>\n<p><code>ExtraData<\/code>: Key-value pairs to <a href=\"#use\">provide additional information for\nthe launch request and launch result<\/a>.<\/p>\n<\/li>\n<\/ul>\n<p><a name=\"explicit\"><\/a><\/p>\n<h3 id=\"content-explicit-launch-request\"><a href=\"#content-explicit-launch-request\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Explicit launch request<\/h3>\n<p>The following example shows how to create an explicit launch request\nwhich launches an application explicitly by setting the <code>ApplicationId<\/code>\nproperty of the\n<a href=\"\/application\/dotnet\/api\/TizenFX\/latest\/api\/Tizen.Applications.AppControl.md\">Tizen.Applications.AppControl<\/a>\nclass instance:<\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">AppControl<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">appcontrol<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">new<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">AppControl<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">();<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">appcontrol.Operation <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> AppControlOperations.Default;<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">appcontrol.ApplicationId <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">&quot;org.tizen.TestApp&quot;<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">;<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">AppControl.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">SendLaunchRequest<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(appcontrol);<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<p>If you want to launch an AppControl asynchronously, use SendLaunchRequestAsync().<\/p>\n<p><a name=\"implicit\"><\/a><\/p>\n<h3 id=\"content-implicit-launch-request\"><a href=\"#content-implicit-launch-request\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Implicit launch request<\/h3>\n<p>The following examples show how to create an implicit launch request:<\/p>\n<ul>\n<li>\n<p>To launch a camera application with a specific operation and MIME\ntype, use the following code:<\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">AppControl<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">appcontrol<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">new<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">AppControl<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">();<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">appcontrol.Operation <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> AppControlOperations.CreateContent;<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">appcontrol.Mime <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">&quot;image\/jpg&quot;<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">;<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">AppControl.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">SendLaunchRequest<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(appcontrol);<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<\/li>\n<li>\n<p>To launch a viewer application with a specific operation, URI, and\nMIME type, use the following code:<\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">AppControl<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">appcontrol<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">new<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">AppControl<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">();<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">appcontrol.Operation <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> AppControlOperations.View;<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">appcontrol.Mime <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">&quot;image\/*&quot;<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">;<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">appcontrol.Uri <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">&quot;file:\/\/\/home\/myhome\/Photos\/1_photo.jpg&quot;<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">;<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">AppControl.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">SendLaunchRequest<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(appcontrol);<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<\/li>\n<\/ul>\n<p><a name=\"resolution\"><\/a><\/p>\n<h3 id=\"content-determine-the-application-for-an-implicit-launch-request\"><a href=\"#content-determine-the-application-for-an-implicit-launch-request\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Determine the application for an implicit launch request<\/h3>\n<p>In the case of an implicit launch, the platform determines which\napplication to launch by &quot;resolving the application control&quot;. This means\nthat the platform considers the given conditions (operation, URI, and\nMIME type) in the launch request, searches the filters (installed\napplications with available application controls) on the device, and\nattempts to find a match.<\/p>\n<p>The launch request conditions are matched to the available filters using\nthe following logic:<\/p>\n<ol>\n<li>\n<p>The operation value is matched first. An exact match is required for\nthe value in both the launch request and the filters.<\/p>\n<p>If multiple matching filters with identical operations are\navailable, the URI and MIME types in the matching filters\nare compared.<\/p>\n<\/li>\n<li>\n<p>If the launch request has URI or MIME types as a condition, the\ncomparison is done only among the filters that have URI or\nMIME types. For example, if the launch request has a URI, but a\nfilter does not, that filter is not added to the result even if the\noperations are the same. Similarly, if the launch request has MIME\ntypes, it is not compared to the filters that have no MIME types.<\/p>\n<p>An exception is applied to the URIs with a &quot;file&quot; scheme for\nthe value. If the launch request URI contains an existing file path\nand no MIME types are supplied, the filters that have the MIME type\nof the given file path are also added to the results.<\/p>\n<div class=\"md-alert md-alert-note\">\n<span><svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\"><path d=\"M0 8a8 8 0 1 1 16 0A8 8 0 0 1 0 8Zm8-6.5a6.5 6.5 0 1 0 0 13 6.5 6.5 0 0 0 0-13ZM6.5 7.75A.75.75 0 0 1 7.25 7h1a.75.75 0 0 1 .75.75v2.75h.25a.75.75 0 0 1 0 1.5h-2a.75.75 0 0 1 0-1.5h.25v-2h-.25a.75.75 0 0 1-.75-.75ZM8 6a1 1 0 1 1 0-2 1 1 0 0 1 0 2Z\"\/><\/svg>Note<\/span>\n<p>A filter (application) that expects to match with any form\nof URI and any type of MIME must use <code>'*'<\/code> and <code>*\/*<\/code> in their\napplication control information in the <code>tizen-manifest.xml<\/code> file,\ninstead of leaving the value to <code>NULL<\/code>. Otherwise, the application\nis discarded by the platform when the application control\nis resolved.<\/p>\n<\/div>\n<\/li>\n<li>\n<p>Unlike the operation, the URI and MIME types support wildcards on\nthe filters. Detailed conditions for matches are described below:<\/p>\n<ul>\n<li>The URI match can be an exact, partial (scheme), or pattern\nmatch according to the value in the filters. URI filters are\nmatched with the launch request if:\n<ul>\n<li>Both URIs are exactly the same.<\/li>\n<li>Launch request URI passes the test with a <code>glob()<\/code>-like\nfunction with the filter URI.<\/li>\n<li>Scheme and host part of the URI in the launch request and\nfilters are the same.<\/li>\n<li>Scheme part of the URI in the launch request and filters is\nthe same.<\/li>\n<\/ul>\n<\/li>\n<li>The MIME type match can be an exact or pattern match according\nto the value in the filters. MIME type filters are matched with\nthe launch request if:\n<ul>\n<li>Both MIME types are exactly the same.<\/li>\n<li>MIME type in the launch request and filters has the same\ntype and '*' for the subtype.<\/li>\n<li>The filters have <code>*\/*<\/code> for the MIME type.<\/li>\n<\/ul>\n<\/li>\n<\/ul>\n<\/li>\n<\/ol>\n<p>The following examples show different scenarios for the results of resolving the application control:<\/p>\n<ul>\n<li>\n<p>Operation provided:<\/p>\n<ul>\n<li>Request:\n<ul>\n<li>Operation: <code>http:\/\/tizen.org\/appcontrol\/operation\/view<\/code><\/li>\n<li>URI: <code>NULL<\/code><\/li>\n<li>MIME: <code>NULL<\/code><\/li>\n<\/ul>\n<\/li>\n<li>Result (the reason for the failure is marked in <strong>bold<\/strong>):<\/li>\n<\/ul>\n<p><strong>Table: Scenario when only the operation is provided<\/strong><\/p>\n<div class=\"overflow-auto grid table-fixed\" data-table-container=\"data-table-container\"><table>\n<thead>\n<tr>\n<th>Filter ID<\/th>\n<th>Operation<\/th>\n<th>URI<\/th>\n<th>MIME<\/th>\n<th>Result<\/th>\n<\/tr>\n<\/thead>\n<tbody>\n<tr>\n<td>1<\/td>\n<td><code>http:\/\/tizen.org\/appcontrol\/operation\/view<\/code><\/td>\n<td><code>NULL<\/code><\/td>\n<td><code>NULL<\/code><\/td>\n<td>Pass<\/td>\n<\/tr>\n<tr>\n<td>2<\/td>\n<td><strong><code>http:\/\/tizen.org\/appcontrol\/operation\/default<\/code><\/strong><\/td>\n<td><code>NULL<\/code><\/td>\n<td><code>NULL<\/code><\/td>\n<td>Fail<\/td>\n<\/tr>\n<tr>\n<td>3<\/td>\n<td><code>http:\/\/tizen.org\/appcontrol\/operation\/view<\/code><\/td>\n<td><strong><code>file<\/code><\/strong><\/td>\n<td><code>NULL<\/code><\/td>\n<td>Fail<\/td>\n<\/tr>\n<\/tbody>\n<\/table><\/div>\n<\/li>\n<li>\n<p>Operation and URI provided:<\/p>\n<ul>\n<li>Request:\n<ul>\n<li>Operation: <code>http:\/\/tizen.org\/appcontrol\/operation\/view<\/code><\/li>\n<li>URI: <code>file:\/\/\/usr\/share\/icons\/calendar.png<\/code><\/li>\n<li>MIME: <code>NULL<\/code><\/li>\n<\/ul>\n<\/li>\n<li>Result (the reason for the failure is marked in <strong>bold<\/strong>):<\/li>\n<\/ul>\n<p><strong>Table: Scenario when the operation and URI are provided<\/strong><\/p>\n<div class=\"overflow-auto grid table-fixed\" data-table-container=\"data-table-container\"><table>\n<thead>\n<tr>\n<th>Filter ID<\/th>\n<th>Operation<\/th>\n<th>URI<\/th>\n<th>MIME<\/th>\n<th>Result<\/th>\n<\/tr>\n<\/thead>\n<tbody>\n<tr>\n<td>1<\/td>\n<td><code>http:\/\/tizen.org\/appcontrol\/operation\/view<\/code><\/td>\n<td><strong><code>NULL<\/code><\/strong><\/td>\n<td><code>NULL<\/code><\/td>\n<td>Fail<\/td>\n<\/tr>\n<tr>\n<td>2<\/td>\n<td><code>http:\/\/tizen.org\/appcontrol\/operation\/view<\/code><\/td>\n<td><code>file:\/\/\/usr\/share\/icons\/calendar.png<\/code><\/td>\n<td><code>*\/*<\/code><\/td>\n<td>Pass<\/td>\n<\/tr>\n<tr>\n<td>3<\/td>\n<td><code>http:\/\/tizen.org\/appcontrol\/operation\/view<\/code><\/td>\n<td><code>file:\/\/\/*<\/code><\/td>\n<td><code>*\/*<\/code><\/td>\n<td>Pass<\/td>\n<\/tr>\n<tr>\n<td>4<\/td>\n<td><code>http:\/\/tizen.org\/appcontrol\/operation\/view<\/code><\/td>\n<td><code>file<\/code><\/td>\n<td><code>*\/*<\/code><\/td>\n<td>Pass<\/td>\n<\/tr>\n<tr>\n<td>5<\/td>\n<td><code>http:\/\/tizen.org\/appcontrol\/operation\/view<\/code><\/td>\n<td><strong><code>http<\/code><\/strong><\/td>\n<td><code>*\/*<\/code><\/td>\n<td>Fail<\/td>\n<\/tr>\n<tr>\n<td>6<\/td>\n<td><code>http:\/\/tizen.org\/appcontrol\/operation\/view<\/code><\/td>\n<td><code>NULL<\/code><\/td>\n<td><code>image\/png<\/code><\/td>\n<td>Pass<\/td>\n<\/tr>\n<tr>\n<td>7<\/td>\n<td><code>http:\/\/tizen.org\/appcontrol\/operation\/view<\/code><\/td>\n<td><code>NULL<\/code><\/td>\n<td><strong><code>image\/jpg<\/code><\/strong><\/td>\n<td>Fail<\/td>\n<\/tr>\n<\/tbody>\n<\/table><\/div>\n<\/li>\n<li>\n<p>Operation and MIME type provided:<\/p>\n<ul>\n<li>Request:\n<ul>\n<li>Operation: <code>http:\/\/tizen.org\/appcontrol\/operation\/view<\/code><\/li>\n<li>URI: <code>NULL<\/code><\/li>\n<li>MIME: <code>image\/png<\/code><\/li>\n<\/ul>\n<\/li>\n<li>Result (the reason for the failure is marked in <strong>bold<\/strong>):<\/li>\n<\/ul>\n<p><strong>Table: Scenario when the operation and MIME type are provided<\/strong><\/p>\n<div class=\"overflow-auto grid table-fixed\" data-table-container=\"data-table-container\"><table>\n<thead>\n<tr>\n<th>Filter ID<\/th>\n<th>Operation<\/th>\n<th>URI<\/th>\n<th>MIME<\/th>\n<th>Result<\/th>\n<\/tr>\n<\/thead>\n<tbody>\n<tr>\n<td>1<\/td>\n<td><code>http:\/\/tizen.org\/appcontrol\/operation\/view<\/code><\/td>\n<td><code>NULL<\/code><\/td>\n<td><code>image\/png<\/code><\/td>\n<td>Pass<\/td>\n<\/tr>\n<tr>\n<td>2<\/td>\n<td><code>http:\/\/tizen.org\/appcontrol\/operation\/view<\/code><\/td>\n<td><code>NULL<\/code><\/td>\n<td><code>image\/*<\/code><\/td>\n<td>Pass<\/td>\n<\/tr>\n<tr>\n<td>3<\/td>\n<td><code>http:\/\/tizen.org\/appcontrol\/operation\/view<\/code><\/td>\n<td><code>NULL<\/code><\/td>\n<td><code>*\/*<\/code><\/td>\n<td>Pass<\/td>\n<\/tr>\n<tr>\n<td>4<\/td>\n<td><code>http:\/\/tizen.org\/appcontrol\/operation\/view<\/code><\/td>\n<td><code>file:\/\/\/usr\/share\/icons\/calendar.png<\/code><\/td>\n<td><strong><code>NULL<\/code><\/strong><\/td>\n<td>Fail<\/td>\n<\/tr>\n<tr>\n<td>5<\/td>\n<td><code>http:\/\/tizen.org\/appcontrol\/operation\/view<\/code><\/td>\n<td><code>NULL<\/code><\/td>\n<td><strong><code>image\/jpg<\/code><\/strong><\/td>\n<td>Fail<\/td>\n<\/tr>\n<tr>\n<td>6<\/td>\n<td><code>http:\/\/tizen.org\/appcontrol\/operation\/view<\/code><\/td>\n<td><code>NULL<\/code><\/td>\n<td><strong><code>video\/*<\/code><\/strong><\/td>\n<td>Fail<\/td>\n<\/tr>\n<tr>\n<td>7<\/td>\n<td><code>http:\/\/tizen.org\/appcontrol\/operation\/view<\/code><\/td>\n<td><strong><code>http:\/\/tizen.org\/favorites.png<\/code><\/strong><\/td>\n<td><code>image\/png<\/code><\/td>\n<td>Fail<\/td>\n<\/tr>\n<\/tbody>\n<\/table><\/div>\n<\/li>\n<li>\n<p>Operation, URI, and MIME type provided:<\/p>\n<ul>\n<li>Request:\n<ul>\n<li>Operation: <code>http:\/\/tizen.org\/appcontrol\/operation\/view<\/code><\/li>\n<li>URI: <code>http:\/\/www.tizen.org\/favorites.png<\/code><\/li>\n<li>MIME: <code>image\/png<\/code><\/li>\n<\/ul>\n<\/li>\n<li>Result (the reason for the failure is marked in <strong>bold<\/strong>):<\/li>\n<\/ul>\n<p><strong>Table: Scenario when the operation, URI, and MIME type are provided<\/strong><\/p>\n<div class=\"overflow-auto grid table-fixed\" data-table-container=\"data-table-container\"><table>\n<thead>\n<tr>\n<th>Filter ID<\/th>\n<th>Operation<\/th>\n<th>URI<\/th>\n<th>MIME<\/th>\n<th>Result<\/th>\n<\/tr>\n<\/thead>\n<tbody>\n<tr>\n<td>1<\/td>\n<td><code>http:\/\/tizen.org\/appcontrol\/operation\/view<\/code><\/td>\n<td><code>http:\/\/www.tizen.org\/favorites.png<\/code><\/td>\n<td><code>image\/png<\/code><\/td>\n<td>Pass<\/td>\n<\/tr>\n<tr>\n<td>2<\/td>\n<td><code>http:\/\/tizen.org\/appcontrol\/operation\/view<\/code><\/td>\n<td><code>http:\/\/www.tizen.org\/favorites.png<\/code><\/td>\n<td><strong><code>NULL<\/code><\/strong><\/td>\n<td>Fail<\/td>\n<\/tr>\n<tr>\n<td>3<\/td>\n<td><code>http:\/\/tizen.org\/appcontrol\/operation\/view<\/code><\/td>\n<td><code>http:\/\/www.tizen.org\/*<\/code><\/td>\n<td><code>image\/png<\/code><\/td>\n<td>Pass<\/td>\n<\/tr>\n<tr>\n<td>4<\/td>\n<td><code>http:\/\/tizen.org\/appcontrol\/operation\/view<\/code><\/td>\n<td><code>http<\/code><\/td>\n<td><code>image\/png<\/code><\/td>\n<td>Pass<\/td>\n<\/tr>\n<tr>\n<td>5<\/td>\n<td><code>http:\/\/tizen.org\/appcontrol\/operation\/view<\/code><\/td>\n<td><strong><code>NULL<\/code><\/strong><\/td>\n<td><code>image\/png<\/code><\/td>\n<td>Fail<\/td>\n<\/tr>\n<tr>\n<td>6<\/td>\n<td><code>http:\/\/tizen.org\/appcontrol\/operation\/view<\/code><\/td>\n<td><code>*<\/code><\/td>\n<td><code>*\/*<\/code><\/td>\n<td>Pass<\/td>\n<\/tr>\n<\/tbody>\n<\/table><\/div>\n<\/li>\n<\/ul>\n<p><a name=\"process\"><\/a><\/p>\n<h2 id=\"content-launch-process\"><a href=\"#content-launch-process\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Launch process<\/h2>\n<p>Regardless of the launch request type, when the application launcher\nframework has received and resolved a launch request, it starts the\napplication by creating a new process and calling the entry point of the\napplication:<\/p>\n<ol>\n<li>\n<p>Like a conventional C# application, the main method of the\napplication is its entry point. In a Tizen .NET application, the\nmain task is to hand over control to the application framework by\ncalling the <code>Run()<\/code> method:<\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">class<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">App<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> : <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">NUIApplication<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">{<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">    <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">protected<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">override<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">void<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">OnCreate<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">()<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">    {<\/span><\/span>\n<span class=\"line\"><span style=\"color:#6A737D;--shiki-dark:#6A737D\">        \/\/\/ Hook to take necessary actions before main event loop starts; this<\/span><\/span>\n<span class=\"line\"><span style=\"color:#6A737D;--shiki-dark:#6A737D\">        \/\/\/ usually means initializing the UI<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">        <\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">base<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">OnCreate<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">();<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">    }<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">    <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">protected<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">override<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">void<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">OnAppControlReceived<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">AppControlReceivedEventArgs<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">e<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">)<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">    {<\/span><\/span>\n<span class=\"line\"><span style=\"color:#6A737D;--shiki-dark:#6A737D\">        \/\/\/ Handle the launch request, show the user the task requested through the<\/span><\/span>\n<span class=\"line\"><span style=\"color:#6A737D;--shiki-dark:#6A737D\">        \/\/\/ &quot;AppControlReceivedEventArgs&quot; parameter<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">        <\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">base<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">OnAppControlReceived<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(e);<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">    }<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">    <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">protected<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">override<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">void<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">OnPause<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">()<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">    {<\/span><\/span>\n<span class=\"line\"><span style=\"color:#6A737D;--shiki-dark:#6A737D\">        \/\/\/ Take necessary actions when application becomes invisible<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">        <\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">base<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">OnPause<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">();<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">    }<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">    <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">protected<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">override<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">void<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">OnResume<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">()<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">    {<\/span><\/span>\n<span class=\"line\"><span style=\"color:#6A737D;--shiki-dark:#6A737D\">        \/\/\/ Take necessary actions when application becomes visible<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">        <\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">base<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">OnResume<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">();<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">    }<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">    <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">protected<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">override<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">void<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">OnTerminate<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">()<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">    {<\/span><\/span>\n<span class=\"line\"><span style=\"color:#6A737D;--shiki-dark:#6A737D\">        \/\/\/ Release all resources<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">        <\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">base<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">OnTerminate<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">();<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">    }<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">    <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">static<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">void<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Main<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(<\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">string<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">[] <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">args<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">)<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">    {<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">        <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">App<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">app<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">new<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">App<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">();<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">        app.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Run<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(args);<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">    }<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">}<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<\/li>\n<li>\n<p>The <code>Run()<\/code> method initializes the application and starts the\nmain loop.<\/p>\n<p>It takes a parameter and uses it to initialize the application. The\n<code>args<\/code> parameter contains the values from the application framework,\nand you must never change their values.<\/p>\n<\/li>\n<li>\n<p>When the <code>Run()<\/code> method is first invoked, the application moves from\nthe ready state to the created state, and must initialize itself.\nDuring this transition, the application framework calls the\napplication's <code>OnCreate()<\/code> state transition method just before the\napplication enters the main loop. Within the method, you must\ninitialize the application resources and create the main window.<\/p>\n<\/li>\n<li>\n<p>Just after the application enters the main loop, the application\nframework calls the application's <code>OnAppControlReceived()<\/code> method.<\/p>\n<p>The reason the application was launched is contained in an instance\nof the\n<a href=\"\/application\/dotnet\/api\/TizenFX\/latest\/api\/Tizen.Applications.ReceivedAppControl.md\">Tizen.Applications.ReceivedAppControl<\/a>\nclass, which is derived from the\n<a href=\"\/application\/dotnet\/api\/TizenFX\/latest\/api\/Tizen.Applications.AppControl.md\">Tizen.Applications.AppControl<\/a> class.\nThe application is always responsible for checking the content of\nthe <code>Tizen.Applications.ReceivedAppControl<\/code> instance and\nresponding appropriately. The content of the\n<code>Tizen.Applications.ReceivedAppControl<\/code> instance can be empty if\nthe application is launched by the user from the launcher.<\/p>\n<p>If the application wants to return the result of the application\ncontrol operation to the application that originally sent the launch\nrequest, the result can be sent with the <code>ReplyToLaunchRequest()<\/code>\nmethod of the <code>Tizen.Applications.ReceivedAppControl<\/code> class:<\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">protected<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">override<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">void<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">OnAppControlReceived<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">AppControlReceivedEventArgs<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">e<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">)<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">{<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">    <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">ReceivedAppControl<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">receivedAppControl<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> e.ReceivedAppControl;<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">    <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">if<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> (receivedAppControl.IsReplyRequest)<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">    {<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">        <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">AppControl<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">replyRequest<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">new<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">AppControl<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">();<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#6A737D;--shiki-dark:#6A737D\">        \/\/\/ Send reply to the caller app<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">        receivedAppControl.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">ReplyToLaunchRequest<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(replyRequest, AppControlReplyResult.Succeeded);<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">    }<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">    <\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">base<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">OnAppControlReceived<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(e);<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">}<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<\/li>\n<\/ol>\n<p><a name=\"results\"><\/a><\/p>\n<h2 id=\"content-launch-results\"><a href=\"#content-launch-results\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Launch results<\/h2>\n<p>After the requested application (callee) has been launched and the\nlaunched application has performed the requested operation, the results\nof the operation are delivered back to the application that sent the\noriginal launch request (caller).<\/p>\n<p>The following code example requests the launch of another application\nand sets the <code>AppControlReplyCallback()<\/code> method to get the launch\nresult:<\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">public<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">void<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">LaunchRequestResultTest<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">()<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">{<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">    <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">string<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">MyAppId<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">&quot;org.tizen.MyApp&quot;<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">;<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">    <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">AppControl<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">appCtrl<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">new<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">AppControl<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">();<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">    appCtrl.Operation <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> AppControlOperations.Default;<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">    appCtrl.ApplicationId <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> MyAppId;<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#6A737D;--shiki-dark:#6A737D\">    \/\/\/ Set method to get the launch result<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">    AppControl.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">SendLaunchRequest<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(appCtrl, AppControlReplyCallback);<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">}<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<p>The results are delivered in an instance of the\n<a href=\"\/application\/dotnet\/api\/TizenFX\/latest\/api\/Tizen.Applications.AppControl.md\">Tizen.Applications.AppControl<\/a>\ninstance with extra data. For some cases, the\n<a href=\"\/application\/dotnet\/api\/TizenFX\/latest\/api\/Tizen.Applications.AppControlData.md\">Tizen.Applications.AppControlData<\/a>\nprovides predefined extra data keys. If the key you need is not\npredefined, you can create your own key. However, the customized key\nmust be shared between the caller and callee applications.<\/p>\n<p>The following example shows how you can retrieve the results of the\nlaunch request and requested operation by implementing the\n<code>AppControlReplyCallback()<\/code> method:<\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#6A737D;--shiki-dark:#6A737D\">\/\/\/ Method for getting the result<\/span><\/span>\n<span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">static<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">void<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">AppControlReplyCallback<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Tizen<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Applications<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">AppControl<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">launchRequest<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">, <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Tizen<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Applications<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">AppControl<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">replyRequest<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">, <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">AppControlReplyResult<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">result<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">)<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">{<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">    <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">string<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">callerAppId<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">;<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">    <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">string<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">selected<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">;<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">    <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">if<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> (result <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">&gt;=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> AppControlReplyResult.Succeeded)<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">    {<\/span><\/span>\n<span class=\"line\"><span style=\"color:#6A737D;--shiki-dark:#6A737D\">        \/\/\/ Get the value of ExtraData sent by callee<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">        callerAppId <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> replyRequest.ExtraData.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Get<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">&lt;<\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">string<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">&gt;(<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">&quot;CallerApplicationId&quot;<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">);<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">        selected <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> replyRequest.ExtraData.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Get<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">&lt;<\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">string<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">&gt;(AppControlData.Selected);<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">    }<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">}<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<p><a name=\"export_appcontrol\"><\/a><\/p>\n<h2 id=\"content-application-control-export\"><a href=\"#content-application-control-export\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Application control export<\/h2>\n<p>You can allow other applications to launch your application and use your\napplication features through application controls by exporting your\napplication control functionalities. To allow other applications to\nlaunch your application implicitly without the application ID, specify\nyour application control information in Visual Studio.<\/p>\n<p><strong>Figure: Exporting app control<\/strong><\/p>\n<p><img src=\"media\/app_control_exporting_appcontrol.png\" alt=\"Exporting app control\" \/><\/p>\n<p>The operation, URI, and MIME type information are used when <a href=\"#resolution\">resolving\nthe application control<\/a>. The operation information is\nmandatory, while the URI or MIME type information is optional. Any\napplication requesting a launch of your application must either specify\nyour application ID (for an explicit launch) or have the same operation\nvalue and applicable URI and MIME type information (for an implicit\nlaunch).\nYou can define privileges to restrict your application from launching. To launch\nyour application, the caller application must request for launch permission\nby defining privileges in the <code>tizen-manifest.xml<\/code> file.<\/p>\n<div class=\"md-alert md-alert-note\">\n<span><svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\"><path d=\"M0 8a8 8 0 1 1 16 0A8 8 0 0 1 0 8Zm8-6.5a6.5 6.5 0 1 0 0 13 6.5 6.5 0 0 0 0-13ZM6.5 7.75A.75.75 0 0 1 7.25 7h1a.75.75 0 0 1 .75.75v2.75h.25a.75.75 0 0 1 0 1.5h-2a.75.75 0 0 1 0-1.5h.25v-2h-.25a.75.75 0 0 1-.75-.75ZM8 6a1 1 0 1 1 0-2 1 1 0 0 1 0 2Z\"\/><\/svg>Note<\/span>\n<p>The URI or MIME type can contain wildcards, such as '*', to\nmatch against given conditions in the application control:<\/p>\n<ul>\n<li>In the MIME type, you can use two types of wildcards: <code>image\/*<\/code> and\n<code>*\/*<\/code>.<\/li>\n<li>In the URI, a more complex pattern of wildcards with similar\nsemantics as the standard <code>glob()<\/code> function is available: '*'\nmatches an arbitrary, possibly empty, string, and '?' matches an\narbitrary character. Unlike in the <code>glob()<\/code> function, the '\/'\ncharacter can be matched by the wildcards. There are no [...]\ncharacter ranges, and the wildcards '*' and '?' cannot be escaped\nto include them literally in a pattern.<\/li>\n<\/ul>\n<\/div>\n<p><a name=\"group\"><\/a><\/p>\n<h2 id=\"content-application-group-management\"><a href=\"#content-application-group-management\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Application group management<\/h2>\n<p>You can <a href=\"#mode\">define the application launch mode<\/a> and group your applications into entities that can be managed together.<\/p>\n<p>The main application group features include the following:<\/p>\n<ul>\n<li>\n<p>Defining the application launch mode<\/p>\n<p>When an application is launched through an application control, its\nlaunch mode defines its behavior:<\/p>\n<ul>\n<li>The single launch mode means that the application is launched as\na main application (in a new group).<\/li>\n<li>The caller launch mode means that the application is launched as\na sub application belonging to the same group as the caller\napplication that is causing the application to be launched.<\/li>\n<\/ul>\n<p>You can set the application launch mode <a href=\"..\/..\/..\/vstools\/tools\/manifest-editor.md#launch_mode\">in the manifest\nfile<\/a>\nusing the <code>launch_mode<\/code> attribute of the <code>&lt;ui-application&gt;<\/code> element.\nIf the launch mode is set to <code>caller<\/code>, the application that calls\nthe application control can define the launch mode for the called\napplication using the <code>LaunchMode<\/code> property. However, if the called\napplication has set its launch mode in its manifest file to\n<code>single<\/code>, that setting overrides the caller application's launch\nmode request.<\/p>\n<\/li>\n<li>\n<p>Managing the application group<\/p>\n<p>Applications in the same group act as if they are in 1 stack. For\nexample, if application A wants to send an email using email\napplication B, application A can launch email application B,\nmaking email application B a sub application in the same group\nas application A. When both applications are running, and the\nuser presses the home button, both applications are hidden. When the\nuser later resumes the caller application (application A), the email\napplication B is shown on top of the caller application.<\/p>\n<p>If an application is launched in a group, it can be terminated by\nthe main (first) application in the group. If the main application\nis terminated or killed, the sub applications in the group are\nterminated automatically (they can be terminated by the framework\neven if they are hidden).<\/p>\n<p><strong>Figure: Group behavior<\/strong><\/p>\n<p><img src=\"media\/app_control_app_group_behavior.png\" alt=\"Group behavior\" \/><\/p>\n<\/li>\n<\/ul>\n<h2 id=\"content-prerequisites\"><a href=\"#content-prerequisites\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Prerequisites<\/h2>\n<p>To enable your application to use the application control functionality, follow these steps:<\/p>\n<ol>\n<li>\n<p>To use application controls, the application has to request\npermission by adding the following privilege to the\n<code>tizen-manifest.xml<\/code> file:<\/p>\n<code class=\"language-XML\">&lt;privileges&gt;\n   &lt;privilege&gt;http:\/\/tizen.org\/privilege\/appmanager.launch&lt;\/privilege&gt;\n&lt;\/privileges&gt;\n<\/code>\n<\/li>\n<li>\n<p>To use the methods and data types of the\n<a href=\"\/application\/dotnet\/api\/TizenFX\/latest\/api\/Tizen.Applications.md\">Tizen.Applications<\/a>\nnamespace, include it in your application:<\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">using<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Tizen<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Applications<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">;<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<\/li>\n<\/ol>\n<p><a name=\"use\"><\/a><\/p>\n<h2 id=\"content-launch-applications-using-extra-data\"><a href=\"#content-launch-applications-using-extra-data\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Launch applications using extra data<\/h2>\n<p>To run a specific application control with some preconfigured parameters, follow these steps:<\/p>\n<ol>\n<li>\n<p>Prepare the application control:<\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">AppControl<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">appControl<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">new<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">AppControl<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">();<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<\/li>\n<li>\n<p>When the instance of the\n<a href=\"\/application\/dotnet\/api\/TizenFX\/latest\/api\/Tizen.Applications.AppControl.md\">Tizen.Applications.AppControl<\/a>\nclass is created, set the operation and MIME type. In this example,\nthe application control launches an application that has the\n<code>AppControlOperations.View<\/code> operation and the <code>image\/jpeg<\/code>\nMIME type.<\/p>\n<p>The <code>Operation<\/code> property is mandatory information for the\nlaunch request. If the operation is not specified,\n<code>AppControlOperations.Default<\/code> is used for the launch request:<\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">appControl.Operation <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> AppControlOperations.View;<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">appControl.Mime <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">&quot;image\/jpeg&quot;<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">;<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<\/li>\n<li>\n<p>Add extra data to the <code>Tizen.Applications.AppControl<\/code> instance by\nusing the <code>ExtraData<\/code> property and the <code>Add()<\/code> method of the\n<a href=\"\/application\/dotnet\/api\/TizenFX\/latest\/api\/Tizen.Applications.AppControl.ExtraDataCollection.md\">Tizen.Applications.AppControl.ExtraDataCollection<\/a> class.\nIn the following example, a message is added as extra data:<\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">appControl.ExtraData.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Add<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">&quot;MyKey&quot;<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">, <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">&quot;My Message&quot;<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">);<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<\/li>\n<li>\n<p>Launch the <code>Tizen.Applications.AppControl<\/code> instance with the\n<code>SendLaunchRequest()<\/code> method:<\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">AppControl.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">SendLaunchRequest<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(appControl, AppControlReplyCallback);<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<\/li>\n<li>\n<p>In the launched application, read the extra data added to the\napplication control by using the <code>ExtraData<\/code> property of the\n<a href=\"\/application\/dotnet\/api\/TizenFX\/latest\/api\/Tizen.Applications.ReceivedAppControl.md\">Tizen.Applications.ReceivedAppControl<\/a>\nclass instance and the <code>Get()<\/code> method of the\n<code>Tizen.Applications.ExtraDataCollection<\/code> class. The same property\nand method can be used in the original application to read the reply\nmessage, when the application control reply is returned:<\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#6A737D;--shiki-dark:#6A737D\">\/\/\/ Callee application<\/span><\/span>\n<span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">protected<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">override<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">void<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">OnAppControlReceived<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">AppControlReceivedEventArgs<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">e<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">)<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">{<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">    <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">string<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">message<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">;<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">    <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">ReceivedAppControl<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">receivedAppControl<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> e.ReceivedAppControl;<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#6A737D;--shiki-dark:#6A737D\">    \/\/\/ Get ExtraData coming from caller application<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">    message  <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> receivedAppControl.ExtraData.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Get<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">&lt;<\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">string<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">&gt;(<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">&quot;MyKey&quot;<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">);<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">    <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">if<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> (receivedAppControl.IsReplyRequest)<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">    {<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">        <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">AppControl<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">replyRequest<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">new<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">AppControl<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">();<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">        replyRequest.ExtraData.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Add<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">&quot;ReplyKey&quot;<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">, <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">&quot;Reply message&quot;<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">);<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#6A737D;--shiki-dark:#6A737D\">        \/\/\/ Send reply to the caller application<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">        receivedAppControl.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">ReplyToLaunchRequest<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(replyRequest, AppControlReplyResult.Succeeded);<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">    }<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">    <\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">base<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">OnAppControlReceived<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(e);<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">}<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#6A737D;--shiki-dark:#6A737D\">\/\/\/ Caller application<\/span><\/span>\n<span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">static<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">void<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">AppControlReplyCallback<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Tizen<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Applications<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">AppControl<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">launchRequest<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">, <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Tizen<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Applications<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">AppControl<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">replyRequest<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">, <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">AppControlReplyResult<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">result<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">)<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">{<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">    <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">string<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">receivedMessage<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">;<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">    <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">if<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(result <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">&gt;=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> AppControlReplyResult.Succeeded)<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">    {<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">        receivedMessage <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> replyRequest.ExtraData.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Get<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">&lt;<\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">string<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">&gt;(<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">&quot;ReplyKey&quot;<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">);<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">    }<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">}<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<\/li>\n<\/ol>\n<p><a name=\"mode\"><\/a><\/p>\n<h2 id=\"content-control-the-launch-mode\"><a href=\"#content-control-the-launch-mode\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Control the launch mode<\/h2>\n<p>The following code sets the application control in the caller application to launch a sub application within the same group:<\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">AppControl<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">appControl<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">new<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">AppControl<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">();<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">appControl.ApplicationId <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">&quot;org.tizen.TestApp&quot;<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">;<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">appControl.LaunchMode <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> AppControlLaunchMode.Group;<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">AppControl.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">SendLaunchRequest<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(appControl);<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<h2 id=\"content-related-information\"><a href=\"#content-related-information\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Related information<\/h2>\n<ul>\n<li>Dependencies\n<ul>\n<li>Tizen 4.0 and Higher<\/li>\n<\/ul>\n<\/li>\n<li>API References\n<ul>\n<li><a href=\"\/application\/dotnet\/api\/TizenFX\/latest\/api\/Tizen.Applications.AppControl\">Tizen.Applications.AppControl<\/a> class<\/li>\n<li><a href=\"\/application\/dotnet\/api\/TizenFX\/latest\/api\/Tizen.Applications.AppControlOperations\">Tizen.Applications.AppControlOperations<\/a> class<\/li>\n<li><a href=\"\/application\/dotnet\/api\/TizenFX\/latest\/api\/Tizen.Applications.ReceivedAppControl\">Tizen.Applications.ReceivedAppControl<\/a> class<\/li>\n<li><a href=\"\/application\/dotnet\/api\/TizenFX\/latest\/api\/Tizen.Applications.AppControlData\">Tizen.Applications.AppControlData<\/a> class<\/li>\n<\/ul>\n<\/li>\n<\/ul>\n","table_of_content":"<ul class=\"table-of-contents\">\n<li><a href=\"#content-launch-types\">Launch types<\/a><\/li>\n<li><a href=\"#content-launch-requests\">Launch requests<\/a><\/li>\n<li><a href=\"#content-explicit-launch-request\">Explicit launch request<\/a><\/li>\n<li><a href=\"#content-implicit-launch-request\">Implicit launch request<\/a><\/li>\n<li><a href=\"#content-determine-the-application-for-an-implicit-launch-request\">Determine the application for an implicit launch request<\/a><\/li>\n<li><a href=\"#content-launch-process\">Launch process<\/a><\/li>\n<li><a href=\"#content-launch-results\">Launch results<\/a><\/li>\n<li><a href=\"#content-application-control-export\">Application control export<\/a><\/li>\n<li><a href=\"#content-application-group-management\">Application group management<\/a><\/li>\n<li><a href=\"#content-prerequisites\">Prerequisites<\/a><\/li>\n<li><a href=\"#content-launch-applications-using-extra-data\">Launch applications using extra data<\/a><\/li>\n<li><a href=\"#content-control-the-launch-mode\">Control the launch mode<\/a><\/li>\n<li><a href=\"#content-related-information\">Related information<\/a><\/li>\n<\/ul>\n","title":"Application Controls","raw":null},{"class":"App\\Services\\Documentation\\Data\\RenderedMarkdown","s":"wrbl"}]},{"s":"arr"}]},"memo":{"id":"SsqcQeZWD8J6C1iOwc7u","name":"__mountParamsContainer","path":"docs\/application\/dotnet\/guides\/exchange-data-between-apps\/app-controls","method":"GET","release":"a-a-a"},"checksum":"8d5631cf54c1611a0751e30d802bd3e72c3d88cc505a439adfe2500648355398"}')" >