Application

Chose application
.NET Native Web Flutter
Chose version
ver. 14.0 ver. 13.0 ver. 12.0 ver. 11.0 ver. 10.0 ver. 9.0 ver. 8.0 ver. 7.0 ver. 6.0 ver. 5.0 ver. 4.0
Choose device
View is the fundamental concept for all the UI components such as <code>Button<\/code>, <code>Image<\/code>, <code>Text<\/code>, and so on.\n<code>View<\/code> provides <a href=https://samsungtizenos.com/"..//api//TizenFX//latest//api//Tizen.NUI.BaseComponents.View.md#properties\">Properties<\/a>, <a href=https://samsungtizenos.com/"//application//dotnet//api//TizenFX//latest//api//Tizen.NUI.BaseComponents.View.md#methods\">Methods<\/a>, and <a href=https://samsungtizenos.com/"//application//dotnet//api//TizenFX//latest//api//Tizen.NUI.BaseComponents.View.md#events\">Events<\/a> that are commonly used on every components. To render <code>View<\/code>, you must add it on <a href=https://samsungtizenos.com/"//application//dotnet//api//TizenFX//latest//api//Tizen.NUI.Window.md/">Window as a child.<\/p>\n<p><a name=\"1\"><\/a><\/p>\n<h2 id=\"content-transforms\"><a href=https://samsungtizenos.com/"#content-transforms\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Transforms<\/h2>\n<p><code>Position<\/code>, <code>Orientation<\/code>, and <code>Scale<\/code> of <code>View<\/code> are known as transforms.\n<code>View<\/code> supports hierarchical structure. Therefore, <code>Position<\/code>, <code>Orientation<\/code>, and <code>Scale<\/code> of every <code>View<\/code> are affected by their parents.<\/p>\n<p>The <code>Position<\/code> of each <code>View<\/code> is defined as the distance between the position of <a href=https://samsungtizenos.com/"//application//dotnet//api//TizenFX//latest//api//Tizen.NUI.BaseComponents.View.md#Tizen_NUI_BaseComponents_View_ParentOrigin\">ParentOrigin<\/a> and <a href=https://samsungtizenos.com/"//application//dotnet//api//TizenFX//latest//api//Tizen.NUI.BaseComponents.View.md#Tizen_NUI_BaseComponents_View_PivotPoint\">PivotPoint<\/a> of the <code>View<\/code>. The <code>ParentOrigin<\/code> is a property that defines the reference point in the parent <code>View<\/code>, whereas the <code>PivotPoint<\/code> is a property that defines the anchor point of the child. The default value for both <code>PivotPoint<\/code> and <code>ParentOrigin<\/code> is <strong>TopLeft<\/strong>. For instance, if the <code>Position<\/code> property of the <code>View<\/code> is set to (5, 3) coordinates, the <code>ParentOrigin<\/code> property is set to <strong>Center<\/strong>, and the <code>PivotPoint<\/code> property is set to <strong>TopLeft<\/strong>, then the <strong>TopLeft<\/strong> of the object is located (5, 3) coordinates away from the <strong>Center<\/strong> position of its parent's <code>View<\/code> object.<\/p>\n<p>In addition, if the <code>ParentOrigin<\/code> property is changed to <strong>BottomRight<\/strong>, then the position of the <strong>TopLeft<\/strong> corner of the <code>View<\/code> will be located (5, 3) coordinates from the <strong>BottomRight<\/strong> corner.<\/p>\n<p>NUI provides predefined <code>ParentOrigin<\/code> as well as <code>PivotPoint<\/code> positions as shown in the following figure, and you can also use custom values for setting the position:<\/p>\n<p><strong>Figure: Predefined positions for ParentOrigin and PivotPoint<\/strong><\/p>\n<table style=\"width:100%\">\n<tr>\n<td style=\"width:100%\" align=\"center\">\n<img src=https://samsungtizenos.com/"media//view_Figure_ParentOrigin_PivotPoint.png/">/n/n/n/n

