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
Grid Layout API<\/a><\/li>\n<\/ul>\n<\/li>\n<\/ul>\n&lt;script>\n function openTabSection(evt, profileName, sectionId) {\n var i, tabcontent, tablinks, section;\n let selected = 0;\n\n section = document.getElementById(sectionId);\n tabcontent = section.getElementsByClassName(\"tabcontent\");\n\n for (i = 0; i < tabcontent.length; i++) {\n tabcontent[i].style.display = \"none\";\n if (tabcontent[i].id == profileName) {\n selected = i;\n }\n }\n\n tablinks = section.getElementsByClassName(\"tablinks\");\n\n for (i = 0; i < tablinks.length; i++) {\n tablinks[i].className = tablinks[i].className.replace(\" active\", \"\");\n }\n\n tabcontent[selected].style.display = \"block\";\n evt.currentTarget.className += \" active\";\n }\n\n document.getElementById(\"GridLayout-RowsColumns-CSharp\").click();\n&lt;\/script>\n","table_of_content":"<ul class=\"table-of-contents\">\n<li><a href=https://samsungtizenos.com/"#content-columns-and-rows\">Columns and rows<\/a><\/li>\n<li><a href=https://samsungtizenos.com/"#content-grid-orientation\">Grid orientation<\/a><\/li>\n<li><a href=https://samsungtizenos.com/"#content-column-spacing-and-row-spacing\">Column spacing and row spacing<\/a><\/li>\n<li><a href=https://samsungtizenos.com/"#content-column-and-row\">Column and row<\/a><\/li>\n<li><a href=https://samsungtizenos.com/"#content-column-span-and-row-span\">Column span and row span<\/a><\/li>\n<li><a href=https://samsungtizenos.com/"#content-horizontal-stretch-and-vertical-stretch\">Horizontal stretch and vertical stretch<\/a><\/li>\n<li><a href=https://samsungtizenos.com/"#content-horizontal-alignment-and-vertical-alignment\">Horizontal alignment and vertical alignment<\/a><\/li>\n<li><a href=https://samsungtizenos.com/"#content-related-information\">Related information<\/a><\/li>\n<\/ul>\n","title":"Grid Layout","raw":null},{"class":"App\\Services\\Documentation\\Data\\RenderedMarkdown","s":"wrbl"}]},"memo":{"id":"ZDEMNTLvkrGqAEnpKJGQ","name":"documentation::article","path":"docs\/application\/dotnet\/guides\/user-interface\/nui\/grid-layout","method":"GET","release":"a-a-a","children":[],"scripts":[],"assets":[],"lazyLoaded":false,"lazyIsolated":true,"errors":[],"locale":"en","islands":[]},"checksum":"7681ffe9a44ce074e0fdd6a299b9b52ec3f49ffd5f38da6d9ae28f032006ddbe"}" wire:effects="[]" wire:id="ZDEMNTLvkrGqAEnpKJGQ" wire:name="documentation::article" x-init="$wire.__lazyLoad('{"data":{"forMount":[{"markdown":[{"body":"<h1 id=\"content-grid-layout\"><a href=\"#content-grid-layout\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Grid Layout<\/h1><div data-knowledge-base-metadata><\/div>\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>Only <code>Columns<\/code> property is supported on Tizen 5.5.<\/p>\n<\/div>\n<p><code>GridLayout<\/code> is a grid box for the two dimensional layout. It constraints the x and y position, width, and height of the child actors. It positions the children in a grid form, where the size of each column and row is set to the largest size of the cells belonging to their axis.<\/p>\n<p>Two types of properties affect the <code>GridLayout<\/code>. One is the property for the grid layout and the other is the property that affects the specified child.<\/p>\n<p>The following table describes the properties of <code>GridLayout<\/code>:<\/p>\n<div class=\"overflow-auto grid table-fixed\" data-table-container=\"data-table-container\"><table>\n<thead>\n<tr>\n<th>Property<\/th>\n<th>Type<\/th>\n<th>Description<\/th>\n<\/tr>\n<\/thead>\n<tbody>\n<tr>\n<td><code>Columns<\/code><\/td>\n<td>int<\/td>\n<td>Gets or sets the number of columns in the grid.<\/td>\n<\/tr>\n<tr>\n<td><code>Rows<\/code><\/td>\n<td>int<\/td>\n<td>Gets or sets the number of rows in the grid.<\/td>\n<\/tr>\n<tr>\n<td><code>GridOrientation<\/code><\/td>\n<td>Orientation<\/td>\n<td>Gets or sets the orientation in the grid.<\/td>\n<\/tr>\n<tr>\n<td><code>ColumnSpacing<\/code><\/td>\n<td>float<\/td>\n<td>Gets or sets the distance between columns.<\/td>\n<\/tr>\n<tr>\n<td><code>RowSpacing<\/code><\/td>\n<td>float<\/td>\n<td>Gets or sets the distance between rows.<\/td>\n<\/tr>\n<\/tbody>\n<\/table><\/div>\n<p><a name=\"columns-and-rows\"><\/a><\/p>\n<h2 id=\"content-columns-and-rows\"><a href=\"#content-columns-and-rows\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Columns and rows<\/h2>\n<p>The <code>Columns<\/code> and the <code>Rows<\/code> properties specify the maximum number of cells on a horizontal or vertical axis.<\/p>\n<p>When the <code>Column<\/code> or <code>Row<\/code> of child is automatically set without a specified value, the value cannot exceed the number of main-axis cell which is the <code>Columns<\/code> value on horizontal orientation, or the <code>Rows<\/code> value on vertical orientation. However, it can be assigned a value that exceeds the number of cross-axis cell.<\/p>\n<p>The following figure shows how to set the <code>Columns<\/code> and the <code>Rows<\/code> properties. Since the <code>GridOrientation<\/code> is set to horizontal, the row index of last item can be <code>2<\/code> that exceeds the <code>Rows<\/code> property.<\/p>\n<p><img src=\"media\/columnLayout.png\" alt=\"Column\" \/><\/p>\n<div id=\"TabSection1\">\n    <div class=\"sampletab \" id=\"ProjectCreateTab\">\n        <button id=\"GridLayout-RowsColumns-CSharp\" class=\"tablinks \" onclick=\"openTabSection(event, 'GridLayout-RowsColumns-CSharp', 'TabSection1') \">C#<\/button>\n        <button id=\"GridLayout-RowsColumns-Xaml\" class=\"tablinks \" onclick=\"openTabSection(event, 'GridLayout-RowsColumns-Xaml', 'TabSection1') \">Xaml<\/button>\n    <\/div>\n    <div id=\"GridLayout-RowsColumns-CSharp\" class=\"tabcontent\">\n        <table>\n            <tbody>\n                <tr>\n<span style=\"display:block\">\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\">layoutView<\/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:#D73A49;--shiki-dark:#F97583\">var<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">gridLayout<\/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\">GridLayout<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">();<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">gridLayout.GridOrientation <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> GridLayout.Orientation.Horizontal;<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">gridLayout.Columns <\/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\">gridLayout.Rows <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">1<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">;<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">layoutView.Layout <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> gridLayout;<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<\/span>\n                <\/tr>\n            <\/tbody>\n        <\/table>\n    <\/div>\n    <div id=\"GridLayout-RowsColumns-Xaml\" class=\"tabcontent\">\n        <table>\n            <tbody>\n                <tr>\n<span style=\"display:block\">\n<code class=\"language-xaml\">&lt;View&gt;\n    &lt;View.Layout&gt;\n        &lt;GridLayout Columns=&quot;2&quot; Rows=&quot;1&quot; \/&gt;\n    &lt;\/View.Layout&gt;\n&lt;\/View&gt;\n<\/code>\n<\/span>\n                <\/tr>\n            <\/tbody>\n        <\/table>\n    <\/div>\n<\/div>\n<p><a name=\"grid-orientation\"><\/a><\/p>\n<h2 id=\"content-grid-orientation\"><a href=\"#content-grid-orientation\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Grid orientation<\/h2>\n<p>The <code>GridOrientation<\/code> only works when a child is added without the specified <code>Row<\/code> or <code>Column<\/code> property.<\/p>\n<ul>\n<li>On horizontal orientation, the children will automatically occupy empty cells from left to right.<\/li>\n<li>On vertical orientation, the children will automatically occupy empty cells from top to bottom.<\/li>\n<\/ul>\n<p>The following figure shows how the <code>GridOrientation<\/code> property works:<\/p>\n<p><img src=\"media\/gridOrientation.png\" alt=\"gridOrientation\" \/><\/p>\n<h2 id=\"content-column-spacing-and-row-spacing\"><a href=\"#content-column-spacing-and-row-spacing\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Column spacing and row spacing<\/h2>\n<p>The <code>ColumnSpacing<\/code> and <code>RowSpacing<\/code> properties are the distance between columns or rows. In order to set the same space between the child, you can use <code>ColumnSpacing<\/code> and <code>RowSpacing<\/code> properties instead of setting the same margin for each child.<\/p>\n<p>The following figure shows how the <code>ColumnSpacing<\/code> and <code>RowSpacing<\/code> properties work:<\/p>\n<p><img src=\"media\/gridSpacing.png\" alt=\"gridSpacing\" \/><\/p>\n<p>The following table describes the properties that affect the specified child:<\/p>\n<div class=\"overflow-auto grid table-fixed\" data-table-container=\"data-table-container\"><table>\n<thead>\n<tr>\n<th>Property<\/th>\n<th>Type<\/th>\n<th>Description<\/th>\n<\/tr>\n<\/thead>\n<tbody>\n<tr>\n<td><code>Column<\/code><\/td>\n<td>int<\/td>\n<td>Gets or sets the column index of the child.<\/td>\n<\/tr>\n<tr>\n<td><code>Row<\/code><\/td>\n<td>int<\/td>\n<td>Gets or sets the row index of the child.<\/td>\n<\/tr>\n<tr>\n<td><code>ColumnSpan<\/code><\/td>\n<td>int<\/td>\n<td>Gets or sets the number of columns that the child occupy.<\/td>\n<\/tr>\n<tr>\n<td><code>RowSpan<\/code><\/td>\n<td>int<\/td>\n<td>Gets or sets the number of rows that the child occupy.<\/td>\n<\/tr>\n<tr>\n<td><code>HorizontalStretch<\/code><\/td>\n<td>StretchFlags<\/td>\n<td>Gets or sets the value how child is resized within horizontal space of the cell where child occupy.<\/td>\n<\/tr>\n<tr>\n<td><code>VerticalStretch<\/code><\/td>\n<td>StretchFlags<\/td>\n<td>Gets or sets the value how child is resized within vertical space of the cell where child occupy.<\/td>\n<\/tr>\n<tr>\n<td><code>HorizontalAlignment<\/code><\/td>\n<td>Alignment<\/td>\n<td>Gets or sets the horizontal alignment of the child within the cell.<\/td>\n<\/tr>\n<tr>\n<td><code>VerticalAlignment<\/code><\/td>\n<td>Alignment<\/td>\n<td>Gets or sets the vertical alignment of the child within the cell.<\/td>\n<\/tr>\n<\/tbody>\n<\/table><\/div>\n<h2 id=\"content-column-and-row\"><a href=\"#content-column-and-row\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Column and row<\/h2>\n<p>The <code>Column<\/code> and <code>Row<\/code> properties specify the cell index of the child. If these properties aren't assigned, they are automatically set depending on <a href=\"#grid-orientation\"><code>GridOrientation<\/code><\/a>, <a href=\"#columns-and-rows\"><code>Columns<\/code><\/a> and <a href=\"#columns-and-rows\"><code>Rows<\/code><\/a>.<\/p>\n<p>The following figure shows how to position child on the grid using <code>Column<\/code> and <code>Row<\/code> properties:<\/p>\n<p><img src=\"media\/gridColumnRow.png\" alt=\"gridColumnRow\" \/><\/p>\n<h2 id=\"content-column-span-and-row-span\"><a href=\"#content-column-span-and-row-span\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Column span and row span<\/h2>\n<p>The <code>ColumnSpan<\/code> and <code>RowSpan<\/code> properties specify the number of cells that the child can occupy. The sum of cell index and cell span should be less than the maximum number of cells specified by <code>Columns<\/code> or <code>Rows<\/code> properties.<\/p>\n<p>The following figure shows how to position child on the grid using <code>Column<\/code> and <code>ColumnSpan<\/code> properties:<\/p>\n<p><img src=\"media\/gridColumn.png\" alt=\"gridColumn\" \/><\/p>\n<h2 id=\"content-horizontal-stretch-and-vertical-stretch\"><a href=\"#content-horizontal-stretch-and-vertical-stretch\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Horizontal stretch and vertical stretch<\/h2>\n<p>The <code>HorizontalStretch<\/code> and <code>VerticalStretch<\/code> properties define how a child is resized within the space of the cell. The values can be specified as <code>Stretchflags<\/code> enum:<\/p>\n<p><img src=\"media\/gridStretch.png\" alt=\"gridStretch\" \/><\/p>\n<div class=\"overflow-auto grid table-fixed\" data-table-container=\"data-table-container\"><table>\n<thead>\n<tr>\n<th>Value<\/th>\n<th>Description<\/th>\n<\/tr>\n<\/thead>\n<tbody>\n<tr>\n<td><code>None<\/code><\/td>\n<td>Fits to the measured size.<\/td>\n<\/tr>\n<tr>\n<td><code>Fill<\/code><\/td>\n<td>Resizes to completely fill the space.<\/td>\n<\/tr>\n<tr>\n<td><code>Expand<\/code><\/td>\n<td>Expands to share available space.<\/td>\n<\/tr>\n<tr>\n<td><code>ExpandAndFill<\/code><\/td>\n<td>Expands to share available space and fill the space.<\/td>\n<\/tr>\n<\/tbody>\n<\/table><\/div>\n<h2 id=\"content-horizontal-alignment-and-vertical-alignment\"><a href=\"#content-horizontal-alignment-and-vertical-alignment\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Horizontal alignment and vertical alignment<\/h2>\n<p>The <code>HorizontalAlignment<\/code> and <code>VerticalAlignment<\/code> properties specify the alignment for the child within its cells:<\/p>\n<p><img src=\"media\/gridAlignment.png\" alt=\"gridAlignment\" \/><\/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>\n<p>Dependencies<\/p>\n<ul>\n<li>Tizen 5.5 and Higher<\/li>\n<\/ul>\n<\/li>\n<li>\n<p>API References<\/p>\n<ul>\n<li><a href=\"\/application\/dotnet\/api\/TizenFX\/latest\/api\/Tizen.NUI.GridLayout.md\">Grid Layout API<\/a><\/li>\n<\/ul>\n<\/li>\n<\/ul>\n&lt;script>\n    function openTabSection(evt, profileName, sectionId) {\n        var i, tabcontent, tablinks, section;\n        let selected = 0;\n\n        section = document.getElementById(sectionId);\n        tabcontent = section.getElementsByClassName(\"tabcontent\");\n\n        for (i = 0; i < tabcontent.length; i++) {\n            tabcontent[i].style.display = \"none\";\n            if (tabcontent[i].id == profileName) {\n                selected = i;\n            }\n        }\n\n        tablinks = section.getElementsByClassName(\"tablinks\");\n\n        for (i = 0; i < tablinks.length; i++) {\n            tablinks[i].className = tablinks[i].className.replace(\" active\", \"\");\n        }\n\n        tabcontent[selected].style.display = \"block\";\n        evt.currentTarget.className += \" active\";\n    }\n\n    document.getElementById(\"GridLayout-RowsColumns-CSharp\").click();\n&lt;\/script>\n","table_of_content":"<ul class=\"table-of-contents\">\n<li><a href=\"#content-columns-and-rows\">Columns and rows<\/a><\/li>\n<li><a href=\"#content-grid-orientation\">Grid orientation<\/a><\/li>\n<li><a href=\"#content-column-spacing-and-row-spacing\">Column spacing and row spacing<\/a><\/li>\n<li><a href=\"#content-column-and-row\">Column and row<\/a><\/li>\n<li><a href=\"#content-column-span-and-row-span\">Column span and row span<\/a><\/li>\n<li><a href=\"#content-horizontal-stretch-and-vertical-stretch\">Horizontal stretch and vertical stretch<\/a><\/li>\n<li><a href=\"#content-horizontal-alignment-and-vertical-alignment\">Horizontal alignment and vertical alignment<\/a><\/li>\n<li><a href=\"#content-related-information\">Related information<\/a><\/li>\n<\/ul>\n","title":"Grid Layout","raw":null},{"class":"App\\Services\\Documentation\\Data\\RenderedMarkdown","s":"wrbl"}]},{"s":"arr"}]},"memo":{"id":"r3L3HthpO7ZNrs9Zo7OC","name":"__mountParamsContainer","path":"docs\/application\/dotnet\/guides\/user-interface\/nui\/grid-layout","method":"GET","release":"a-a-a"},"checksum":"78436b3bd1454bfae4e49d501b201f9db82b349298a41b683f8bdbbe00d57af8"}')" >

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.