XAML in Xamarin.Forms 基礎篇 電子書

XAML in Xamarin.Forms 基礎篇 電子書
XAML in Xamarin.Forms 基礎篇 電子書

Xamarin.Forms 快速入門 電子書

Xamarin.Forms 快速入門 電子書
Xamarin.Forms 快速入門 電子書

2016/07/16

Xamarin.Forms Azure Mobile後端資料庫存取

Azure Mobile後端資料庫存取

當進行跨平台裝置專案開發過程中,大多會需要使用到後端資料庫存取服務,在這個範例中,將會為您說明使用 Microsoft Azure 所提供的 Azure Mobile App 服務。透過這個服務,可以讓開發者輕鬆的存取遠端資料庫或者企業內部的資料、進行AD或者社群身分驗證、線上與離線資料存取、行動裝置的訊息推播等等。
在這裡,僅僅針對如何透過 Azure Mobile Client 這個套件,來存取遠端的資料庫內的資料。

建立標籤式的樣板式頁面方案

  1. 首先,開啟您的 Visual Studio 2015
  2. 接著透過 Visual Studio 2015 功能表,選擇這些項目 檔案 > 新增 > 專案 準備新增一個專案。
  3. 接著,Visual Studio 2015 會顯示 新增專案 對話窗,請在這個對話窗上,進行選擇 Visual C# >Cross-Platform > Blank Xaml App (Xamarin.Forms Portable)
  4. 接著,在最下方的 名稱 文字輸入盒處,輸入 XFAzureMA 這個名稱,最後使用滑鼠右擊右下方的 確定 按鈕。
  5. 當專案建立到一半,若您的開發環境還沒有建置與設定完成 Mac 電腦與 Xamarin Studio for Mac 系統,此時會看到 Xamarin Mac Agent Instructions 對話窗出現,這個對話窗是要提醒您進行與 Mac 電腦連線設定,這是因為,您無法在 Windows 作業系統進行 iOS 相關應用程式的建立與設計工作,而是需要透過 Mac 電腦安裝的 XCode 來協助您完成這些 iOS 應用程式的建立工作。不過,這不影響您繼續開發 Xamarin.Forms 的應用程式,只不過此時,您無法編譯與執行 iOS 的應用程式。
  6. 接著會看到 新的通用Windows專案 對話視窗,此時,您只需要按下 確定 按鈕即可,此時,專案精靈會繼續完成相關平台的專案建立工作。
  7. 最後,整個新的 Xamarin.Forms 專案就建立完成了。

安裝所需 NuGet 套件

請在 方案 'XFAzureMa' 節點上,滑鼠右擊,接著點選 管理方案的 NuGet 套件 選項,接著點選 瀏覽 標籤頁次,在搜尋文字輸入盒中,輸入 Microsoft.Azure.Mobile.Client 這個套件,當找到這個套件之後,請將這個套件安裝到這個方案內的所有專案裡面。

原生專案修正

為了要能夠讓 Microsoft.Azure.Mobile.Client 套件可以正常運作,此時,需要修改 XFAzureMA.Droid,XFAzureMA.iOS 這兩專案內容。也就是要在這兩個專案內,分別加入底下程式碼。
Microsoft.WindowsAzure.MobileServices.CurrentPlatform.Init();

XFAzureMA.Droid 專案

  • 在 Android 專案內找到 MainActivity.cs 並且打開這個檔案
  • 將底下程式碼複製到這個檔案內
using System;

using Android.App;
using Android.Content.PM;
using Android.Runtime;
using Android.Views;
using Android.Widget;
using Android.OS;

namespace XFAzureMA.Droid
{
    [Activity(Label = "XFAzureMA", Icon = "@drawable/icon", Theme = "@style/MainTheme", MainLauncher = true, ConfigurationChanges = ConfigChanges.ScreenSize | ConfigChanges.Orientation)]
    public class MainActivity : global::Xamarin.Forms.Platform.Android.FormsAppCompatActivity
    {
        protected override void OnCreate(Bundle bundle)
        {
            TabLayoutResource = Resource.Layout.Tabbar;
            ToolbarResource = Resource.Layout.Toolbar;

            base.OnCreate(bundle);

            global::Xamarin.Forms.Forms.Init(this, bundle);
            Microsoft.WindowsAzure.MobileServices.CurrentPlatform.Init();

            LoadApplication(new App());
        }
    }
}