The following figure shows three cases of parent <code>View<\/code> and its child <code>View<\/code>. The parent <code>View<\/code> is represented by blue color and child <code>View<\/code> is represented by red color.\nIn the following examples, all of the red-colored <code>View<\/code> coordinates are identically located at (3, 5) of its parent coordinate system, which is based on the <code>ParentOrigin<\/code> property of the child <code>View<\/code>. <code>PivotPoint<\/code> is set to default <strong>TopLeft<\/strong>:<\/p>\n<p><strong>Figure: The final position with different ParentOrigin<\/strong><\/p>\n<table style=\"width:100%\">\n<tr>\n<td style=\"width:100%\" align=\"center\">\n<img src=https://samsungtizenos.com/"media//view_Figure_Position.png/" width=\"100%\">\n<\/td>\n<\/tr>\n<\/table>\n<p>Alternatively, you can use an arbitrary <code>Position<\/code> type value defined in the unit coordinates to set <code>ParentOrigin<\/code> without predefined values.<\/p>\n<p>The <code>Orientation<\/code> of <code>View<\/code> is the rotation from its default orientation. <code>Scale<\/code> of <code>View<\/code> is the size ratio between the size to be rendered and the default size. For these two transforms, <code>View<\/code> is rotated and scaled around <code>PivotPoint<\/code>.<\/p>\n<p><code>Orientation<\/code> and <code>Scale<\/code> of <code>View<\/code> are also affected by the transforms of its parent. In the final calculation of <code>View<\/code>, <code>Orientation<\/code> and <code>Scale<\/code> of parents are first applied to the child <code>View<\/code> with parent's <code>PivotPoint<\/code>, and then <code>Orientation<\/code> and <code>Scale<\/code> of child are applied.<\/p>\n<p>The following examples demonstrate the rotation and scaling that change <code>Orientation<\/code> and <code>Scale<\/code> respectively. <strong>View A<\/strong> is a child of <strong>View B<\/strong>. Therefore, transforms of <strong>A<\/strong> only affects <strong>A<\/strong>. However, the transforms of parent <strong>B<\/strong> influences its child <strong>A<\/strong>. The black dot in the figure is <code>PivotPoint<\/code> that is used by the transforms.<\/p>\n<p><strong>Figure: Rotation and Scaling.<\/strong><\/p>\n<table style=\"width:100%\">\n<tr>\n<td style=\"width:50%\" align=\"center\">\n<img src=https://samsungtizenos.com/"media//view_Figure_Orientation.gif/" width=\"100%\">\n<\/td>\n<td style=\"width:50%\" align=\"center\">\n<img src=https://samsungtizenos.com/"media//view_Figure_Scale.gif/" width=\"100%\">\n<\/td>\n<\/tr>\n<\/table>\n<p><a name=\"2\"><\/a><\/p>\n<h2 id=\"content-directional-navigation\"><a href=https://samsungtizenos.com/"#content-directional-navigation\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Directional navigation<\/h2>\n<p>NUI also provides directional navigation between each <code>View<\/code> using arrow keys on the keyboard. You can simply set the following properties to specify the next <code>FocusableView<\/code> for each direction:<\/p>\n<ul>\n<li>\n<p><a href=https://samsungtizenos.com/"//application//dotnet//api//TizenFX//latest//api//Tizen.NUI.BaseComponents.View.md#Tizen_NUI_BaseComponents_View_UpFocusableView\">View.UpFocusableView<\/a><\/p>\n<\/li>\n<li>\n<p><a href=https://samsungtizenos.com/"//application//dotnet//api//TizenFX//latest//api//Tizen.NUI.BaseComponents.View.md#Tizen_NUI_BaseComponents_View_DownFocusableView\">View.DownFocusableView<\/a><\/p>\n<\/li>\n<li>\n<p><a href=https://samsungtizenos.com/"//application//dotnet//api//TizenFX//latest//api//Tizen.NUI.BaseComponents.View.md#Tizen_NUI_BaseComponents_View_LeftFocusableView\">View.LeftFocusableView<\/a><\/p>\n<\/li>\n<li>\n<p><a href=https://samsungtizenos.com/"//application//dotnet//api//TizenFX//latest//api//Tizen.NUI.BaseComponents.View.md#Tizen_NUI_BaseComponents_View_RightFocusableView\">View.RightFocusableView<\/a><\/p>\n<\/li>\n<\/ul>\n<p>When an arrow key is pressed and the current <code>View<\/code> has next <code>FocusableView<\/code> for that direction, the system passes focus to the next <code>FocusableView<\/code>. However, if the current <code>View<\/code> does not have the next <code>FocusableView<\/code> for the direction or the next <code>ForcusableView<\/code> is not on the window, the property returns <code>NULL<\/code> and no change occurs.<\/p>\n<p><a name=\"3\"><\/a><\/p>\n<h2 id=\"content-view-event\"><a href=https://samsungtizenos.com/"#content-view-event\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>View event<\/h2>\n<p><code>View<\/code> provides a variety of events that are commonly used by the components. The following table lists the basic events provided by <code>View<\/code>:<\/p>\n<p><strong>Table: View events<\/strong><\/p>\n<div class=\"overflow-auto grid table-fixed\" data-table-container=\"data-table-container\"><table>\n<thead>\n<tr>\n<th>Event<\/th>\n<th>Description<\/th>\n<\/tr>\n<\/thead>\n<tbody>\n<tr>\n<td><code>KeyEvent<\/code><\/td>\n<td>Triggered when the key input is received.<\/td>\n<\/tr>\n<tr>\n<td><code>TouchEvent<\/code><\/td>\n<td>Triggered when the touch input is received.<\/td>\n<\/tr>\n<tr>\n<td><code>HoverEvent<\/code><\/td>\n<td>Triggered when the hover input is received.<\/td>\n<\/tr>\n<tr>\n<td><code>WheelEvent<\/code><\/td>\n<td>Triggered when the wheel input is received.<\/td>\n<\/tr>\n<tr>\n<td><code>FocusGained<\/code><\/td>\n<td>Triggered when the control gets the key input focus.<\/td>\n<\/tr>\n<tr>\n<td><code>FocusLost<\/code><\/td>\n<td>Triggered when the control loses key input focus.<\/td>\n<\/tr>\n<tr>\n<td><code>Relayout<\/code><\/td>\n<td>Triggered after the size has been set on View during relayout.<\/td>\n<\/tr>\n<tr>\n<td><code>LayoutDirectionChanged<\/code><\/td>\n<td>Triggered when the layout direction property of View or its parent View is changed.<\/td>\n<\/tr>\n<tr>\n<td><code>AddedToWindow<\/code><\/td>\n<td>Triggered after View has been connected to the window.<\/td>\n<\/tr>\n<tr>\n<td><code>RemovedFromWindow<\/code><\/td>\n<td>Triggered after View has been disconnected from the window.<\/td>\n<\/tr>\n<tr>\n<td><code>VisibilityChanged<\/code><\/td>\n<td>Triggered when the visible property of View or parent View is changed.<\/td>\n<\/tr>\n<tr>\n<td><code>ResourcesLoaded<\/code><\/td>\n<td>Triggered after all the resources required by View are loaded and ready.<\/td>\n<\/tr>\n<\/tbody>\n<\/table><\/div>\n<p>You can create custom <code>callback<\/code> methods with event handler for each <code>Event<\/code>.<\/p>\n<p>Input <code>Event<\/code> such as <code>KeyEvent<\/code> and <code>TouchEvent<\/code> is first received on the current focused <code>View<\/code> to be handled. However, if the focused <code>View<\/code> is not having a proper event handler, then the <code>Event<\/code> is delivered to its parent <code>View<\/code> iteratively until it can be consumed.<\/p>\n<p>The following code explains how to handle <code>Event<\/code> with a simple example of <code>TouchEvent<\/code>. If you touch the blue <code>View<\/code> then the background color is changed:<\/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\">View<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">touchedView<\/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\">View<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">();<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">touchedView.BackgroundColor <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> Color.Blue;<\/span><\/span>\n<span class=\"line\"><span style=\"color:#6A737D;--shiki-dark:#6A737D\">\/\/ Attach callback method<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">touchedView.TouchEvent <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">+=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> ViewTouchEventCallBack;<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">..<\/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\">\/\/ Custom callback method<\/span><\/span>\n<span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">private<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">bool<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">ViewTouchEventCallBack<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(<\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">object<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">sender<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">, <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">View<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">TouchEventArgs<\/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\">View<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">touchedView<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> sender <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">as<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">View<\/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\"> (e.Touch.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">GetState<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(<\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">0<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">) <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">==<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> PointStateType.Down)<\/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\"> touchedView.BackgroundColor <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> Color.Red;<\/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\">return<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">true<\/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><\/code><\/pre>\n<p><strong>Figure: TouchEvent example<\/strong><\/p>\n<p><img src=https://samsungtizenos.com/"media//view_Figure_Touch.gif/" alt=\"View with a background image\" \/><\/p>\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<\/ul>\n","table_of_content":"<ul class=\"table-of-contents\">\n<li><a href=https://samsungtizenos.com/"#content-transforms\">Transforms<\/a><\/li>\n<li><a href=https://samsungtizenos.com/"#content-directional-navigation\">Directional navigation<\/a><\/li>\n<li><a href=https://samsungtizenos.com/"#content-view-event\">View event<\/a><\/li>\n<li><a href=https://samsungtizenos.com/"#content-related-information\">Related information<\/a><\/li>\n<\/ul>\n","title":"View","raw":null},{"class":"App\\Services\\Documentation\\Data\\RenderedMarkdown","s":"wrbl"}]},"memo":{"id":"Vtlq1n7o9il3FolABYQT","name":"documentation::article","path":"docs\/application\/dotnet\/guides\/user-interface\/nui\/view","method":"GET","release":"a-a-a","children":[],"scripts":[],"assets":[],"lazyLoaded":false,"lazyIsolated":true,"errors":[],"locale":"en","islands":[]},"checksum":"9b0e62a4e8f69cd4cc2e08f5b9b6d73baffc1b11ddefd0a36970a704e1037023"}" wire:effects="[]" wire:id="Vtlq1n7o9il3FolABYQT" wire:name="documentation::article" x-init="$wire.__lazyLoad('{"data":{"forMount":[{"markdown":[{"body":"<h1 id=\"content-view\"><a href=\"#content-view\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>View<\/h1><div data-knowledge-base-metadata><\/div>\n<p><a href=\"..\/..\/..\/api\/TizenFX\/latest\/api\/Tizen.NUI.BaseComponents.View.md\">View<\/a> is the fundamental concept for all the UI components such as <code>Button<\/code>, <code>Image<\/code>, <code>Text<\/code>, and so on.\n<code>View<\/code> provides <a href=\"..\/..\/..\/api\/TizenFX\/latest\/api\/Tizen.NUI.BaseComponents.View.md#properties\">Properties<\/a>, <a href=\"\/application\/dotnet\/api\/TizenFX\/latest\/api\/Tizen.NUI.BaseComponents.View.md#methods\">Methods<\/a>, and <a href=\"\/application\/dotnet\/api\/TizenFX\/latest\/api\/Tizen.NUI.BaseComponents.View.md#events\">Events<\/a> that are commonly used on every components. To render <code>View<\/code>, you must add it on <a href=\"\/application\/dotnet\/api\/TizenFX\/latest\/api\/Tizen.NUI.Window.md\">Window<\/a> as a child.<\/p>\n<p><a name=\"1\"><\/a><\/p>\n<h2 id=\"content-transforms\"><a href=\"#content-transforms\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Transforms<\/h2>\n<p><code>Position<\/code>, <code>Orientation<\/code>, and <code>Scale<\/code> of <code>View<\/code> are known as transforms.\n<code>View<\/code> supports hierarchical structure. Therefore, <code>Position<\/code>, <code>Orientation<\/code>, and <code>Scale<\/code> of every <code>View<\/code> are affected by their parents.<\/p>\n<p>The <code>Position<\/code> of each <code>View<\/code> is defined as the distance between the position of <a href=\"\/application\/dotnet\/api\/TizenFX\/latest\/api\/Tizen.NUI.BaseComponents.View.md#Tizen_NUI_BaseComponents_View_ParentOrigin\">ParentOrigin<\/a> and <a href=\"\/application\/dotnet\/api\/TizenFX\/latest\/api\/Tizen.NUI.BaseComponents.View.md#Tizen_NUI_BaseComponents_View_PivotPoint\">PivotPoint<\/a> of the <code>View<\/code>. The <code>ParentOrigin<\/code> is a property that defines the reference point in the parent <code>View<\/code>, whereas the <code>PivotPoint<\/code> is a property that defines the anchor point of the child. The default value for both <code>PivotPoint<\/code> and <code>ParentOrigin<\/code> is <strong>TopLeft<\/strong>. For instance, if the <code>Position<\/code> property of the <code>View<\/code> is set to (5, 3) coordinates, the <code>ParentOrigin<\/code> property is set to <strong>Center<\/strong>, and the <code>PivotPoint<\/code> property is set to <strong>TopLeft<\/strong>, then the <strong>TopLeft<\/strong> of the object is located (5, 3) coordinates away from the <strong>Center<\/strong> position of its parent's <code>View<\/code> object.<\/p>\n<p>In addition, if the <code>ParentOrigin<\/code> property is changed to <strong>BottomRight<\/strong>, then the position of the <strong>TopLeft<\/strong> corner of the <code>View<\/code> will be located (5, 3) coordinates from the <strong>BottomRight<\/strong> corner.<\/p>\n<p>NUI provides predefined <code>ParentOrigin<\/code> as well as <code>PivotPoint<\/code> positions as shown in the following figure, and you can also use custom values for setting the position:<\/p>\n<p><strong>Figure: Predefined positions for ParentOrigin and PivotPoint<\/strong><\/p>\n<table style=\"width:100%\">\n<tr>\n<td style=\"width:100%\" align=\"center\">\n<img src=\"media\/view_Figure_ParentOrigin_PivotPoint.png\">\n<\/td>\n<\/tr>\n<\/table>\n<p>The following figure shows three cases of parent <code>View<\/code> and its child <code>View<\/code>. The parent <code>View<\/code> is represented by blue color and child <code>View<\/code> is represented by red color.\nIn the following examples, all of the red-colored <code>View<\/code> coordinates are identically located at (3, 5) of its parent coordinate system, which is based on the <code>ParentOrigin<\/code> property of the child <code>View<\/code>. <code>PivotPoint<\/code> is set to default <strong>TopLeft<\/strong>:<\/p>\n<p><strong>Figure: The final position with different ParentOrigin<\/strong><\/p>\n<table style=\"width:100%\">\n<tr>\n<td style=\"width:100%\" align=\"center\">\n<img src=\"media\/view_Figure_Position.png\" width=\"100%\">\n<\/td>\n<\/tr>\n<\/table>\n<p>Alternatively, you can use an arbitrary <code>Position<\/code> type value defined in the unit coordinates to set <code>ParentOrigin<\/code> without predefined values.<\/p>\n<p>The <code>Orientation<\/code> of <code>View<\/code> is the rotation from its default orientation. <code>Scale<\/code> of <code>View<\/code> is the size ratio between the size to be rendered and the default size. For these two transforms, <code>View<\/code> is rotated and scaled around <code>PivotPoint<\/code>.<\/p>\n<p><code>Orientation<\/code> and <code>Scale<\/code> of <code>View<\/code> are also affected by the transforms of its parent. In the final calculation of <code>View<\/code>, <code>Orientation<\/code> and <code>Scale<\/code> of parents are first applied to the child <code>View<\/code> with parent's <code>PivotPoint<\/code>, and then <code>Orientation<\/code> and <code>Scale<\/code> of child are applied.<\/p>\n<p>The following examples demonstrate the rotation and scaling that change <code>Orientation<\/code> and <code>Scale<\/code> respectively. <strong>View A<\/strong> is a child of <strong>View B<\/strong>. Therefore, transforms of <strong>A<\/strong> only affects <strong>A<\/strong>. However, the transforms of parent <strong>B<\/strong> influences its child <strong>A<\/strong>. The black dot in the figure is <code>PivotPoint<\/code> that is used by the transforms.<\/p>\n<p><strong>Figure: Rotation and Scaling.<\/strong><\/p>\n<table style=\"width:100%\">\n<tr>\n<td style=\"width:50%\" align=\"center\">\n<img src=\"media\/view_Figure_Orientation.gif\" width=\"100%\">\n<\/td>\n<td style=\"width:50%\" align=\"center\">\n<img src=\"media\/view_Figure_Scale.gif\" width=\"100%\">\n<\/td>\n<\/tr>\n<\/table>\n<p><a name=\"2\"><\/a><\/p>\n<h2 id=\"content-directional-navigation\"><a href=\"#content-directional-navigation\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Directional navigation<\/h2>\n<p>NUI also provides directional navigation between each <code>View<\/code> using arrow keys on the keyboard. You can simply set the following properties to specify the next <code>FocusableView<\/code> for each direction:<\/p>\n<ul>\n<li>\n<p><a href=\"\/application\/dotnet\/api\/TizenFX\/latest\/api\/Tizen.NUI.BaseComponents.View.md#Tizen_NUI_BaseComponents_View_UpFocusableView\">View.UpFocusableView<\/a><\/p>\n<\/li>\n<li>\n<p><a href=\"\/application\/dotnet\/api\/TizenFX\/latest\/api\/Tizen.NUI.BaseComponents.View.md#Tizen_NUI_BaseComponents_View_DownFocusableView\">View.DownFocusableView<\/a><\/p>\n<\/li>\n<li>\n<p><a href=\"\/application\/dotnet\/api\/TizenFX\/latest\/api\/Tizen.NUI.BaseComponents.View.md#Tizen_NUI_BaseComponents_View_LeftFocusableView\">View.LeftFocusableView<\/a><\/p>\n<\/li>\n<li>\n<p><a href=\"\/application\/dotnet\/api\/TizenFX\/latest\/api\/Tizen.NUI.BaseComponents.View.md#Tizen_NUI_BaseComponents_View_RightFocusableView\">View.RightFocusableView<\/a><\/p>\n<\/li>\n<\/ul>\n<p>When an arrow key is pressed and the current <code>View<\/code> has next <code>FocusableView<\/code> for that direction, the system passes focus to the next <code>FocusableView<\/code>. However, if the current <code>View<\/code> does not have the next <code>FocusableView<\/code> for the direction or the next <code>ForcusableView<\/code> is not on the window, the property returns <code>NULL<\/code> and no change occurs.<\/p>\n<p><a name=\"3\"><\/a><\/p>\n<h2 id=\"content-view-event\"><a href=\"#content-view-event\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>View event<\/h2>\n<p><code>View<\/code> provides a variety of events that are commonly used by the components. The following table lists the basic events provided by <code>View<\/code>:<\/p>\n<p><strong>Table: View events<\/strong><\/p>\n<div class=\"overflow-auto grid table-fixed\" data-table-container=\"data-table-container\"><table>\n<thead>\n<tr>\n<th>Event<\/th>\n<th>Description<\/th>\n<\/tr>\n<\/thead>\n<tbody>\n<tr>\n<td><code>KeyEvent<\/code><\/td>\n<td>Triggered when the key input is received.<\/td>\n<\/tr>\n<tr>\n<td><code>TouchEvent<\/code><\/td>\n<td>Triggered when the touch input is received.<\/td>\n<\/tr>\n<tr>\n<td><code>HoverEvent<\/code><\/td>\n<td>Triggered when the hover input is received.<\/td>\n<\/tr>\n<tr>\n<td><code>WheelEvent<\/code><\/td>\n<td>Triggered when the wheel input is received.<\/td>\n<\/tr>\n<tr>\n<td><code>FocusGained<\/code><\/td>\n<td>Triggered when the control gets the key input focus.<\/td>\n<\/tr>\n<tr>\n<td><code>FocusLost<\/code><\/td>\n<td>Triggered when the control loses key input focus.<\/td>\n<\/tr>\n<tr>\n<td><code>Relayout<\/code><\/td>\n<td>Triggered after the size has been set on View during relayout.<\/td>\n<\/tr>\n<tr>\n<td><code>LayoutDirectionChanged<\/code><\/td>\n<td>Triggered when the layout direction property of View or its parent View is changed.<\/td>\n<\/tr>\n<tr>\n<td><code>AddedToWindow<\/code><\/td>\n<td>Triggered after View has been connected to the window.<\/td>\n<\/tr>\n<tr>\n<td><code>RemovedFromWindow<\/code><\/td>\n<td>Triggered after View has been disconnected from the window.<\/td>\n<\/tr>\n<tr>\n<td><code>VisibilityChanged<\/code><\/td>\n<td>Triggered when the visible property of View or parent View is changed.<\/td>\n<\/tr>\n<tr>\n<td><code>ResourcesLoaded<\/code><\/td>\n<td>Triggered after all the resources required by View are loaded and ready.<\/td>\n<\/tr>\n<\/tbody>\n<\/table><\/div>\n<p>You can create custom <code>callback<\/code> methods with event handler for each <code>Event<\/code>.<\/p>\n<p>Input <code>Event<\/code> such as <code>KeyEvent<\/code> and <code>TouchEvent<\/code> is first received on the current focused <code>View<\/code> to be handled. However, if the focused <code>View<\/code> is not having a proper event handler, then the <code>Event<\/code> is delivered to its parent <code>View<\/code> iteratively until it can be consumed.<\/p>\n<p>The following code explains how to handle <code>Event<\/code> with a simple example of <code>TouchEvent<\/code>. If you touch the blue <code>View<\/code> then the background color is changed:<\/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\">View<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">touchedView<\/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\">View<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">();<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">touchedView.BackgroundColor <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> Color.Blue;<\/span><\/span>\n<span class=\"line\"><span style=\"color:#6A737D;--shiki-dark:#6A737D\">\/\/ Attach callback method<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">touchedView.TouchEvent <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">+=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> ViewTouchEventCallBack;<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">..<\/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\">\/\/ Custom callback method<\/span><\/span>\n<span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">private<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">bool<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">ViewTouchEventCallBack<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(<\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">object<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">sender<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">, <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">View<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">TouchEventArgs<\/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\">View<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">touchedView<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> sender <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">as<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">View<\/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\"> (e.Touch.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">GetState<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(<\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">0<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">) <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">==<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> PointStateType.Down)<\/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\">        touchedView.BackgroundColor <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> Color.Red;<\/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\">return<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">true<\/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><\/code><\/pre>\n<p><strong>Figure: TouchEvent example<\/strong><\/p>\n<p><img src=\"media\/view_Figure_Touch.gif\" alt=\"View with a background image\" \/><\/p>\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<\/ul>\n","table_of_content":"<ul class=\"table-of-contents\">\n<li><a href=\"#content-transforms\">Transforms<\/a><\/li>\n<li><a href=\"#content-directional-navigation\">Directional navigation<\/a><\/li>\n<li><a href=\"#content-view-event\">View event<\/a><\/li>\n<li><a href=\"#content-related-information\">Related information<\/a><\/li>\n<\/ul>\n","title":"View","raw":null},{"class":"App\\Services\\Documentation\\Data\\RenderedMarkdown","s":"wrbl"}]},{"s":"arr"}]},"memo":{"id":"0d6t5E9xA9wIDJtralMk","name":"__mountParamsContainer","path":"docs\/application\/dotnet\/guides\/user-interface\/nui\/view","method":"GET","release":"a-a-a"},"checksum":"a68648adee33107b709b5f4b25c38169efb57d36b7c576c11737d893cc7a377c"}')" >

For the best experience,
Please visit us from a computer

Copyright © 2026 SAMSUNG. All rights reserved.

Customize your cookie preferences

You can enable or disable non-essential cookies. Essential cookies are always on to ensure the site works properly and to keep you signed in.

Necessary

These cookies are necessary for the website to function properly and cannot be switched off. They help with things like logging in and setting your privacy preferences.

Always on

Analytics

These cookies help us improve the site by tracking which pages are most popular and how visitors move around the site.

Enable analytics cookies
Public Forum Public Forum
Employees only. Please sign in with your company account.