Xamarin入門的第一個範例

只會寫 Windows Form或是 ASP.NET Web Form,有機會快速轉移、快速開發手機程式(Mobile App)嗎?

Xamarin「免費」與 Visual Studio 2015整合,給您一個新選擇

 

對於寫過 Windows Form or ASP.NET Web Form的朋友、或是使用 C#的朋友

使用 Xamarin來撰寫手機 Mobile App應該覺得似曾相似,甚至熟悉度很高

 

Xamarin號稱可以  :   (詳見:https://www.thinkpower.info/xamarin/ )

  • 以C# 開發,編譯成iOS與Android原生執行碼,非HTML5解決方案
  • 任何Objective-C(iOS)與Java(Android)可以做的,Xamarin都可以做到
  • 執行效能100%與原平台程式(Objective-C,Java)所開發的一樣
  • 結合Microsoft Visual Studio開發工具,讓開發更方便、快速


圖片來源 https://blogs.msdn.microsoft.com/msdntaiwan/2016/02/29/4/

 

 

Xamarin售價不便宜,幸好2016年二月微軟買下,並免費整合在 Visual Studio裡面

      新聞 http://www.ithome.com.tw/news/105072

      微軟2月才剛買下跨平台開發工具Xamarin,宣佈將整合到Visual Studio所有版本,包括免費的社群版(Community Edition)、專業版及企業版。

      Xamarin Studio for OS X除了整合Visual Studio 各版本及MSDN訂閱服務內,也將包含在社群版內免費提供。

 



 

==== 以下是採用 VS 2015 Update 3的操作畫面 =================

 

 

專案建立好之後,先測試一下環境能否運作?不要寫任何程式,我們直接建置專案(如下圖)並且執行這個空專案。

提醒您,

1.  建置時間很長,因為要啟動手機模擬器(類似VM或是啟動另一套OS),所以請您耐心等候。就算您的電腦CPU很強,也需要一段時間。

2.  如果您使用  Win 10家用版,或是沒有 Hyper-V,就會採用以下的手機模擬器 (AVD_Galaxy_ToolsForApacheCordova ...... 如下圖)

3.  如果您安裝的OS是專業版(含更高階版本)就可以安裝 Hyper-V,使用其他 手機模擬器。

 

第一個看見的檔名是 MainActivity.cs 

您可以看見 OnCreate事件,可以把他想成 ASP.NET Web Form的 Page_Load事件(請放心,這裡不會有 PostBack  :-p  )

 

 MainActivity.cs個檔案的內容其實跟其他檔案有密切關係。

如下圖,「主畫面」可以對應 \Resources\layout\main.axml檔案。

 

簡單的說,畫面上的控制項弄好以後,可以寫程式,是不是跟  Windows Form or Web Form很類似呢?

 

如果您自己新增一個 Button按鈕,

以下圖的 ID為例,他會在另一個檔案 (Resource.Designer.cs)  自動產生這個ID的編號(獨一無二的編號)

Resource.Designer.cs 千萬不要自己動手去改,請讓程式自動產生這些編號......千萬不要自己動手去改

 

撰寫主畫面(Main.axml)時,也可以接換到設計模式

      從左邊的「工具箱」把控制項拉到畫面來用......是不是跟  Windows Form or Web Form很類似呢?

 

接下來就要撰寫「後置程式碼」了

Sorry......不好意思,ASP.NET Web Form寫久了,有些名詞用習慣,暫時改不過來

 

以前寫ASP.NET Web Form,按下 Button按鈕以後,程式要寫在 Button_Click事件內

現在改成 Xamarin其實大同小異。

 

檔案MainActivity.cs

 protected override void OnCreate(Bundle bundle)
 {
      base.OnCreate(bundle);

      // Set our view from the "main" layout resource
      SetContentView(Resource.Layout.Main);

      // Get our button from the layout resource, and attach an event to it  畫面上的第一個按鈕
      Button button = FindViewById<Button>(Resource.Id.MyButton);
      button.Click += delegate { button.Text = string.Format("您按下 {0} 次!", count++); };

      // 畫面上的第二個按鈕。其實是模仿上一個按鈕改寫的

      Button button2 = FindViewById<Button>(Resource.Id.MyButton2);

      // 模仿上面第一個按鈕的範例,自己改寫......按下按鈕,就會觸發這個動作(事件)
      button2.Click += delegate { button2.Text = string.Format("今天是 {0}", DateTime.Now.ToLongDateString()); };

  }
 

回憶一下,您在 ASP.NET Web Form有沒有用過 .FindControl()方法?用來抓取畫面上的控制項?或是大型控制項「樣版裡面」的子控制項?

 

回憶一下,按下 ASP.NET Web Form -- Button按鈕的 Click事件,也能寫成這樣

跟上面程式比對一下,是否很相似?

  • VB語法  -- AddHandler Button1.Click, AddressOf myEventHandler
  • C#語法  -- Button1.Click += new System.EventHandler(this.myEventHandler);

(詳見以前文章 https://dotblogs.com.tw/mis2000lab/2011/11/05/eventhandler_addhandler_addressof_method 

(詳見Youtube教學影片 https://youtu.be/GtI8P0Onods 

 

 

下圖是執行結果:

 

補充資料:

  • 台灣微軟 Xamarin研討會    http://www.microsoft.com/taiwan/vstudio/Xamarin/ 
  • (中文) 投影片 & 影片下載    https://onedrive.live.com/?id=FB49C7CED61BD893%212016&cid=FB49C7CED61BD893

 

  • 台灣微軟範例(中文)    https://msdn.microsoft.com/zh-tw/library/dn879698.aspx
  • .NET 標準函式庫支援 Xamarin 囉!    https://blogs.msdn.microsoft.com/msdntaiwan/2016/09/02/net-standard-library-support-for-xamarin/

 

 

 

我將思想傳授他人, 他人之所得,亦無損於我之所有;

猶如一人以我的燭火點燭,光亮與他同在,我卻不因此身處黑暗。----Thomas Jefferson

線上課程教學,遠距教學 (Web Form 約 51hr)  https://dotblogs.com.tw/mis2000lab/2016/02/01/aspnet_online_learning_distance_education_VS2015

線上課程教學,遠距教學 (ASP.NET MVC 約 135hr)  https://dotblogs.com.tw/mis2000lab/2018/08/14/ASPnet_MVC_Online_Learning_MIS2000Lab

 

寫信給我,不要私訊 --  mis2000lab (at) yahoo.com.tw  或  school (at) mis2000lab.net

 (1) 第一天 ASP.NET MVC5 完整影片(5.5小時 / .NET 4.x版)免費試聽。影片 https://youtu.be/9spaHik87-A 

 (2) 第一天 ASP.NET Core MVC 完整影片(3小時 / .NET Core 6.0~8.0)免費試聽。影片 https://youtu.be/TSmwpT-Bx4I 

[學員感言] mis2000lab課程評價 - ASP.NET MVC , WebForm  。 https://mis2000lab.medium.com/%E5%AD%B8%E5%93%A1%E6%84%9F%E8%A8%80-mis2000lab%E8%AA%B2%E7%A8%8B%E8%A9%95%E5%83%B9-asp-net-mvc-webform-77903ce9680b  


ASP.NET遠距教學、線上課程(Web Form + MVC)。 第一天課程, "完整" 試聽。 

.........   facebook社團   https://www.facebook.com/mis2000lab   ......................

.........  YouTube (ASP.NET) 線上教學影片  https://www.youtube.com/channel/UC6IPPf6tvsNG8zX3u1LddvA/

 

Blog文章 "附的範例" 無法下載,請看 https://dotblogs.com.tw/mis2000lab/2016/03/14/2008_2015_mis2000lab_sample_download

請看我們的「售後服務」範圍(嚴格認定)。

...................................................................................................................................................... 

ASP.NET MVC  => .NET Core MVC 線上教學  ...... 第一天課程 完整內容 "免費"讓您評估 / 試聽

[遠距教學、教學影片] ASP.NET (Web Form) 課程 上線了!MIS2000Lab.主講   事先錄好的影片,並非上課側錄!   觀看時,有如「一對一」面對面講課