XFAzureMA.iOS 專案

  • 在 iOS 專案內找到 AppDelegate.cs 並且打開這個檔案
  • 將底下程式碼複製到這個檔案內
using System;
using System.Collections.Generic;
using System.Linq;

using Foundation;
using UIKit;

namespace XFAzureMA.iOS
{
    // The UIApplicationDelegate for the application. This class is responsible for launching the 
    // User Interface of the application, as well as listening (and optionally responding) to 
    // application events from iOS.
    [Register("AppDelegate")]
    public partial class AppDelegate : global::Xamarin.Forms.Platform.iOS.FormsApplicationDelegate
    {
        //
        // This method is invoked when the application has loaded and is ready to run. In this 
        // method you should instantiate the window, load the UI into it and then make the window
        // visible.
        //
        // You have 17 seconds to return from this method, or iOS will terminate your application.
        //
        public override bool FinishedLaunching(UIApplication app, NSDictionary options)
        {
            global::Xamarin.Forms.Forms.Init();
            Microsoft.WindowsAzure.MobileServices.CurrentPlatform.Init();

            LoadApplication(new App());

            return base.FinishedLaunching(app, options);
        }
    }
}

MainPage

  • 當上述準備工作已經就緒,接下來就可以開始在核心PCL專案內寫相關商業邏輯程式碼了。
  • 打開核心PCL 的 MainPage.xaml 檔案,將底下的 XAML 宣告定義複製到這個檔案內。
  • 這個頁面宣告內容相當簡單,使用版面配置 StackLayout 將其包含的控制項,以垂直的方式排列
  • 後端的資料,將會透過 ListView 控制項來顯示,當需要重新整理資料的時候,可以在 ListView 控制項的最上方,使用手勢由上往下滑動,即可抓取後端資料庫內最新的資料,顯示在畫面上了。
  • 共有兩個按鈕,一個是會產生新資料,另外一個是將 ListView 點選的項目,予以刪除。

MainPage.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"
             xmlns:local="clr-namespace:XFAzureMA"
             x:Class="XFAzureMA.MainPage">

  <StackLayout
    Orientation="Vertical">
    <ListView x:Name="todoList"
              Header="代辦事項"
              IsPullToRefreshEnabled="true" 
              >
      <ListView.ItemTemplate>
        <DataTemplate>
          <ViewCell>
            <StackLayout HorizontalOptions="StartAndExpand" Orientation="Horizontal" Padding="15,5,0,0">
              <StackLayout Padding="5,0,0,0" VerticalOptions="StartAndExpand" Orientation="Vertical">
                <Label Text="{Binding Name}"  />
              </StackLayout>
            </StackLayout>
          </ViewCell>
        </DataTemplate>
      </ListView.ItemTemplate>
    </ListView>

    <Grid>
      <Grid.ColumnDefinitions>
        <ColumnDefinition Width="*" />
        <ColumnDefinition Width="*" />
      </Grid.ColumnDefinitions>
      <Button x:Name="buttonAdd" Text="新增" Grid.Column="0"/>
      <Button x:Name="buttonDel" Text="刪除" Grid.Column="1"/>           
    </Grid>
  </StackLayout>
</ContentPage>
  • 請將下列 C# 程式碼複製到 MainPage.xaml.cs內。
  • 在 MainPage 類別內,定義了兩個屬性 MobileServiceClientIMobileServiceTable<DoggyTodo>,前者將會提供 Azure Mobile App 的服務,後者,則是提供 DoggyTodo 這個資料表的存取動作。
  • 在建構式內,首先產生 MobileServiceClient 物件,其中,需要 Azure Mobile App 的網址作為產生該物件的參數,當這個物件建立之後,就可以操控這個 Azure Mobile App 所提供的服務。接著,透過MobileServiceClient.GetTable<DoggyTodo>() 取得這個資料表,也就是這個應用程式要存取的代辦事項清單項目紀錄要存放的地方。接著訂閱各控制項需要用到的事件,並且進行相對應的處理。
  • 要讀取後端資料,可以透過 await IMobileServiceTable<DoggyTodo>.ToListAsync(); 取得,也可以透過 LINQ 進行過濾與排序。
  • 要新增後端資料,可以透過 wait IMobileServiceTable<DoggyTodo>.InsertAsync(new DoggyTodo{Name = DateTime.Now.ToString()}); 。
  • 要刪除後端資料,可以透過 wait IMobileServiceTable<DoggyTodo>.DeleteAsync(fooItem); 。

