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
https:////docs.microsoft.com//en-US//xamarin//xamarin-forms//xaml//namespaces./n

https:////docs.microsoft.com//en-US//xamarin//xamarin-forms//xaml//xaml-basics//data-binding-basics./n

https:////docs.microsoft.com//en-US//xamarin//xamarin-forms//xaml//resource-dictionaries./n

TypeConverters and XAML<\/a>.<\/p>\n<\/div>\n<h3 id=\"content-type-conversion\"><a href=https://samsungtizenos.com/"#content-type-conversion\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Type Conversion<\/h3>\n<p>In the XAML file, all the attribute values are represented as type of string with pure text.\nEven primitives (ex: Int, Double) are simple text string and they are needed to be changed as the type that XAML processor can understand.\nFor instance, <strong>Tizen.NUI<\/strong> defines some properties that take a value of type <code>Size2D<\/code>.\n<code>Size2D<\/code> is a value that describes two-dimensional sizes and has two important properties, width and height.\nWhen you are specifying size2D in XAML, you must specify it as a string with a comma between the width and height values:<\/p>\n<code class=\"language-XML\">&lt;ImageView PositionX=&quot;100&quot; PositionY=&quot;320&quot; Size2D=&quot;300, 300&quot; ResourceUrl=&quot;ImageResourcePath&quot;\/&gt;\n<\/code>\n<p>In this scenario, the type converter is the <code>Size2DTypeConverter<\/code> class.\nIf a type converter is not available, you must use verbose markup as shown in the following code:<\/p>\n<code class=\"language-XML\">&lt;ImageView PositionX=&quot;100&quot; PositionY=&quot;320&quot; ResourceUrl=&quot;ImageResourcePath&quot;&gt;\n &lt;ImageView.Size2D&gt;\n &lt;Size2D Width=&quot;300&quot; Height=&quot;300&quot;\/&gt;\n &lt;\/ImageView.Size2D&gt;\n&lt;\/ImageView&gt;\n<\/code>\n<h3 id=\"content-nui-typeconverter\"><a href=https://samsungtizenos.com/"#content-nui-typeconverter\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>NUI TypeConverter<\/h3>\n<p>Currently, Tizen.NUI supports the following type converters:<\/p>\n<ul>\n<li><code>ColorTypeConverter<\/code><\/li>\n<li><code>PositionTypeConverter<\/code><\/li>\n<li><code>Position2DTypeConverter<\/code><\/li>\n<li><code>SizeTypeConverter<\/code><\/li>\n<li><code>Size2DTypeConverter<\/code><\/li>\n<li><code>Vector2TypeConverter<\/code><\/li>\n<li><code>Vector3TypeConverter<\/code><\/li>\n<li><code>Vector4TypeConverter<\/code><\/li>\n<li><code>RelativeVector2TypeConverter<\/code><\/li>\n<li><code>RelativeVector3TypeConverter<\/code><\/li>\n<li><code>RelativeVector4TypeConverter<\/code><\/li>\n<\/ul>\n<p>Therefore, you can define the color, position, Size2D, and so on as string in XAML as shown in the following code:<\/p>\n<code class=\"language-XML\">&lt;TextLabel Text=&quot;HelloWorld!&quot; BackgroundColor=&quot;1.0,0.0,0.0,1.0&quot; Position=&quot;20,10,0&quot; Size2D=&quot;440,400&quot;\/&gt;\n<\/code>\n<h3 id=\"content-implement-type-converter\"><a href=https://samsungtizenos.com/"#content-implement-type-converter\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Implement Type Converter<\/h3>\n<p>If you want to convert a string to some custom type in XAML, you need to define a <code>TypeConverter<\/code>.\nThe most important method in <code>TypeConverter<\/code> is <code>ConvertFromInvariantString<\/code>, which converts the input string to the required object type.\nYou can see <code>Size2DTypeConverter<\/code> as shown in 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:#D73A49;--shiki-dark:#F97583\">internal<\/span><span style=\"color:#D73A49;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">class<\/span><span style=\"color:#D73A49;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#B392F0\">Size2DTypeConverter<\/span><span style=\"color:#D73A49;--shiki-dark:#E1E4E8\"> : <\/span><span style=\"color:#D73A49;--shiki-dark:#B392F0\">TypeConverter<\/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:#24292E;--shiki-dark:#F97583\">public<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#24292E;--shiki-dark:#F97583\">override<\/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\">ConvertFromInvariantString<\/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\">value<\/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\">if<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> (value <\/span><span style=\"color:#24292E;--shiki-dark:#F97583\">!=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#24292E;--shiki-dark:#79B8FF\">null<\/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:#24292E;--shiki-dark:#B392F0\">parts<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> value.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Split<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">&#39;,&#39;<\/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:#F97583\">if<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> (parts.Length <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">==<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">2<\/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:#24292E;--shiki-dark:#F97583\">return<\/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\">Size2D<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(Int32.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Parse<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(parts[<\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">0<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">].<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Trim<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(), CultureInfo.InvariantCulture),<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> Int32.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Parse<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(parts[<\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">1<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">].<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Trim<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(), CultureInfo.InvariantCulture));<\/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>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">throw<\/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\">InvalidOperationException<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">$&quot;Cannot convert <\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">\\&quot;<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">{<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">value<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">}<\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">\\&quot;<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\"> into <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">{<\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">typeof<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">(<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Size2D<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">)}<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">&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<h2 id=\"content-property-trigger\"><a href=https://samsungtizenos.com/"#content-property-trigger\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Property Trigger<\/h2>\n<p>The following example shows two triggers that changes <code>PositionX<\/code> of the <code>ImageView<\/code> property when the <code>ResourceUrl<\/code> property is changed to or set equal to <code>..\/res\/detail.png<\/code> or <code>..\/res\/sendtophone.png<\/code>:<\/p>\n<code class=\"language-XML\">&lt;View x:Class=&quot;Tizen.NUI.Examples.StyleDemoPage&quot;\n xmlns=&quot;http:\/\/tizen.org\/Tizen.NUI\/2018\/XAML&quot;\n xmlns:x=&quot;http:\/\/schemas.microsoft.com\/winfx\/2009\/xaml&quot;&gt;\n\n &lt;View.XamlResources&gt;\n &lt;ResourceDictionary&gt;\n &lt;Style x:Key=&quot;CustomStyle&quot; TargetType=&quot;ImageView&quot;&gt;\n &lt;Style.Triggers&gt;\n &lt;Trigger TargetType=&quot;ImageView&quot; Property=&quot;ResourceUrl&quot; Value=&quot;..\/res\/detail.png&quot;&gt;\n &lt;Trigger.Setters &gt;\n &lt;Setter Property=&quot;PositionX&quot; Value=&quot;200&quot; \/&gt;\n &lt;\/Trigger.Setters&gt;\n &lt;\/Trigger&gt;\n &lt;Trigger TargetType=&quot;ImageView&quot; Property=&quot;ResourceUrl&quot; Value=&quot;..\/res\/sendtophone.png&quot;&gt;\n &lt;Trigger.Setters &gt;\n &lt;Setter Property=&quot;PositionX&quot; Value=&quot;500&quot; \/&gt;\n &lt;\/Trigger.Setters&gt;\n &lt;\/Trigger&gt;\n &lt;\/Style.Triggers&gt;\n &lt;\/Style&gt;\n &lt;\/ResourceDictionary&gt;\n &lt;\/View.XamlResources&gt;\n\n &lt;ImageView Name=&quot;ImageView&quot; Position2D=&quot;0,0&quot; Size2D=&quot;400,400&quot; Style=&quot;{StaticResource CustomStyle}&quot;&gt;\n &lt;x:Arguments&gt;\n &lt;x:String&gt;..\/res\/traffic_content.png&lt;\/x:String&gt;\n &lt;\/x:Arguments&gt;\n &lt;\/ImageView&gt;\n\n &lt;PushButton Name=&quot;Click&quot; LabelText=&quot;Click&quot; Size2D=&quot;400,80&quot; Position2D=&quot;1000,100&quot; \/&gt;\n&lt;\/View&gt;\n<\/code>\n<ul>\n<li><code>TargetType<\/code>: The control type that the trigger applies to.<\/li>\n<li><code>Property<\/code>: The property on the control that is monitored.<\/li>\n<li><code>Value<\/code>: The value that occurs for the monitored property that causes the trigger to activate.<\/li>\n<li><code>Setter<\/code>: A collection of Setter elements can be added when the trigger condition is met. You must specify <code>Property<\/code> and set <code>Value<\/code>.<\/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>The Property for Trigger and Setter must not be same.<\/p>\n<\/div>\n<p>For more information, see <a href=https://samsungtizenos.com/"https:////docs.microsoft.com//en-us//xamarin//xamarin-forms//app-fundamentals//triggers#targetText=Triggers%20allow%20you%20to%20express,on%20events%20or%20property%20changes.&amp;targetText=Property%20Trigger%20%2D%20occurs%20when%20a,the%20properties%20of%20another%20control\">Xamarin.Forms Triggers<\/a>.<\/p>\n<h2 id=\"content-how-to-use-transition\"><a href=https://samsungtizenos.com/"#content-how-to-use-transition\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>How to Use Transition<\/h2>\n<p>To load a transition, you can create transition in XAML and then use this transition in the <strong>.cs<\/strong> code.<\/p>\n<p>Following is the format of transition in XAML:<\/p>\n<code class=\"language-XML\">&lt;?xml version=&quot;1.0&quot; encoding=&quot;UTF-8&quot; ?&gt;\n&lt;Transition xmlns=&quot;http:\/\/tizen.org\/Tizen.NUI\/2018\/XAML&quot;\n xmlns:x=&quot;http:\/\/schemas.microsoft.com\/winfx\/2009\/xaml&quot;\n Duration=&quot;3000&quot;\n LoopCount=&quot;3&quot;\n EndAction=&quot;Cancel&quot;\n Name=&quot;Type1&quot;&gt;\n &lt;Transition.Behaviors&gt;\n &lt;x:Array Type=&quot;{x:Type AnimationBehavior}&quot;&gt;\n &lt;AnimationBehavior Key=&quot;DestOpacity&quot; Property=&quot;Opacity&quot; DestValue=&quot;0.5&quot; StartTime=&quot;0&quot; EndTime=&quot;1000&quot; \/&gt;\n &lt;AnimationBehavior Key=&quot;DestPosition&quot; Property=&quot;Position&quot; DestValue=&quot;300,100,0&quot; StartTime=&quot;1000&quot; EndTime=&quot;3000&quot; \/&gt;\n &lt;\/x:Array&gt;\n &lt;\/Transition.Behaviors&gt;\n&lt;\/Transition&gt;\n<\/code>\n<p>The ID for transition is <code>Name<\/code>. Every transition has an array of behavior. Each behavior defines a target. You can bind a behavior into one animatable object in the <strong>.cs<\/strong> code.<\/p>\n<p>Following is the sample of the <strong>.cs<\/strong> 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\">Transition<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">newAnimation<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#24292E;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> myPage.<\/span><span style=\"color:#24292E;--shiki-dark:#B392F0\">GetTransition<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(<\/span><span style=\"color:#24292E;--shiki-dark:#9ECBFF\">&quot;Type1&quot;<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">);<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">PushButton<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">button<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> NameScopeExtensions.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">FindByName<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">&lt;<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">PushButton<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">&gt;(myPage, <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">&quot;Click&quot;<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">);<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">if<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> (<\/span><span style=\"color:#24292E;--shiki-dark:#79B8FF\">null<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#24292E;--shiki-dark:#F97583\">!=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> button)<\/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\"> FocusManager.Instance.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">SetCurrentFocusView<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(button);<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> button.Clicked <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">+=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> (<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">obj<\/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 style=\"color:#D73A49;--shiki-dark:#F97583\">=&gt;<\/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\">if<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> (newAnimation <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">!=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">null<\/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\"> Console.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">WriteLine<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">&quot;newAnimation.Duration: {0}&quot;<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">, newAnimation.Duration);<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> newAnimation.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">AnimateTo<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(label, <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">&quot;DestOpacity&quot;<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">);<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> newAnimation.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">AnimateTo<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(label, <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">&quot;DestPosition&quot;<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">);<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> newAnimation.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Play<\/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\">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 style=\"color:#24292E;--shiki-dark:#E1E4E8\">}<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<p>To load transition, add the following code in the XAML file of the page:<\/p>\n<code class=\"language-XML\">&lt;View.TransitionNames&gt;\n &lt;x:Array Type=&quot;{x:Type x:String}&quot;&gt;\n &lt;x:String&gt;OpacityAndPositionAnimation&lt;\/x:String&gt;\n &lt;x:String&gt;OrientationAnimation&lt;\/x:String&gt;\n &lt;\/x:Array&gt;\n&lt;\/View.TransitionNames&gt;\n<\/code>\n<p>In the preceding example, <code>OpacityAndPositionAnimation<\/code> and <code>OrientationAnimation<\/code> are the transition names.\nThe XAML file must be placed in the <strong>res\/animation<\/strong> folder.<\/p>\n<p><img src=https://samsungtizenos.com/"media//PathForTransition.PNG/" alt=\"PathForTransition\" \/><\/p>\n","table_of_content":"<ul class=\"table-of-contents\">\n<li><a href=https://samsungtizenos.com/"#content-xaml-namespaces\">XAML Namespaces<\/a><\/li>\n<li><a href=https://samsungtizenos.com/"#content-data-binding\">Data Binding<\/a><\/li>\n<li><a href=https://samsungtizenos.com/"#content-view-to-view-bindings\">View-to-View Bindings<\/a><\/li>\n<li><a href=https://samsungtizenos.com/"#content-source-and-bindingcontext\">Source and BindingContext<\/a><\/li>\n<li><a href=https://samsungtizenos.com/"#content-how-to-handle-object-created-by-xaml\">How to Handle Object Created by XAML<\/a><\/li>\n<li><a href=https://samsungtizenos.com/"#content-how-to-define-and-use-xaml-resources\">How to Define and Use XAML Resources<\/a><\/li>\n<li><a href=https://samsungtizenos.com/"#content-create-and-consume-resourcedictionary\">Create and Consume ResourceDictionary<\/a><\/li>\n<li><a href=https://samsungtizenos.com/"#content-typeconverters\">TypeConverters<\/a><\/li>\n<li><a href=https://samsungtizenos.com/"#content-type-conversion\">Type Conversion<\/a><\/li>\n<li><a href=https://samsungtizenos.com/"#content-nui-typeconverter\">NUI TypeConverter<\/a><\/li>\n<li><a href=https://samsungtizenos.com/"#content-implement-type-converter\">Implement Type Converter<\/a><\/li>\n<li><a href=https://samsungtizenos.com/"#content-property-trigger\">Property Trigger<\/a><\/li>\n<li><a href=https://samsungtizenos.com/"#content-how-to-use-transition\">How to Use Transition<\/a><\/li>\n<\/ul>\n","title":"XAML Support for Tizen.NUI","raw":null},{"class":"App\\Services\\Documentation\\Data\\RenderedMarkdown","s":"wrbl"}]},"memo":{"id":"xgibaf1BjndII43rFyIY","name":"documentation::article","path":"docs\/application\/dotnet\/guides\/user-interface\/nui\/xaml\/xaml-support-for-tizen-nui","method":"GET","release":"a-a-a","children":[],"scripts":[],"assets":[],"lazyLoaded":false,"lazyIsolated":true,"errors":[],"locale":"en","islands":[]},"checksum":"3d105ba3ca73153827d514426e053aef45d73b7d84052166bdc781b822de430d"}" wire:effects="[]" wire:id="xgibaf1BjndII43rFyIY" wire:name="documentation::article" x-init="$wire.__lazyLoad('{"data":{"forMount":[{"markdown":[{"body":"<h1 id=\"content-xaml-support-for-tizennui\"><a href=\"#content-xaml-support-for-tizennui\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>XAML Support for Tizen.NUI<\/h1><div data-knowledge-base-metadata><\/div>\n<h2 id=\"content-xaml-namespaces\"><a href=\"#content-xaml-namespaces\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>XAML Namespaces<\/h2>\n<p>To use Tizen.NUI, you must define the default namespace as shown in the following code:<\/p>\n<code class=\"language-XML\">xmlns=&quot;http:\/\/tizen.org\/Tizen.NUI\/2018\/XAML&quot;\n<\/code>\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 default namespace must be the root element of the XAML file.<\/p>\n<\/div>\n<p>The following code example shows a XAML namespace declaration:<\/p>\n<code class=\"language-XML\">xmlns:l=&quot;clr-namespace:Tizen.NUI.Examples;assembly=TestXaml&quot;\n<\/code>\n<p>The namespace prefix is specified while declaring an instance of a type from an imported namespace, as shown in the following XAML code example:<\/p>\n<code class=\"language-XML\">&lt;View x:Name=&quot;view&quot; BackgroundColor=&quot;{Binding Color}&quot; Size2D=&quot;440,400&quot; Position2D=&quot;20,10&quot; &gt;\n    &lt;View.BindingContext&gt;\n      &lt;l:HslViewModel x:Name=&quot;hsl&quot; Color=&quot;Red&quot; \/&gt;\n    &lt;\/View.BindingContext&gt;\n&lt;\/View&gt;\n<\/code>\n<p>The default namespace specifies the elements defined within the XAML file with no prefix referring to the Tizen.NUI classes, such as <code>View<\/code>.<\/p>\n<p>In the following XAML code example, namespace declaration uses <code>x<\/code> as prefix:<\/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\">xmlns:x=&quot;http:\/\/schemas.microsoft.com\/winfx\/2009\/xaml&quot;<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<p>The <code>x<\/code> namespace declaration specifies the elements defined within the XAML with a prefix of <code>x<\/code>.\nThe following table outlines the <code>x<\/code> namespace attributes supported by Tizen.NUI:<\/p>\n<div class=\"overflow-auto grid table-fixed\" data-table-container=\"data-table-container\"><table>\n<thead>\n<tr>\n<th align=\"left\">Construct<\/th>\n<th align=\"left\">Description<\/th>\n<\/tr>\n<\/thead>\n<tbody>\n<tr>\n<td align=\"left\">x:Arguments<\/td>\n<td align=\"left\">Specifies constructor arguments for a non-default constructor, or for a factory method object declaration.<\/td>\n<\/tr>\n<tr>\n<td align=\"left\">x:Class<\/td>\n<td align=\"left\">Specifies the namespace and class name for a class defined in XAML. The class name must match the class name of the code-behind file. It is a must to keep this construct in the root element of a XAML file.<\/td>\n<\/tr>\n<tr>\n<td align=\"left\">x:FactoryMethod<\/td>\n<td align=\"left\">Specifies a factory method that can be used to initialize an object.<\/td>\n<\/tr>\n<tr>\n<td align=\"left\">x:Key<\/td>\n<td align=\"left\">Specifies a unique user-defined key for each resource in a ResourceDictionary. The key's value is used to retrieve the XAML resource and is typically used as the argument for the StaticResource Markup Extension.<\/td>\n<\/tr>\n<tr>\n<td align=\"left\">x:Name<\/td>\n<td align=\"left\">Specifies a runtime object name for the XAML element. Setting <strong>x:Name<\/strong> is similar to declaring a variable in code.<\/td>\n<\/tr>\n<\/tbody>\n<\/table><\/div>\n<p>For more information, see <a href=\"https:\/\/docs.microsoft.com\/en-US\/xamarin\/xamarin-forms\/xaml\/namespaces\">https:\/\/docs.microsoft.com\/en-US\/xamarin\/xamarin-forms\/xaml\/namespaces<\/a>.<\/p>\n<h2 id=\"content-data-binding\"><a href=\"#content-data-binding\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Data Binding<\/h2>\n<p>Data bindings allow the properties of two objects to be linked together. Therefore, a change in one property causes the corresponding change in the other property that is linked.\nThere are two objects, the source and the target. The target property must be a bindable property, which means that the target object must derive from <code>BindableObject<\/code>. A property of <code>TextLabel<\/code> such as <code>Text<\/code> is associated with the bindable property <code>TextProperty<\/code>.<\/p>\n<h3 id=\"content-view-to-view-bindings\"><a href=\"#content-view-to-view-bindings\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>View-to-View Bindings<\/h3>\n<p>You can define data bindings to link properties of two views on the same page. You can set the data binding in XAML using the following:<\/p>\n<ul>\n<li>Set the <code>BindingContext<\/code> property of the target element to an <code>x:Reference<\/code> markup extension that references the source element.<\/li>\n<li>Set the target property to a <code>Binding<\/code> markup extension that references the source property.<\/li>\n<\/ul>\n<p>Following is a XAML file that contains a <code>Slider<\/code> and two <code>TextLabel<\/code> views. One of the <code>TextLabel<\/code> view is rotated by the <code>Slider<\/code> value and the other displays the <code>Slider<\/code> value:<\/p>\n<code class=\"language-XML\">&lt;TextLabel Text=&quot;ROTATION&quot; BindingContext=&quot;{x:Reference Name=slider}&quot; Position2D=&quot;50,50&quot; Rotation=&quot;{Binding Path=Value}&quot; Size2D=&quot;300,50&quot; HorizontalAlignment=&quot;Center&quot; VerticalAlignment=&quot;Center&quot; PivotPoint=&quot;Center&quot; \/&gt;\n\n&lt;Slider x:Name=&quot;slider&quot; Name=&quot;slider&quot; LowerBound=&quot;0&quot; UpperBound=&quot;360&quot; Value=&quot;10&quot; ShowPopup=&quot;true&quot; ShowValue=&quot;true&quot; ValuePrecision=&quot;1&quot; Position2D=&quot;50,200&quot; Size2D=&quot;300,20&quot; \/&gt;\n\n&lt;TextLabel BindingContext=&quot;{x:Reference slider}&quot; Position2D=&quot;50,300&quot; Size2D=&quot;300,50&quot; Text=&quot;{Binding Value, StringFormat='The angle is {0:F0} degrees'}&quot; \/&gt;\n<\/code>\n<p>The <code>Slider<\/code> contains an <code>x:Name<\/code> attribute that is referenced by the two <code>TextLabel<\/code> views using the <code>x:Reference<\/code> markup extension.<\/p>\n<h3 id=\"content-source-and-bindingcontext\"><a href=\"#content-source-and-bindingcontext\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Source and BindingContext<\/h3>\n<p>The <code>BindingContext<\/code> property is one of the two ways to link the source and target objects. You can include a reference to the source object within the binding expression.\nThe following code shows how the source object and source property can be specified in the Binding markup extension:<\/p>\n<code class=\"language-XML\">&lt;TextLabel x:Name=&quot;label&quot; Name =&quot;label&quot; Text=&quot;Text&quot; Position2D=&quot;100,100&quot; Size2D=&quot;300,50&quot; PositionX=&quot;{Binding Source={x:Reference Name=slider}, Path=Value}&quot; \/&gt;\n\n&lt;Slider x:Name=&quot;slider&quot; Name=&quot;slider&quot; LowerBound=&quot;100&quot; UpperBound=&quot;800&quot; Value=&quot;100&quot; ShowPopup=&quot;true&quot; ShowValue=&quot;false&quot; Position2D=&quot;400,400&quot; Size2D=&quot;300,20&quot; \/&gt;\n<\/code>\n<p>The <code>Binding<\/code> markup extension has two arguments, one of which is a markup extension for <code>x:Reference<\/code>. Therefore, a pair of curly braces are nested within the main curly braces:<\/p>\n<code class=\"language-XML\">PositionX=&quot;{Binding Source={x:Reference Name=slider}, Path=Value}&quot;\n<\/code>\n<p>Following are the two ways to specify the link between the source object with the target object:<\/p>\n<ul>\n<li>Use the <code>BindingContext<\/code> to reference the source object.<\/li>\n<li>Use the <code>Source<\/code> property of the <code>Binding<\/code> markup extension.<\/li>\n<\/ul>\n<p>If you specify both, the <code>Source<\/code> property takes precedence over the <code>BindingContext<\/code>.<\/p>\n<p>For more information, see <a href=\"https:\/\/docs.microsoft.com\/en-US\/xamarin\/xamarin-forms\/xaml\/xaml-basics\/data-binding-basics\">https:\/\/docs.microsoft.com\/en-US\/xamarin\/xamarin-forms\/xaml\/xaml-basics\/data-binding-basics<\/a>.<\/p>\n<h2 id=\"content-how-to-handle-object-created-by-xaml\"><a href=\"#content-how-to-handle-object-created-by-xaml\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>How to Handle Object Created by XAML<\/h2>\n<p>In order to implement various functions in an Application, the instances of objects created in XAML must be referenced and handled in the C# code.<\/p>\n<p>In the following XAML code, Tizen.NUI supports two ways to access the <code>ImageView<\/code> instance in the sample code:<\/p>\n<code class=\"language-XML\">&lt;View x:Class=&quot;Tizen.NUI.Examples.xNameDemoPage&quot;\n  xmlns=&quot;http:\/\/tizen.org\/Tizen.NUI\/2018\/XAML&quot;\n  xmlns:x=&quot;http:\/\/schemas.microsoft.com\/winfx\/2009\/xaml&quot;&gt;\n\n  &lt;ImageView x:Name=&quot;ImageOne&quot; Name=&quot;title&quot; Position2D=&quot;0,0&quot; Size2D=&quot;400,400&quot; ResourceUrl=&quot;*Resource*\/res\/xxx.png&quot;\/&gt;\n\n&lt;\/View&gt;\n<\/code>\n<ul>\n<li>View.FindChildByName<\/li>\n<li>NameScopeExtensions.FindByName&lt;T&gt;<\/li>\n<\/ul>\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\">myPage<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#24292E;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#24292E;--shiki-dark:#F97583\">new<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#24292E;--shiki-dark:#B392F0\">xNameDemoPage<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">();<\/span><\/span>\n<span class=\"line\"><span style=\"color:#6F42C1;--shiki-dark:#E1E4E8\">Tizen<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">.<\/span><span style=\"color:#6F42C1;--shiki-dark:#E1E4E8\">NUI<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">.<\/span><span style=\"color:#6F42C1;--shiki-dark:#E1E4E8\">Xaml<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">.<\/span><span style=\"color:#6F42C1;--shiki-dark:#E1E4E8\">Extensions<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">LoadFromXaml<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(<\/span><span style=\"color:#6F42C1;--shiki-dark:#E1E4E8\">myPage<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">, <\/span><span style=\"color:#6F42C1;--shiki-dark:#F97583\">typeof<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">xNameDemoPage<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">));<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">ImageView<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">title<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> myPage.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">FindChildByName<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">&quot;title&quot;<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">) <\/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\">ImageView<\/span><span style=\"color:#6F42C1;--shiki-dark:#E1E4E8\">;<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#B392F0\">ImageView<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#24292E;--shiki-dark:#B392F0\">imageOne<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> NameScopeExtensions.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">FindByName<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">&lt;<\/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\">NUI<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">BaseComponents<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">ImageView<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">&gt;(myPage, <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">&quot;ImageOne&quot;<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">);<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<p>In <code>View.FindChildByName<\/code> method, set the <code>Name<\/code> property of the control as <code>Name=&quot;title&quot;<\/code>. In the <code>NameScopeExtensions.FindByName&lt;T&gt;<\/code> method, set <code>x:Name<\/code> of the element as <code>x:Name=&quot;ImageOne&quot;<\/code>.\nTo have a better performance, it is recommended to use the <code>NameScopeExtensions.FindByName&lt;T&gt;<\/code> method.<\/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>If you add the Tizen.NUI.XamlBuild nuget package into a project, and set the XAML file as <code>Embedded Resource<\/code>. It will be generated in the <strong>.g.cs<\/strong> file.\nIn the <strong>.g.cs<\/strong> file, every node with <code>x:Name<\/code> in XAML has a variable that is generated with a similar name as its <code>x:Name<\/code>. You can use it directly in your <strong>.xaml.cs<\/strong> file.<\/p>\n<\/div>\n<h2 id=\"content-how-to-define-and-use-xaml-resources\"><a href=\"#content-how-to-define-and-use-xaml-resources\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>How to Define and Use XAML Resources<\/h2>\n<p>XAML resources are definitions of objects that can be shared and reused throughout a Tizen.NUI application. These resource objects are stored in a resource dictionary.<\/p>\n<p><code>View<\/code> defines a property named as <code>XamlResources<\/code>, which is of type <code>ResourceDictionary<\/code>. The <code>ResourceDictionary<\/code> is a dictionary with <code>string<\/code> keys and values of an object. Items can be added to this dictionary in XAML, and they can be accessed in XAML with the <code>StaticResource<\/code> and <code>DynamicResource<\/code> markup extensions.\n<code>DynamicResource<\/code> is for the dictionary keys associated with values that might change during runtime, while <code>StaticResource<\/code> accesses elements from the dictionary only once when the elements on the page are constructed.<\/p>\n<h3 id=\"content-create-and-consume-resourcedictionary\"><a href=\"#content-create-and-consume-resourcedictionary\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Create and Consume ResourceDictionary<\/h3>\n<p>Each resource has a key that is specified using the <code>x:Key<\/code> attribute, which becomes a dictionary key in <code>ResourceDictionary<\/code>.\nThe following <strong>TestStaticDynamicResource<\/strong> example explains the usage of <code>StaticResource<\/code> and <code>DynamicResource<\/code>:<\/p>\n<code class=\"language-XML\">&lt;View x:Class=&quot;Tizen.NUI.Examples.TestStaticDynamicResourcePage&quot;\n  xmlns=&quot;http:\/\/tizen.org\/Tizen.NUI\/2018\/XAML&quot;\n  xmlns:x=&quot;http:\/\/schemas.microsoft.com\/winfx\/2009\/xaml&quot;&gt;\n\n  &lt;View.XamlResources&gt;\n    &lt;ResourceDictionary&gt;\n      &lt;x:String x:Key=&quot;urlKey&quot;&gt;\n          *Resource*\/res\/picture_m_1.jpg\n      &lt;\/x:String&gt;\n      &lt;x:String x:Key=&quot;positionKey&quot;&gt;\n          200, 200\n      &lt;\/x:String&gt;\n    &lt;\/ResourceDictionary&gt;\n  &lt;\/View.XamlResources&gt;`\n\n  &lt;ImageView x:Name=&quot;img1&quot; ResourceUrl=&quot;{StaticResource urlKey}&quot;  Position2D=&quot;{DynamicResource positionKey}&quot;\/&gt;\n&lt;\/View&gt;\n<\/code>\n<p><code>StaticResource<\/code> accesses the item in the dictionary only once, while XAML is being parsed and the page is being built. However, <code>DynamicResource<\/code> maintains a link between the dictionary key and the property set from that dictionary item. If the item in the resource dictionary referenced by the key changes, then <code>DynamicResource<\/code> will detect that change and set the new value to the property.\nWhen you change the value of <code>&quot;positionKey&quot;<\/code>, <code>DynamicResource<\/code> will detect that change and set the new value to the <code>Position2D<\/code> property.<\/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\">Tizen<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">NUI<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Binding<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">ResourceDictionary<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">dict<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#24292E;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> Tizen.NUI.GetResourcesProvider.<\/span><span style=\"color:#24292E;--shiki-dark:#B392F0\">Get<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">().XamlResources;<\/span><\/span>\n<span class=\"line\"><span style=\"color:#6F42C1;--shiki-dark:#E1E4E8\">Tizen<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">.<\/span><span style=\"color:#6F42C1;--shiki-dark:#E1E4E8\">NUI<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">.<\/span><span style=\"color:#6F42C1;--shiki-dark:#E1E4E8\">GetResourcesProvider<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Get<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">().XamlResources[<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">&quot;positionKey&quot;<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">] <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> positionX.<\/span><span style=\"color:#24292E;--shiki-dark:#B392F0\">ToString<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">() <\/span><span style=\"color:#24292E;--shiki-dark:#F97583\">+<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#24292E;--shiki-dark:#9ECBFF\">&quot;,&quot;<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#24292E;--shiki-dark:#F97583\">+<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> positionY.<\/span><span style=\"color:#24292E;--shiki-dark:#B392F0\">ToString<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">();<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<p>For more information, see <a href=\"https:\/\/docs.microsoft.com\/en-US\/xamarin\/xamarin-forms\/xaml\/resource-dictionaries\">https:\/\/docs.microsoft.com\/en-US\/xamarin\/xamarin-forms\/xaml\/resource-dictionaries<\/a>.<\/p>\n<h2 id=\"content-typeconverters\"><a href=\"#content-typeconverters\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>TypeConverters<\/h2>\n<p>If you want to convert a string to some custom type in XAML, you need to define a TypeConverter. This changes the string format as a XAML format such as converting <code>Red<\/code> to <code>Color.Red<\/code>.\nIf you write a custom class, and you want instances of your class to be usable as XAML settable attribute values, you might need to write a custom TypeConverter class.<\/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>NUI XAML is very similar to WPF XAML. For more information, see <a href=\"https:\/\/docs.microsoft.com\/en-us\/dotnet\/framework\/wpf\/advanced\/typeconverters-and-xaml\">TypeConverters and XAML<\/a>.<\/p>\n<\/div>\n<h3 id=\"content-type-conversion\"><a href=\"#content-type-conversion\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Type Conversion<\/h3>\n<p>In the XAML file, all the attribute values are represented as type of string with pure text.\nEven primitives (ex: Int, Double) are simple text string and they are needed to be changed as the type that XAML processor can understand.\nFor instance, <strong>Tizen.NUI<\/strong> defines some properties that take a value of type <code>Size2D<\/code>.\n<code>Size2D<\/code> is a value that describes two-dimensional sizes and has two important properties, width and height.\nWhen you are specifying size2D in XAML, you must specify it as a string with a comma between the width and height values:<\/p>\n<code class=\"language-XML\">&lt;ImageView PositionX=&quot;100&quot; PositionY=&quot;320&quot; Size2D=&quot;300, 300&quot; ResourceUrl=&quot;ImageResourcePath&quot;\/&gt;\n<\/code>\n<p>In this scenario, the type converter is the <code>Size2DTypeConverter<\/code> class.\nIf a type converter is not available, you must use verbose markup as shown in the following code:<\/p>\n<code class=\"language-XML\">&lt;ImageView PositionX=&quot;100&quot; PositionY=&quot;320&quot; ResourceUrl=&quot;ImageResourcePath&quot;&gt;\n  &lt;ImageView.Size2D&gt;\n    &lt;Size2D Width=&quot;300&quot; Height=&quot;300&quot;\/&gt;\n  &lt;\/ImageView.Size2D&gt;\n&lt;\/ImageView&gt;\n<\/code>\n<h3 id=\"content-nui-typeconverter\"><a href=\"#content-nui-typeconverter\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>NUI TypeConverter<\/h3>\n<p>Currently, Tizen.NUI supports the following type converters:<\/p>\n<ul>\n<li><code>ColorTypeConverter<\/code><\/li>\n<li><code>PositionTypeConverter<\/code><\/li>\n<li><code>Position2DTypeConverter<\/code><\/li>\n<li><code>SizeTypeConverter<\/code><\/li>\n<li><code>Size2DTypeConverter<\/code><\/li>\n<li><code>Vector2TypeConverter<\/code><\/li>\n<li><code>Vector3TypeConverter<\/code><\/li>\n<li><code>Vector4TypeConverter<\/code><\/li>\n<li><code>RelativeVector2TypeConverter<\/code><\/li>\n<li><code>RelativeVector3TypeConverter<\/code><\/li>\n<li><code>RelativeVector4TypeConverter<\/code><\/li>\n<\/ul>\n<p>Therefore, you can define the color, position, Size2D, and so on as string in XAML as shown in the following code:<\/p>\n<code class=\"language-XML\">&lt;TextLabel Text=&quot;HelloWorld!&quot; BackgroundColor=&quot;1.0,0.0,0.0,1.0&quot; Position=&quot;20,10,0&quot; Size2D=&quot;440,400&quot;\/&gt;\n<\/code>\n<h3 id=\"content-implement-type-converter\"><a href=\"#content-implement-type-converter\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Implement Type Converter<\/h3>\n<p>If you want to convert a string to some custom type in XAML, you need to define a <code>TypeConverter<\/code>.\nThe most important method in <code>TypeConverter<\/code> is <code>ConvertFromInvariantString<\/code>, which converts the input string to the required object type.\nYou can see <code>Size2DTypeConverter<\/code> as shown in 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:#D73A49;--shiki-dark:#F97583\">internal<\/span><span style=\"color:#D73A49;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">class<\/span><span style=\"color:#D73A49;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#B392F0\">Size2DTypeConverter<\/span><span style=\"color:#D73A49;--shiki-dark:#E1E4E8\"> : <\/span><span style=\"color:#D73A49;--shiki-dark:#B392F0\">TypeConverter<\/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:#24292E;--shiki-dark:#F97583\">public<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#24292E;--shiki-dark:#F97583\">override<\/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\">ConvertFromInvariantString<\/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\">value<\/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\">if<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> (value <\/span><span style=\"color:#24292E;--shiki-dark:#F97583\">!=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#24292E;--shiki-dark:#79B8FF\">null<\/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:#24292E;--shiki-dark:#B392F0\">parts<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> value.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Split<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">&#39;,&#39;<\/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:#F97583\">if<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> (parts.Length <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">==<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">2<\/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:#24292E;--shiki-dark:#F97583\">return<\/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\">Size2D<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(Int32.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Parse<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(parts[<\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">0<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">].<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Trim<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(), CultureInfo.InvariantCulture),<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">                                Int32.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Parse<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(parts[<\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">1<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">].<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Trim<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(), CultureInfo.InvariantCulture));<\/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>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">        <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">throw<\/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\">InvalidOperationException<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">$&quot;Cannot convert <\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">\\&quot;<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">{<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">value<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">}<\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">\\&quot;<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\"> into <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">{<\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">typeof<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">(<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Size2D<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">)}<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">&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<h2 id=\"content-property-trigger\"><a href=\"#content-property-trigger\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Property Trigger<\/h2>\n<p>The following example shows two triggers that changes <code>PositionX<\/code> of the <code>ImageView<\/code> property when the <code>ResourceUrl<\/code> property is changed to or set equal to <code>..\/res\/detail.png<\/code> or <code>..\/res\/sendtophone.png<\/code>:<\/p>\n<code class=\"language-XML\">&lt;View x:Class=&quot;Tizen.NUI.Examples.StyleDemoPage&quot;\n  xmlns=&quot;http:\/\/tizen.org\/Tizen.NUI\/2018\/XAML&quot;\n  xmlns:x=&quot;http:\/\/schemas.microsoft.com\/winfx\/2009\/xaml&quot;&gt;\n\n  &lt;View.XamlResources&gt;\n    &lt;ResourceDictionary&gt;\n      &lt;Style x:Key=&quot;CustomStyle&quot; TargetType=&quot;ImageView&quot;&gt;\n        &lt;Style.Triggers&gt;\n          &lt;Trigger TargetType=&quot;ImageView&quot; Property=&quot;ResourceUrl&quot; Value=&quot;..\/res\/detail.png&quot;&gt;\n            &lt;Trigger.Setters &gt;\n              &lt;Setter Property=&quot;PositionX&quot; Value=&quot;200&quot; \/&gt;\n            &lt;\/Trigger.Setters&gt;\n          &lt;\/Trigger&gt;\n          &lt;Trigger TargetType=&quot;ImageView&quot; Property=&quot;ResourceUrl&quot; Value=&quot;..\/res\/sendtophone.png&quot;&gt;\n            &lt;Trigger.Setters &gt;\n              &lt;Setter Property=&quot;PositionX&quot; Value=&quot;500&quot; \/&gt;\n            &lt;\/Trigger.Setters&gt;\n          &lt;\/Trigger&gt;\n        &lt;\/Style.Triggers&gt;\n      &lt;\/Style&gt;\n    &lt;\/ResourceDictionary&gt;\n  &lt;\/View.XamlResources&gt;\n\n  &lt;ImageView Name=&quot;ImageView&quot; Position2D=&quot;0,0&quot; Size2D=&quot;400,400&quot; Style=&quot;{StaticResource CustomStyle}&quot;&gt;\n    &lt;x:Arguments&gt;\n      &lt;x:String&gt;..\/res\/traffic_content.png&lt;\/x:String&gt;\n    &lt;\/x:Arguments&gt;\n  &lt;\/ImageView&gt;\n\n  &lt;PushButton Name=&quot;Click&quot; LabelText=&quot;Click&quot; Size2D=&quot;400,80&quot; Position2D=&quot;1000,100&quot; \/&gt;\n&lt;\/View&gt;\n<\/code>\n<ul>\n<li><code>TargetType<\/code>: The control type that the trigger applies to.<\/li>\n<li><code>Property<\/code>: The property on the control that is monitored.<\/li>\n<li><code>Value<\/code>: The value that occurs for the monitored property that causes the trigger to activate.<\/li>\n<li><code>Setter<\/code>: A collection of Setter elements can be added when the trigger condition is met. You must specify <code>Property<\/code> and set <code>Value<\/code>.<\/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>The Property for Trigger and Setter must not be same.<\/p>\n<\/div>\n<p>For more information, see <a href=\"https:\/\/docs.microsoft.com\/en-us\/xamarin\/xamarin-forms\/app-fundamentals\/triggers#targetText=Triggers%20allow%20you%20to%20express,on%20events%20or%20property%20changes.&amp;targetText=Property%20Trigger%20%2D%20occurs%20when%20a,the%20properties%20of%20another%20control\">Xamarin.Forms Triggers<\/a>.<\/p>\n<h2 id=\"content-how-to-use-transition\"><a href=\"#content-how-to-use-transition\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>How to Use Transition<\/h2>\n<p>To load a transition, you can create transition in XAML and then use this transition in the <strong>.cs<\/strong> code.<\/p>\n<p>Following is the format of transition in XAML:<\/p>\n<code class=\"language-XML\">&lt;?xml version=&quot;1.0&quot; encoding=&quot;UTF-8&quot; ?&gt;\n&lt;Transition xmlns=&quot;http:\/\/tizen.org\/Tizen.NUI\/2018\/XAML&quot;\n            xmlns:x=&quot;http:\/\/schemas.microsoft.com\/winfx\/2009\/xaml&quot;\n            Duration=&quot;3000&quot;\n            LoopCount=&quot;3&quot;\n            EndAction=&quot;Cancel&quot;\n            Name=&quot;Type1&quot;&gt;\n  &lt;Transition.Behaviors&gt;\n    &lt;x:Array Type=&quot;{x:Type AnimationBehavior}&quot;&gt;\n      &lt;AnimationBehavior Key=&quot;DestOpacity&quot; Property=&quot;Opacity&quot; DestValue=&quot;0.5&quot; StartTime=&quot;0&quot; EndTime=&quot;1000&quot; \/&gt;\n      &lt;AnimationBehavior Key=&quot;DestPosition&quot; Property=&quot;Position&quot; DestValue=&quot;300,100,0&quot; StartTime=&quot;1000&quot; EndTime=&quot;3000&quot; \/&gt;\n    &lt;\/x:Array&gt;\n  &lt;\/Transition.Behaviors&gt;\n&lt;\/Transition&gt;\n<\/code>\n<p>The ID for transition is <code>Name<\/code>. Every transition has an array of behavior. Each behavior defines a target. You can bind a behavior into one animatable object in the <strong>.cs<\/strong> code.<\/p>\n<p>Following is the sample of the <strong>.cs<\/strong> 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\">Transition<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">newAnimation<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#24292E;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> myPage.<\/span><span style=\"color:#24292E;--shiki-dark:#B392F0\">GetTransition<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(<\/span><span style=\"color:#24292E;--shiki-dark:#9ECBFF\">&quot;Type1&quot;<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">);<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">PushButton<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">button<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> NameScopeExtensions.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">FindByName<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">&lt;<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">PushButton<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">&gt;(myPage, <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">&quot;Click&quot;<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">);<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">if<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> (<\/span><span style=\"color:#24292E;--shiki-dark:#79B8FF\">null<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#24292E;--shiki-dark:#F97583\">!=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> button)<\/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\">    FocusManager.Instance.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">SetCurrentFocusView<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(button);<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">    button.Clicked <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">+=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> (<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">obj<\/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 style=\"color:#D73A49;--shiki-dark:#F97583\">=&gt;<\/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\">if<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> (newAnimation <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">!=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">null<\/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\">            Console.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">WriteLine<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">&quot;newAnimation.Duration: {0}&quot;<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">, newAnimation.Duration);<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">            newAnimation.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">AnimateTo<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(label, <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">&quot;DestOpacity&quot;<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">);<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">            newAnimation.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">AnimateTo<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(label, <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">&quot;DestPosition&quot;<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">);<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">            newAnimation.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Play<\/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\">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 style=\"color:#24292E;--shiki-dark:#E1E4E8\">}<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<p>To load transition, add the following code in the XAML file of the page:<\/p>\n<code class=\"language-XML\">&lt;View.TransitionNames&gt;\n  &lt;x:Array Type=&quot;{x:Type x:String}&quot;&gt;\n    &lt;x:String&gt;OpacityAndPositionAnimation&lt;\/x:String&gt;\n    &lt;x:String&gt;OrientationAnimation&lt;\/x:String&gt;\n  &lt;\/x:Array&gt;\n&lt;\/View.TransitionNames&gt;\n<\/code>\n<p>In the preceding example, <code>OpacityAndPositionAnimation<\/code> and <code>OrientationAnimation<\/code> are the transition names.\nThe XAML file must be placed in the <strong>res\/animation<\/strong> folder.<\/p>\n<p><img src=\"media\/PathForTransition.PNG\" alt=\"PathForTransition\" \/><\/p>\n","table_of_content":"<ul class=\"table-of-contents\">\n<li><a href=\"#content-xaml-namespaces\">XAML Namespaces<\/a><\/li>\n<li><a href=\"#content-data-binding\">Data Binding<\/a><\/li>\n<li><a href=\"#content-view-to-view-bindings\">View-to-View Bindings<\/a><\/li>\n<li><a href=\"#content-source-and-bindingcontext\">Source and BindingContext<\/a><\/li>\n<li><a href=\"#content-how-to-handle-object-created-by-xaml\">How to Handle Object Created by XAML<\/a><\/li>\n<li><a href=\"#content-how-to-define-and-use-xaml-resources\">How to Define and Use XAML Resources<\/a><\/li>\n<li><a href=\"#content-create-and-consume-resourcedictionary\">Create and Consume ResourceDictionary<\/a><\/li>\n<li><a href=\"#content-typeconverters\">TypeConverters<\/a><\/li>\n<li><a href=\"#content-type-conversion\">Type Conversion<\/a><\/li>\n<li><a href=\"#content-nui-typeconverter\">NUI TypeConverter<\/a><\/li>\n<li><a href=\"#content-implement-type-converter\">Implement Type Converter<\/a><\/li>\n<li><a href=\"#content-property-trigger\">Property Trigger<\/a><\/li>\n<li><a href=\"#content-how-to-use-transition\">How to Use Transition<\/a><\/li>\n<\/ul>\n","title":"XAML Support for Tizen.NUI","raw":null},{"class":"App\\Services\\Documentation\\Data\\RenderedMarkdown","s":"wrbl"}]},{"s":"arr"}]},"memo":{"id":"a7saSitnoIgAbE8TZpEb","name":"__mountParamsContainer","path":"docs\/application\/dotnet\/guides\/user-interface\/nui\/xaml\/xaml-support-for-tizen-nui","method":"GET","release":"a-a-a"},"checksum":"05584becad393801f417df026380fcdf333a341808017e0300d5a1f0f4f38994"}')" >

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.