C#/Xamarin Maui
[.NET MAUI] UniformItemsLayout 사용하기
kjun.kr
2022. 9. 16. 23:43
728x90
UniformItemsLayout 은 데이터를 화면 사이즈에 따라서 정렬시켜줍니다.
10개의 데이터가 있다면 화면의 사이즈나 데이터표시 사이즈 따라
5개씩 두줄로 표현이 되고
data:image/s3,"s3://crabby-images/f48f6/f48f6b19e6ce673623a64663fa558f97940407f7" alt=""
4개씩 세줄로 표현이 됩니다.
data:image/s3,"s3://crabby-images/1da5a/1da5a80eb88c93c796a8ec9156d73108ed0df4f5" alt=""
MainPage.xaml
<?xml version="1.0" encoding="utf-8" ?>
<ContentPage
x:Class="Maui.ToolKitMaui.MainPage"
xmlns="http://schemas.microsoft.com/dotnet/2021/maui"
xmlns:x="http://schemas.microsoft.com/winfx/2009/xaml"
xmlns:toolkit="http://schemas.microsoft.com/dotnet/2022/maui/toolkit">
<ContentPage.Resources>
<x:Double x:Key="ImageSize">35</x:Double>
</ContentPage.Resources>
<ScrollView>
<VerticalStackLayout
Padding="30,0"
Spacing="25"
VerticalOptions="Center">
<toolkit:UniformItemsLayout
Padding="10"
HorizontalOptions="Center"
VerticalOptions="Center">
<Image
Margin="10"
BackgroundColor="Blue"
HeightRequest="{StaticResource ImageSize}"
Source="keilogo.png"
WidthRequest="{StaticResource ImageSize}" />
<Image
Margin="10"
BackgroundColor="Yellow"
HeightRequest="{StaticResource ImageSize}"
Source="keilogo.png"
WidthRequest="{StaticResource ImageSize}" />
<Image
Margin="10"
BackgroundColor="Red"
HeightRequest="{StaticResource ImageSize}"
Source="keilogo.png"
WidthRequest="{StaticResource ImageSize}" />
<Image
Margin="10"
BackgroundColor="Black"
HeightRequest="{StaticResource ImageSize}"
Source="keilogo.png"
WidthRequest="{StaticResource ImageSize}" />
<Image
Margin="10"
BackgroundColor="Green"
HeightRequest="{StaticResource ImageSize}"
Source="keilogo.png"
WidthRequest="{StaticResource ImageSize}" />
<Image
Margin="10"
BackgroundColor="Purple"
HeightRequest="{StaticResource ImageSize}"
Source="keilogo.png"
WidthRequest="{StaticResource ImageSize}" />
<Image
Margin="10"
BackgroundColor="Gray"
HeightRequest="{StaticResource ImageSize}"
Source="keilogo.png"
WidthRequest="{StaticResource ImageSize}" />
<Image
Margin="10"
BackgroundColor="SkyBlue"
HeightRequest="{StaticResource ImageSize}"
Source="keilogo.png"
WidthRequest="{StaticResource ImageSize}" />
<Image
Margin="10"
BackgroundColor="BurlyWood"
HeightRequest="{StaticResource ImageSize}"
Source="keilogo.png"
WidthRequest="{StaticResource ImageSize}" />
<Image
Margin="10"
BackgroundColor="Gold"
HeightRequest="{StaticResource ImageSize}"
Source="keilogo.png"
WidthRequest="{StaticResource ImageSize}" />
</toolkit:UniformItemsLayout>
</VerticalStackLayout>
</ScrollView>
</ContentPage>
MaxColumns 으로 컬럼의 갯수를 제한 할수도 있습니다. (MaxColumns=2)
data:image/s3,"s3://crabby-images/62575/62575481ca829643f12bcce357a4efc26ce32ac5" alt=""
실행 결과 (이미지 사이즈를 변경할때 마다 재정렬되어 표시됩니다.)
data:image/s3,"s3://crabby-images/ae70c/ae70c5db6a85a8d82910973c982e7f56be7fd691" alt=""
* Windows 는 화면 사이즈 조정시 에러가 발생됩니다;
소스
https://github.com/kei-soft/KJunBlog/tree/master/Maui.ToolKitMaui
728x90