MainPage.xaml.cs

using Microsoft.WindowsAzure.MobileServices;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using Xamarin.Forms;

namespace XFAzureMA
{
    public partial class MainPage : ContentPage
    {
        MobileServiceClient client;
        IMobileServiceTable<DoggyTodo> todoTable;

        public MainPage()
        {
            InitializeComponent();

            this.client = new MobileServiceClient("http://doggylab.azurewebsites.net");
            this.todoTable = client.GetTable<DoggyTodo>();

            todoList.Refreshing += TodoList_Refreshing;
            buttonAdd.Clicked += async (s, e) =>
            {
               await todoTable.InsertAsync(new DoggyTodo
                {
                    Name = DateTime.Now.ToString()
                });
                await Refresh();
            };
            buttonDel.Clicked += async (s, e) =>
            {
                if(todoList.SelectedItem != null)
                {
                    var fooItem = (DoggyTodo)todoList.SelectedItem;
                    await todoTable.DeleteAsync(fooItem);
                    await Refresh();
                }
            };
        }

        private async void TodoList_Refreshing(object sender, EventArgs e)
        {
            await Refresh();
        }

        public async Task Refresh()
        {

            List<DoggyTodo> items = await todoTable.ToListAsync();

            todoList.ItemsSource = items;

            todoList.EndRefresh();
        }
    }
}

DoggyTodo 資料模型定義

  • 請在 XFAzureMA 核心PCL 專案節點使用滑鼠右擊該節點,選擇 加入 > 類別,當 加入新項目 - XFAzureMA 對話窗出現後,點選 Visual C# > 類別,最後在下方名稱欄位的文字輸入盒內,輸入DoggyTodo
  • 請將底下 C# 程式碼複製到這個檔案內。

DoggyTodo.cs

using Microsoft.WindowsAzure.MobileServices;
using Newtonsoft.Json;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

namespace XFAzureMA
{
    public class DoggyTodo
    {
        string id;
        string name;
        bool done;

        [JsonProperty(PropertyName = "id")]
        public string Id
        {
            get { return id; }
            set { id = value; }
        }

        [JsonProperty(PropertyName = "text")]
        public string Name
        {
            get { return name; }
            set { name = value; }
        }

        [JsonProperty(PropertyName = "complete")]
        public bool Done
        {
            get { return done; }
            set { done = value; }
        }

        [Version]
        public string Version { get; set; }
    }
}

定義 Azure Mobile App 上的 簡易表

若您尚未使用過 Azure Mobile App,您可以參考 建立與設定 Azure Mobile App 文章;一旦,您完成了這篇文章上的操作,接著,就可以透過 Azure Mobile App 產生一個新的簡易表。請點選 簡易表 > Add ,接著在最右方的刀鋒視窗內 Name 欄位下,輸入 DoggyTodo,最後按下 確定 按鈕。請參考下圖。
新增簡易表DoggyTodo

實際執行畫面

Android 執行結果

請在方案總管內,滑鼠右擊 XFAzureMA.Droid 專案,選擇 設定為起始專案,接著按下 F5 開始執行。
Android執行結果1
Android執行結果2
底下是在 Azure Mobile App 上查詢 DoggyTodo 資料表的內容。
Android執行結果3

佈署注意事項

iOS 執行結果

請在方案總管內,滑鼠右擊 XFAzureMA.iOS 專案,選擇 設定為起始專案,接著按下 F5 開始執行。
iOS執行結果1
iOS執行結果2
底下是在 Azure Mobile App 上查詢 DoggyTodo 資料表的內容。
iOS執行結果2

2016/07/15

Xamarin.Forms Web 服務存取 RESTful Web API & WCF

Web 服務存取

在這個範例專案中,將會實作 RESTful Web API 與 WCF 這兩種 Web 服務的呼叫方式。
在這裡,網路上提供了兩個Web 服務的網址:
這兩個 Web 服務都會把傳入的兩個整數相加,並且把相加的結果,回傳回來。

