Xamarin學(xué)習(xí)筆記-Page(頁面)-創(chuàng)新互聯(lián)

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

我們提供的服務(wù)有:成都網(wǎng)站制作、網(wǎng)站建設(shè)、微信公眾號開發(fā)、網(wǎng)站優(yōu)化、網(wǎng)站認(rèn)證、江夏ssl等。為上千企事業(yè)單位解決了網(wǎng)站和推廣的問題。提供周到的售前咨詢和貼心的售后服務(wù),是有科學(xué)管理、有技術(shù)的江夏網(wǎng)站制作公司

轉(zhuǎn)載請注明出處:葡萄城官網(wǎng),葡萄城為開發(fā)者提供專業(yè)的開發(fā)工具、解決方案和服務(wù),賦能開發(fā)者。

引言

在之前的章節(jié),我講解了如何為Android或者iOS應(yīng)用程序開發(fā)準(zhǔn)備環(huán)境以及Layout布局的一些基本概念。

在本章中,我將開始在Xamarin.Forms中展示我們頁面的結(jié)構(gòu)。

Xamarin.Forms基于Page頁面的概念,我們可以使用XAML創(chuàng)建一個應(yīng)用程序來設(shè)計(jì)我們的頁面以及后臺的C#代碼。

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

在Visual Studio 2017中創(chuàng)建一個新工程,我們選擇File/New/project。

Xamarin 學(xué)習(xí)筆記 - Page(頁面)

之后會彈出一個窗口以供我們選擇Visual C#/Cross-Platform,此處.NET Framework默認(rèn)將會是最新版本,在我這里Framework的版本號是4.6.2

Xamarin 學(xué)習(xí)筆記 - Page(頁面)

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

該模板允許你選擇想要的內(nèi)容,包括你想要基于的平臺,以及具體的代碼共享策略。

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

Xamarin 學(xué)習(xí)筆記 - Page(頁面)

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

讓我們來理解與之相關(guān)的一些概念。

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

.NET Standard:它是一組“標(biāo)準(zhǔn)”API而不是一個平臺。這里我們將不談?wù)撊魏纹脚_,它僅僅是一個標(biāo)準(zhǔn)(當(dāng)前版本2.0),你的代碼可以在支持它的所有平臺上運(yùn)行。在2017年11月,.NET Standard進(jìn)入了Xamarin.Forms的項(xiàng)目模板。

因此將支持的目標(biāo)從PCL轉(zhuǎn)向.NET Standard,所帶來的不同僅僅是命名空間的指向被標(biāo)準(zhǔn)化為另外一種不同的方式。

.NET Standard 2.0的新版本致力于通過各種平臺共享代碼,現(xiàn)在Xamarin.Forms通過跨平臺應(yīng)用程序向?qū)б胨?,它將默認(rèn)使用PackageReference。我們來看看新窗口的樣子:

Xamarin 學(xué)習(xí)筆記 - Page(頁面)

以下是Github上關(guān)于.NET Standard的更多信息:

  • https://github.com/dotnet/standard

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

  • https://blog.xamarin.com/building-xamarin-forms-apps-net-standard/

    • UI結(jié)構(gòu)

    • 你所看到的第一頁面就是這一個,那么什么是頁面(Page)?它可以包含什么?

    • 頁面是一個主容器,在我們的示例中,它是一個ContentPage類型的頁面。

    • 在該Page頁面中,我們將添加一個Layout布局,在本示例中我們用的是StackLayout,在該StackLayout中間,我們將添加一些view視圖。這些視圖是一組控件,在本示例中,我們用到的是:一個Label標(biāo)簽,一個Entry(輸入文本)以及一個Button按鈕。

    • Xamarin.Forms提供了許多可用的頁面,以允許提出各種不同的導(dǎo)航體驗(yàn)。為了精確的定義什么是一個Xamarin.Forms.Page的示例,官方的文檔給出了一個清晰而簡明的定義。

    • 和這個鏈接中提到的那樣:

    • “頁面是占據(jù)屏幕大部分或全部并包含單個子的視覺元素。一個頁面代表Windows中的一個視圖控制器,一個Windows中的一個頁面,就像Android上的一個Activity,但不是一個活動的Activity?!?/p>

    • 沒有任何特定功能的最簡單頁面,用于開始一個空白頁面的模板。

