Xamarin 學習筆記 - Page(頁面)

来源:https://www.cnblogs.com/powertoolsteam/archive/2018/08/02/9405390.html
-Advertisement-
Play Games

在之前的章節,我講解瞭如何為Android或者iOS應用程式開發準備環境以及Layout佈局的一些基本概念。在本章中,我將開始講解和介紹Xamarin中頁面(Page)相關的介紹。 ...


 

本文翻譯自CodeProject文章:https://www.codeproject.com/Articles/1226447/Xamarin-Notes-Xamarin-Forms-Pages

轉載請註明出處:葡萄城官網,葡萄城為開發者提供專業的開發工具、解決方案和服務,賦能開發者。

 

引言

在之前的章節,我講解瞭如何為Android或者iOS應用程式開發準備環境以及Layout佈局的一些基本概念。

在本章中,我將開始在Xamarin.Forms中展示我們頁面的結構。

 

Xamarin.Forms基於Page頁面的概念,我們可以使用XAML創建一個應用程式來設計我們的頁面以及後臺的C#代碼。

我們有五種不同的頁面類型:ContentPage、NavigationPage、TabbedPage、CarouselPage以及MasterDetailPage。

在Visual Studio 2017中創建一個新工程,我們選擇File/New/project

之後會彈出一個視窗以供我們選擇Visual C#/Cross-Platform,此處.NET Framework預設將會是最新版本,在我這裡Framework的版本號是4.6.2

接下來一個視窗將顯示出來用做選擇是一個空白工程還是一個Master-Detail模式的工程(它集成了MVVM模式的應用)。

該模板允許你選擇想要的內容,包括你想要基於的平臺,以及具體的代碼共用策略。

在過去,我們看到的界面長這個樣子:

但是在最近更新的版本Visual Studio 2015 15.5.2中,我們將看不到在“代碼共用策略”一欄有PCL(可移植類庫)的選項,它被.NET Standard所取代。

讓我們來理解與之相關的一些概念。

PCL或者說可移植類庫是一組類庫,該類庫以一組具有相同API的平臺為目標的類庫更多詳細信息,請參見此鏈接

.NET Standard:它是一組“標準”API而不是一個平臺。這裡我們將不談論任何平臺,它僅僅是一個標準(當前版本2.0),你的代碼可以在支持它的所有平臺上運行。在2017年11月,.NET Standard進入了Xamarin.Forms的項目模板。

因此將支持的目標從PCL轉向.NET Standard,所帶來的不同僅僅是命名空間的指向被標準化為另外一種不同的方式。

.NET Standard 2.0的新版本致力於通過各種平臺共用代碼,現在Xamarin.Forms通過跨平臺應用程式嚮導引入它,它將預設使用PackageReference。我們來看看新視窗的樣子:

以下是Github上關於.NET Standard的更多信息:

這是另外一篇很不錯的文章,解釋相關話題:

  • https://blog.xamarin.com/building-xamarin-forms-apps-net-standard/
    • UI結構
    • 你所看到的第一頁面就是這一個,那麼什麼是頁面(Page)?它可以包含什麼?
    • 頁面是一個主容器,在我們的示例中,它是一個ContentPage類型的頁面。
    • 在該Page頁面中,我們將添加一個Layout佈局,在本示例中我們用的是StackLayout,在該StackLayout中間,我們將添加一些view視圖。這些視圖是一組控制項,在本示例中,我們用到的是:一個Label標簽,一個Entry(輸入文本)以及一個Button按鈕。
    • Xamarin.Forms提供了許多可用的頁面,以允許提出各種不同的導航體驗。為了精確的定義什麼是一個Xamarin.Forms.Page的示例,官方的文檔給出了一個清晰而簡明的定義。
    • 這個鏈接中提到的那樣:
    • “頁面是占據屏幕大部分或全部並包含單個子的視覺元素。一個頁面代表Windows中的一個視圖控制器,一個Windows中的一個頁面,就像Android上的一個Activity,但不是一個活動的Activity。”
    • 沒有任何特定功能的最簡單頁面,用於開始一個空白頁面的模板。

頁面

1. ContentPage

<!--這是 XAML 部分--><? xml version = "1.0" encoding = "utf-8"?><ContentPage xmlns = "http://xamarin.com/schemas/2014/forms" 
       xmlns: x = "http://schemas.microsoft.com/winfx/2009/xaml" 
       x: Class = "Sample.MyContentPage" 
Title
= "ContentPage Presentation" Padding = "10"> <StackLayout><Label Text = "Welcome to Xamarin.Forms !" /></StackLayout></ContentPage>

ContentPage繼承自TemplatedPage,這是Xamarin.Forms.dll中的基類:

要添加新的ContentPage,我們選擇:New Item/ContentPage.xaml