建立標籤式的樣板式頁面方案

  1. 首先,開啟您的 Visual Studio 2015
  2. 接著透過 Visual Studio 2015 功能表,選擇這些項目 檔案 > 新增 > 專案 準備新增一個專案。
  3. 接著,Visual Studio 2015 會顯示 新增專案 對話窗,請在這個對話窗上,進行選擇 Visual C# >Cross-Platform > Blank Xaml App (Xamarin.Forms Portable)
  4. 接著,在最下方的 名稱 文字輸入盒處,輸入 XFWebSrv 這個名稱,最後使用滑鼠右擊右下方的 確定按鈕。
  5. 當專案建立到一半,若您的開發環境還沒有建置與設定完成 Mac 電腦與 Xamarin Studio for Mac 系統,此時會看到 Xamarin Mac Agent Instructions 對話窗出現,這個對話窗是要提醒您進行與 Mac 電腦連線設定,這是因為,您無法在 Windows 作業系統進行 iOS 相關應用程式的建立與設計工作,而是需要透過 Mac 電腦安裝的 XCode 來協助您完成這些 iOS 應用程式的建立工作。不過,這不影響您繼續開發 Xamarin.Forms 的應用程式,只不過此時,您無法編譯與執行 iOS 的應用程式。
  6. 接著會看到 新的通用Windows專案 對話視窗,此時,您只需要按下 確定 按鈕即可,此時,專案精靈會繼續完成相關平台的專案建立工作。
  7. 最後,整個新的 Xamarin.Forms 專案就建立完成了。

WCF 的事前準備

了解 PCL profile

在 Xamarin.Forms 內,想要呼叫 WCF Web 服務,需要先建立出 WCF 代理 (Proxy),之後就可以透過 WCF 代理還呼叫 WCF 服務提供的各項方法。因此,加入 WCF 的方法是在專案內的 參考 節點上,使用滑鼠右擊,透過 加入服務參考 選項,把 WCF 位址輸入到 加入服務參考 對話窗內。
可是,當您在 核心PCL 專案內的 參考 節點上,使用滑鼠右擊,卻沒有看到 加入服務參考 選項可以選擇。
核心PCL的參考功能表
這是因為 核心PCL 是 可移植類別庫 (Portable Class Library),也就是說,為了要讓這個類別庫可以支援更多的平台專案可以使用,因此,在 PCL 專案內,把許多無法跨平台的 API 或者功能,將無法使用。而在 PCL 內,有個欄位 TargetFrameworkProfile 定義了 PCL 的設定檔(Profile)資訊(您可以開啟 XFWebSrv.csproj 檔案茶看到),如下圖所示。
現在(Visual Studio 2015 with Update 2),若是透過 Visual Studio 專案樣版建立的 Xamarin.Forms 跨平台專案,其產生的核心PCL專案,使用的是 Profile111 設定檔;而這個 Profile111 PCL 設定檔內,是不提供 WCF Proxy 支援的。
XFWebSrv.csproj內的PCL版本Profile111
更多關於 PCL 不同設定檔案資訊,可以參考底下連結

解決方案1 利用原生專案

  • 雖然 核心PCL 專案內無法產生與建立 WCF 代理,不過,原生 Android 與 iOS 專案內,卻可以支援
  • 因此,您可以在原生專案內的 參考 節點上,使用滑鼠右擊,就會看到 加入 Web 參考 這個選項,透過這項功能,就可以產生 WCF 代理。
    XFWebSrv.Droid的參考功能表

解決方案2 建立新 類別庫(可攜式)

  • 在方案 XFWebSrv 節點上滑鼠右擊,選擇 加入 > 新的專案 > Visual C# > 類別庫(可攜式) ,接著在下方名稱欄位旁的文字輸入盒,輸入 XFWCFPCL
    千萬注意,不可以選擇 類別庫 (可移植到 iOS、Android、Windows) 這個類別庫
  • 當出現 加入可攜式類別庫 對話窗,點選 確定 按鈕
    加入可攜式類別庫
  • 在 XFWCFPCL 專案內,滑鼠右擊 參考 節點,選擇 加入服務參考 選項
    XFWCFPCL加入服務參考
  • 當 加入服務參考 對話窗出現的時候,在位置欄位,輸入http://wcfservice120160626121524.azurewebsites.net/Service1.svc,接著點選 移至 按鈕,確認所要定義的命名空間,最後按下 確定 按鈕,產生 WCF Proxy Class
    加入服務參考1
  • 滑鼠右擊 XFWCFPCL 專案節點,選擇 加入 > 類別 選項,在名稱欄位文字輸入盒中填入WCFServiceBase,接著按下 確定 按鈕
  • 將底下程式碼複製到這個檔案內。
  • WCFServiceBase 這個類別將會透過相依性服務注入的方式,讓核心PCL專案可以使用這個 WCF 功能。
