在此部分的 Hands-on Lab 要完成的,是要讓大家在對於 .NET MAUI 專案結構有初步了解後,開始進入撰寫程式的部分,並且看看如何在透過 CollectionView 的列表控制項中顯示出資料。
- 開啟 Part 1 - Displaying Data/MonkeyFinder.sln
此 MonkeyFinder 包含 1 個專案:
- MonkeyFinder 專案 - 基於 .NET MAUI 針對 Android、iOS、macOS 和 Windows 的跨平台應用程式的主要專案。它包括應用程式開發所需要的所有部分(Models、Views、ViewModels 和 Services )。
MonkeyFinder 專案 也包括了在 Hands-on Lab 的過程當中將使用到的空白程式碼檔與 XAML 的頁面文件檔。在進行 Hands-on Lab 的時候,都將會透過專案當中的這些檔案直接修改有關的程式碼。
Hands-on Lab 的專案已經都設定好所需引用的 Nuget 套件,因此在 Hands-on Lab 的過程中無須再安裝其他 Nuget 套件。唯一要做的一件事情就是在第一次使用此 Hands-on Lab 的專案時需要還原 Nuget 套件的引用(需透過網際網路連到 nuget.org 進行下載)。
- 在 MonkeyFinder 的解決方案上的 右鍵選單 選項中選擇 Restore NuGet packages 。
此 Hands-on Lab 當中將下載有關猴子的資料,所以在應用程式當中需要設計一個類別來記錄它的資料描述。
可以透過使用 json2csharp.com 來轉換位於 montemagno.com/monkeys.json 的原始 json 資料,並將此原始的 json 資料貼入左邊的輸入框後,也確定上方介面中轉換的選項有選成 json to C# 之後,即可點選 Convert 來進行轉換。
而所產生出 C# 的類別,除了要確認此類別的名稱有被正確設定成 Monkey
之外,也要確認此類別的命名空間是設定 MonkeyFinder.Model
之後,再進行該類別檔案的下載。
但如同前面所述,此 Hands-on Lab 當中所準備的專案中,都已經有先建立好所需的空白類別檔,所以只需要圈選 json2csharp 所協助轉換成的 C# 類別中 Auto 屬性
這個部分的程式碼後複製,即可直接到專案當中進行下面動作。
- 開啟
Model/Monkey.cs
檔案。 - 在
Monkey.cs
類別當中, 貼上剛剛在 json2csharp 服務當中所複製的程式碼。
完成後如下結果:
public class Monkey
{
public string Name { get; set; }
public string Location { get; set; }
public string Details { get; set; }
public string Image { get; set; }
public int Population { get; set; }
public double Latitude { get; set; }
public double Longitude { get; set; }
}
Additionally, because we will be using System.Text.Json
to deserialize the data, we will want to add a MonkeyContext
that will dynamically generate code for better performance. The following code will enable this and we will use it in the future.
[JsonSerializable(typeof(List<Monkey>))]
internal sealed partial class MonkeyContext : JsonSerializerContext
{
}
接著將可以在 MainPage.xaml
的 CollectionView
當中顯示出經過特殊定義而對應類型的任何資料。所以只要透過設定 ItemTemplate
就能設置基本的控制項(如: Image、Label...等),來建立使用者介面呈現資料。
首先,找到在 MainPage.xaml
檔案一開始的 ContentPage 標記,並在該標記中多增加一個新的命名空間引用的撰寫:
xmlns:model="clr-namespace:MonkeyFinder.Model"
以便在後續的 XAML 撰寫可以使用到前一段所做好的 Monkey 類別,並且在也可以透過 Binding 來完成資料繫結。
接著,將下面的 XAML 內容加到 MainPage.xaml 的 ContentPage
成對標記當中:
<CollectionView>
<CollectionView.ItemsSource>
<x:Array Type="{x:Type model:Monkey}">
<model:Monkey
Name="Baboon"
Image="https://raw.githubusercontent.com/jamesmontemagno/app-monkeys/master/baboon.jpg"
Location="Africa and Asia" />
<model:Monkey
Name="Capuchin Monkey"
Image="https://raw.githubusercontent.com/jamesmontemagno/app-monkeys/master/capuchin.jpg"
Location="Central and South America" />
<model:Monkey
Name="Red-shanked douc"
Image="https://raw.githubusercontent.com/jamesmontemagno/app-monkeys/master/douc.jpg"
Location="Vietnam" />
</x:Array>
</CollectionView.ItemsSource>
<CollectionView.ItemTemplate>
<DataTemplate x:DataType="model:Monkey">
<HorizontalStackLayout Padding="10">
<Image
Aspect="AspectFill"
HeightRequest="100"
Source="{Binding Image}"
WidthRequest="100" />
<Label VerticalOptions="Center" TextColor="Gray">
<Label.Text>
<MultiBinding StringFormat="{}{0} | {1}">
<Binding Path="Name" />
<Binding Path="Location" />
</MultiBinding>
</Label.Text>
</Label>
</HorizontalStackLayout>
</DataTemplate>
</CollectionView.ItemTemplate>
</CollectionView>
如果想將兩個串文字垂直呈現,可以將兩個 Label
控制項包在由 VerticalStackLayout
組成的成對標記當中,並在兩個 Label
控制項當中,來透過設定字體大小 (FontSize) 的屬性來讓文字在顯示有差異化的效果:
<HorizontalStackLayout Padding="10">
<Image
Aspect="AspectFill"
HeightRequest="100"
Source="{Binding Image}"
WidthRequest="100" />
<VerticalStackLayout VerticalOptions="Center">
<Label Text="{Binding Name}" FontSize="24" TextColor="Gray"/>
<Label Text="{Binding Location}" FontSize="18" TextColor="Gray"/>
</VerticalStackLayout>
</HorizontalStackLayout>
確認機器的環境都可以在不同平台與目標當中進行測試:
- 在 Visual Studio 中,透過選擇偵錯選單當中的下拉選單來變更
架構
(Framework),將 Android 或 Windows 應用程式設置為啟動專案
- 在 Visual Studio 中點選
偵錯
按鈕或工具 -> 開始偵錯- 如果有遇到任何問题,請參考執行時的設定指引
執行的應用程式後呈現出三隻猴子的資料在列表當中的結果:
接著,繼續到 Hands-on Lab Part 2 : MVVM 和資料繫結 中,學習如何使用資料繫結與 MVVM 框架。