頁面
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。

Xamarin 學(xué)習(xí)筆記 - Page(頁面)

NavigationPage

它是一種可以容納多個頁面的頁面,但只顯示一個頁面,并提供在它們之間進(jìn)行導(dǎo)航的功能。

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

NavigationPage繼承自Page類。

Xamarin 學(xué)習(xí)筆記 - Page(頁面)

當(dāng)我們需要從一個頁面導(dǎo)航到另一個頁面時,我們可以有一組函數(shù)可以調(diào)用。

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

1

Navigation.PushAsync(new AboutPage())

或者該方法的異步版本:

1

Navigation.PushModalAsync(new AboutPage());

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

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

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

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

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

在此示例中,我們創(chuàng)建一個Page,設(shè)置其標(biāo)題為Schedule,并指定一個“schedule.png”的圖標(biāo),我們頁面的內(nèi)容在內(nèi)部的MyPage1中,那是一個ContentView,而不是一個ContentPage。

邀請你在如下鏈接了解更多相關(guān)信息:

  • https://developer.xamarin.com/api/type/Xamarin.Forms.NavigationPage/

TabbedPage

如同該類型的名稱一樣,它類似于Web或Pivot控件中的Tab,允許顯示包含多個選項(xiàng)卡的頁面。

我們通過C#代碼創(chuàng)建了一個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

該頁面使用滑動手勢在頁面之間導(dǎo)航。

更多細(xì)節(jié):

  • https://developer.xamarin.com/guides/xamarin-forms/application-fundamentals/navigation/carousel-page/

我們通過C#代碼創(chuàng)建了一個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>

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

1

2

public partial class CarouselPage : CarouselPage {

}

MasterDetailPage

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

Xamarin 學(xué)習(xí)筆記 - Page(頁面)

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

我們將使用以下XAML代碼對其進(jìn)行定義:

<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>標(biāo)簽中,我們將定義主視圖,在我們的例子中,我們有三個Button按鈕用來鏈接我們的頁面。

在<MasterDetailPage.Detail>標(biāo)記中,如果我們沒有在類的構(gòu)造函數(shù)中定義它,我們將包含默認(rèn)內(nèi)容。

這些標(biāo)簽對于Master-Detail 頁面是必需的。

我們將創(chuàng)建三個頁面:Page1,Page2并且Page3具有不同的內(nèi)容和背景顏色。

現(xiàn)在,在C#部分中,我們將定義默認(rèn)頁面,以便在啟動應(yīng)用程序時顯示它。

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表示點(diǎn)擊后應(yīng)隱藏或不顯示主-從菜單。

源代碼文件
  • https://github.com/didourebai/MasterProject

  • https://github.com/didourebai/Xamarin-Sample2

總結(jié):

至此,我們的Xamarin基礎(chǔ)學(xué)習(xí)筆記就先告一段落,相信通過了如上的學(xué)習(xí),大家也能夠?qū)amarin感興趣,能夠使用和嘗試Xamarin。后面大家如果有其他想了解的Xamarin教程也可以PM我們,也歡迎為我們投稿。

Xamarin這個平臺總的來講是一個快速提高開發(fā)效率和降低開發(fā)成本的一個平臺,你可以不必特別了解多個開發(fā)平臺的語言和環(huán)境特性也能開發(fā)出多個移動應(yīng)用,僅憑這一點(diǎn),Xamarin也已經(jīng)在移動開發(fā)領(lǐng)域擁有了一批擁躉。

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

另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價比高”等特點(diǎn)與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。

當(dāng)前文章:Xamarin學(xué)習(xí)筆記-Page(頁面)-創(chuàng)新互聯(lián)
鏈接分享:http://bm7419.com/article48/diceep.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站排名、App設(shè)計(jì)、網(wǎng)站策劃、商城網(wǎng)站、網(wǎng)頁設(shè)計(jì)公司、關(guān)鍵詞優(yōu)化

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

外貿(mào)網(wǎng)站制作