using System;
using System.Collections.Generic;
using System.Linq;
using System.ServiceModel;
using System.Text;
using System.Threading.Tasks;

namespace XFWCFPCL
{
    public class WCFServiceBase
    {
        public Task<int> Sum(int v1, int v2)
        {
            TaskCompletionSource<int> tcs = new TaskCompletionSource<int>();

            var binding = new BasicHttpBinding()
            {
                Name = "basicHttpBinding",
                MaxReceivedMessageSize = 67108864,
            };

            var timeout = new TimeSpan(0, 1, 0);
            binding.SendTimeout = timeout;
            binding.OpenTimeout = timeout;
            binding.ReceiveTimeout = timeout;

            var client = new ServiceReference1.Service1Client(binding, new EndpointAddress("http://wcfservice120160626121524.azurewebsites.net/Service1.svc"));
            client.GetSumDataCompleted += (s,e) =>
            {
            };
            client.GetSumDataAsync(v1, v2);
            return tcs.Task;
        }
    }
}

MainPage

  • 當上述準備工作已經就緒,接下來就可以開始在核心PCL專案內寫相關商業邏輯程式碼了。
  • 打開核心PCL 的 MainPage.xaml 檔案,將底下的 XAML 宣告定義複製到這個檔案內。
  • 這個頁面宣告內容相當簡單,使用版面配置 StackLayout 將其包含的控制項,以垂直的方式排列
  • 共有兩個按鈕,一個是呼叫 RESTful Web API,另外一個是呼叫 WCF,他們皆會先從 Entry 控制項中取得使用者所輸入的整數值,經會 Web 服務計算過後,將計算後的值,顯示在 Label 控制項內
  • Entry 控制項內,使用了 Keyboard 屬性,定義使用者只能夠輸入數字。

MainPage.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"
             xmlns:local="clr-namespace:XFWebSrv"
             x:Class="XFWebSrv.MainPage">

  <ContentPage.Padding>30</ContentPage.Padding>

  <StackLayout
    Orientation="Vertical"
    >

    <Entry x:Name="entryValue1" Keyboard="Numeric" Text="168" />
    <Entry x:Name="entryValue2" Keyboard="Numeric" Text="99" />

    <Label x:Name="labelRESTful" />
    <Button x:Name="buttonRESTful" Text="呼叫 RESTful" Clicked="OnRESTfulClicked" />

    <Label x:Name="labelWCF" />
    <Button x:Name="buttonWCF" Text="呼叫 WCF" Clicked="OnWCFClicked" />

  </StackLayout>

</ContentPage>
  • 請將下列 C# 程式碼複製到 MainPage.xaml.cs內。
  • 在建構式內,使用了 MessagingCenter 訂閱了一個訊息事件,也就是當使用者有選擇某個日期之後,其相對應的 callback 就會執行,在這裡,將會取出透過訊息中心所傳遞過來的日期參數,並且將其顯示在指定 Label 上。
  • 在 掃描QRCode 按鈕事件內, 使用了相依性注入服務 DependencyService 取得當時行動平台實作的 QRCode 掃描物件,並且呼叫 ScanAsync 這個方法,取得QRCode掃描結果,並且顯示到指定的Label
  • 在 選擇日期 按鈕事件內,則是透過 Navigation.PushModalAsync 方法,開啟一個對話窗頁面,該頁面為 CalendarPage

MainPage.xaml.cs

  • OnRESTfulClicked
    這個按鈕事件,展示了如何呼叫 RESTful Web API 的方式,透過 HttpClient物件的 GetStringAsync 的非同步方法。
  • OnWCFClicked
    這個按鈕事件,展示了如何呼叫 WCF 的方式,透過 DependencyService.Get 靜態方法,取得在該行動裝置平台下實作的物件,並且呼叫實作的 Sum() 方法。