NavigationPage

它是一種可以容納多個頁面的頁面,但只顯示一個頁面,並提供在它們之間進行導航的功能。

在我們的示例中,我們實例化了一個新的NavigationPage對象,在其構造器中,我們指定了其顯示的第一個頁面。

NavigationPage繼承自Page類。

當我們需要從一個頁面導航到另一個頁面時,我們可以有一組函數可以調用。

如果我們希望在一個按鈕動作事件中跳轉到另一個頁面,我們使用以下代碼:

Navigation.PushAsync(new AboutPage())

或者該方法的非同步版本:

Navigation.PushModalAsync(new AboutPage());

我們可以通過使用以下方法返回到前一個頁面:Navigation.PopAsync();或者Navigation.PopModalAsync();

其它可以使用的方法如下:

Navigation.PopToRootAsync();從導航堆棧中彈出所有堆棧的頁面,除了根Xamarin.Forms.Page頁面。

我們可以在XAML部分使用導航功能,如下所示:

<!--這是XAML部分--> 
<NavigationPage Title="Schedule" Icon="schedule.png"> 
        <x:Arguments> 
            <local:MyPage1 /> 
        </x:Arguments> 
</NavigationPage>

在此示例中,我們創建一個Page,設置其標題為Schedule,並指定一個“schedule.png”的圖標,我們頁面的內容在內部的MyPage1中,那是一個ContentView,而不是一個ContentPage

邀請你在如下鏈接瞭解更多相關信息:

TabbedPage

如同該類型的名稱一樣,它類似於Web或Pivot控制項中的Tab,允許顯示包含多個選項卡的頁面。

我們通過C#代碼創建了一個TabbedPage

<TabbedPage xmlns="http://xamarin.com/schemas/2014/forms"

xmlns:x="http://schemas.microsoft.com/winfx/2009/xaml"

xmlns:mypages="clr-namespace:MyApp.Pages;assembly=MyApp"  

            x:Class="MyApp.Pages.Navigation"> 
<TabbedPage.Children> 
   <mypages:Page1 Title="Page 1"/>
   <mypages:Page2 Title="Page 2"/>
   <mypages:Page3 Title="Page 3"/> 
</TabbedPage.Children>  
</TabbedPage>

CarouselPage

該頁面使用滑動手勢在頁面之間導航。

更多細節:

我們通過C#代碼創建了一個CarouselPage

public partial class App : Application
    {
        public App ()
        {
            InitializeComponent();

            MainPage = new MasterProject.Views.MasterPage();
            CarouselPage carouselPage = new CarouselPage(); 
            carouselPage.Children.Add(new MainPage()); 
            carouselPage.Children.Add(new Page1()); 
            carouselPage.Children.Add(new Page2()); 
            MainPage = carouselPage; 
}

 同樣我們也可以使用以下代碼通過XAML添加一個CarouselPage: 

<?xml version="1.0" encoding="UTF-8"?> 
<CarouselPage 

    xmlns="http://xamarin.com/schemas/2014/forms" 

    xmlns:x="http://schemas.microsoft.com/winfx/2009/xaml" 

    xmlns:local="clr-namespace:NogginXamarinFormSample;assembly=CarouselPage"

     x:Class="CarouselPage.Sample"> 
    <CarouselPage.Children> 
        <local:MyPage1 /> 
        <local:MyPage2 /> 
        <local:MyPage3 /> 
    </CarouselPage.Children> 
</CarouselPage>

在我們的示例中,後面的代碼將是這樣的:

public partial class CarouselPage : CarouselPage {
}

MasterDetailPage

Xamarin.Forms MasterDetailPage是一個管理兩個相關信息頁面的頁面 - 一個顯示項目的主記錄頁面,以及一個顯示主記錄頁面上單個項目詳細信息的詳細信息頁面。本文介紹如何使用MasterDetailPage和在其信息頁面之間導航。”更多詳細信息,請查看此鏈接

  

因此,Master Detail Page容器擁有兩個頁面,一個是主記錄頁面,另一個是詳細信息頁面。主記錄頁面將包含菜單列表,詳細信息頁面將顯示詳細信息並將鏈接返回主記錄頁面,想法很簡單,如果你有任何按鈕或選項在菜單中顯示它但你想在一開始隱藏它們,以保持良好的UI體驗。

我們將使用以下XAML代碼對其進行定義:

<MasterDetailPage.Master >
       <ContentPage Padding="10" BackgroundColor="Gray"
       Title="Master" Icon="hamburger.png">
           <ContentPage.Content>
               <StackLayout Margin="5,30,5,5">
                   <Label Text="Master Page">
                   </Label>
                   <Button x:Name="goToPage1"
                   Text="Go to Page 1" BackgroundColor="Yellow"
                    Clicked="goToPage1_Clicked"></Button>
                   <Button x:Name="goToPage2"
                   Text="Go to Page 2" BackgroundColor="Red"
                    Clicked="goToPage2_Clicked"></Button>
                   <Button x:Name="goToPage3"
                   Text="Go to Page 3" BackgroundColor="Green"
                    Clicked="goToPage3_Clicked"></Button>
              </StackLayout>
          </ContentPage.Content>
       </ContentPage>
   </MasterDetailPage.Master>
<MasterDetailPage.Detail>
       <ContentPage Padding="10">
           <ContentPage.Content>
               <StackLayout Margin="5,30,5,5">
                   <Label Text="Detail  Page">
                   </Label>
               </StackLayout>
           </ContentPage.Content>
       </ContentPage>
   </MasterDetailPage.Detail>

在<MasterDetailPage.Master>標簽中,我們將定義主視圖,在我們的例子中,我們有三個Button按鈕用來鏈接我們的頁面。

在<MasterDetailPage.Detail>標記中,如果我們沒有在類的構造函數中定義它,我們將包含預設內容。

這些標簽對於Master-Detail 頁面是必需的。

我們將創建三個頁面:Page1,Page2並且Page3具有不同的內容和背景顏色。

現在,在C#部分中,我們將定義預設頁面,以便在啟動應用程式時顯示它。

public MasterPage (){ InitializeComponent ();
            Detail = new NavigationPage(new Page1());
            //Summary:
            //Gets or sets a value that indicates whether or not the visual element 
            //that is represented by the Xamarin.Forms.MasterDetailPage.Master property 
            //is presented to the user.
            //    Remarks:
            //Setting this property causes the Xamarin.Forms.MasterDetailPage.IsPresentedChanged 
            //event to be raised.
            //We initialize it to false
            IsPresented = false;
}
        void goToPage1_Clicked(object sender, System.EventArgs e)
        {
            //We will display the first page
            Detail = new NavigationPage(new Page1());
            IsPresented = false;
        }
}