using System;
using System.Collections.Generic;
using System.Linq;
using System.Net.Http;
using System.Text;
using System.Threading.Tasks;
using Xamarin.Forms;

namespace XFWebSrv
{
    public partial class MainPage : ContentPage
    {
        public MainPage()
        {
            InitializeComponent();
        }

        async void OnRESTfulClicked(object sender, EventArgs e)
        {
            var fooURL = $"http://doggyrestfulapi.azurewebsites.net/api/SumData?value1={entryValue1.Text}&value2={entryValue2.Text}";
            var fooClient = new HttpClient();
            var fooResult = await fooClient.GetStringAsync(fooURL);
            labelRESTful.Text = $"透過 RESTful API 計算出的結果 : {fooResult}";
        }

        async void OnWCFClicked(object sender, EventArgs e)
        {
            int v1 = int.Parse(entryValue1.Text);
            int v2 = int.Parse(entryValue2.Text);
            int v3 = await DependencyService.Get<IWCFService>().Sum(v1, v2);
            labelWCF.Text = $"透過 WCF 計算出的結果 : {v3}"; ;
        }
    }
}

相依性服務定義

核心PCL

  • 請在 XFWebSrv 核心PCL 專案節點使用滑鼠右擊該節點,選擇 加入 > 類別,當 加入新項目 - XFWebSrv 對話窗出現後,點選 Visual C# > 類別,最後在下方名稱欄位的文字輸入盒內,輸入IWCFService
  • 請將底下 C# 程式碼複製到這個檔案內。

IWCFService.cs

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

namespace XFWebSrv
{
    public interface IWCFService
    {
        Task<int> Sum(int v1, int v2);
    }
}

Android 專案

  • 請在 XFWebSrv.Droid 專案下的 參考 節點,使用滑鼠右擊該節點,選擇 加入參考,當 參考管理員 - XFWebSrv.Droid 對話窗出現後,點選 專案 > 方案,最後勾選 XFWCFPCL
    加入XFWCFPCL參考
  • 請在 XFWebSrv.Droid 專案節點使用滑鼠右擊該節點,選擇 加入 > 類別,當 加入新項目 - XFWebSrv.Droid 對話窗出現後,點選 Visual C# > Class,最後在下方名稱欄位的文字輸入盒內,輸入 WCFService
  • 請將底下 C# 程式碼複製到這個檔案內。

WCFService.cs

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;

using Android.App;
using Android.Content;
using Android.OS;
using Android.Runtime;
using Android.Views;
using Android.Widget;
using XFWCFPCL;
using XFWebSrv.Droid;

[assembly: Xamarin.Forms.Dependency(typeof(WCFService))]
namespace XFWebSrv.Droid
{
    public class WCFService : WCFServiceBase, IWCFService
    {
    }
}

iOS 專案

  • 請在 XFWebSrv.iOS 專案下的 參考 節點,使用滑鼠右擊該節點,選擇 加入參考,當 參考管理員 - XFWebSrv.Droid 對話窗出現後,點選 專案 > 方案,最後勾選 XFWCFPCL
    加入XFWCFPCL參考
  • 請在 XFWebSrv.iOS 專案節點使用滑鼠右擊該節點,選擇 加入 > 類別,當 加入新項目 - XFWebSrv.iOSDroid 對話窗出現後,點選 Apple > 類別,最後在下方名稱欄位的文字輸入盒內,輸入WCFService
  • 請將底下 C# 程式碼複製到這個檔案內。

WCFService.cs

using System;
using System.Collections.Generic;
using System.Text;
using XFWCFPCL;
using XFWebSrv.iOS;

[assembly: Xamarin.Forms.Dependency(typeof(WCFService))]
namespace XFWebSrv.iOS
{
    public class WCFService : WCFServiceBase, IWCFService
    {
    }
}

實際執行畫面

Android 執行結果

請在方案總管內,滑鼠右擊 XFWebSrv.Droid 專案,選擇 設定為起始專案,接著按下 F5 開始執行。
Android執行結果1

佈署注意事項

iOS 執行結果

請在方案總管內,滑鼠右擊 XFWebSrv.iOS 專案,選擇 設定為起始專案,接著按下 F5 開始執行。
iOS執行結果1