屬性IsPresented表示點擊後應隱藏或不顯示主-從菜單。

源代碼文件

總結:

至此,我們的Xamarin基礎學習筆記就先告一段落,相信通過瞭如上的學習,大家也能夠對Xamarin感興趣,能夠使用和嘗試Xamarin。後面大家如果有其他想瞭解的Xamarin教程也可以PM我們,也歡迎為我們投稿。

Xamarin這個平臺總的來講是一個快速提高開發效率和降低開發成本的一個平臺,你可以不必特別瞭解多個開發平臺的語言和環境特性也能開發出多個移動應用,僅憑這一點,Xamarin也已經在移動開發領域擁有了一批擁躉。

而在這其中,葡萄城也是其中的一員,活字格 的用戶專屬App也是使用Xamarin進行開發的,這個App的主要功能是擴展了活字格應用在移動端的可用性,豐富了用戶使用的場景,例如:可以在應用中使用掃碼命令幫你快速錄入產品信息、使用移動設備定位、手機系統級通知等等功能。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • AngularJS與Onsen UI的結合,Onsen UI應用程式實際上是一個AngularJS 1應用程式。 ...
  • 安卓基於Socket通信(伺服器配合) 1.話不多說進入正題,先創建服務端,在Android Studio中創建Java代碼,如下圖所示: 選擇Java Library 需要改名字的自己隨意 2.創建Client Manager客戶端管理類來管理客戶端的消息,因為省時間就直接從我上篇博客的代碼基礎上 ...
  • 一、說明 在下載或者看別人的代碼我們常會看見,每一個文件的上方有個所屬者的備註。如果要是一個一個備註那就累死了。 二、設置方法 File >>> Setting >>> File and Code Templates >>> File Header在右邊的輸入框中輸入你想要備註的內容即可 ...
  • 1、概述 提高網路性能優化,很重要的一點就是降低延遲和提升響應速度。 通常我們在瀏覽器中發起請求的時候header部分往往是這樣的 keep-alive 就是瀏覽器和服務端之間保持長連接,這個連接是可以復用的。在HTTP1.1中是預設開啟的。 連接的復用為什麼會提高性能呢? 通常我們在發起http請 ...
  • 創建Key SHA1查看器下載地址 高德Jar包和so文件下載地址 許可權和服務 實例 ...
  • 一、問題 ①java代碼沒有顏色區分,統一黑色 ②代碼不會聯想提示,原來打前幾個字母便會聯想到後面的內容 二、解決 打開File,將Power save Mode的勾勾去掉 ...
  • 人臉裁剪類 ...
  • WIFI管理類 連接指定WIFI實例 回調介面 彈框驗證 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...