今回はXamarin.Formsで使えるNugetパッケージを作成して、実際にプロジェクトに取り込み使ってみます。
1.VisualStudioを起動し新規を選択
data:image/s3,"s3://crabby-images/8dc90/8dc90b33d0174d224e1de52b502c4b9599781da0" alt=""
2.マルチプラットフォーム>ライブラリ>Xamarin.Forms クラスライブラリを選択
data:image/s3,"s3://crabby-images/81c79/81c791e98583c82b54c5620801b9caf4c6f52a00" alt=""
3.プロジェクト名、ソリューション名、プロジェクトファイルの保存先を入力し、作成
data:image/s3,"s3://crabby-images/f6619/f6619936831fae82f65e91ad2b676ece928ad6ef" alt=""
4.プロジェクトフォルダを選択しダブルクリック
data:image/s3,"s3://crabby-images/58ab4/58ab498fc48d3d0511ced5da1ba7941122bc6c48" alt=""
5.Nugetパッケージ > メタデータ
id,バージョン,作成者,説明を入力しOKを押す
data:image/s3,"s3://crabby-images/56267/562676fe9cbbff3c9dcedbe3c4997122219828d0" alt=""
6.プロジェクトファイル内にパッケージ化したい処理を書く
今回は例として、タップしたら色の変わるBoxViewを作成
data:image/s3,"s3://crabby-images/5f5a6/5f5a60fa70b1a41522163b78c7e67be70f323409" alt=""
using System;
using Xamarin.Forms;
namespace NugetTest {
public class MyBoxView : BoxView {
public static readonly BindableProperty TapCommandProperty =
BindableProperty.Create(
nameof(TapCommand),
typeof(Command),
typeof(MyBoxView),
null,
propertyChanged: (bindable, oldValue, newValue) => ((MyBoxView)bindable).TapCommand = (Command)newValue);
public Command TapCommand {
get { return (Command)GetValue(TapCommandProperty); }
set { SetValue(TapCommandProperty, value); }
}
public MyBoxView() : base() {
var tgr = new TapGestureRecognizer();
tgr.Tapped += (sender, e) => OnClicked(sender, e);
this.GestureRecognizers.Add(tgr);
}
private void OnClicked(object sender, EventArgs e) {
var myBoxView = sender as MyBoxView;
myBoxView.BackgroundColor = Color.Red;
if (TapCommand != null && TapCommand.CanExecute(""))
TapCommand.Execute("");
}
}
}
7.ビルド構成をReleaseに変更
data:image/s3,"s3://crabby-images/c1451/c1451b175516743c4981af8ca69262c032d1d798" alt=""
8.プロジェクトフォルダを右クリックし、Nugetパッケージの作成を押す
data:image/s3,"s3://crabby-images/ae283/ae28321b82ca27c36b86ae8d4c24ddc787d33603" alt=""
9.Finderで作成したプロジェクトのフォルダを開き プロジェクトフォルダ>bin>Releaseの中に「.nupkg」の拡張子のファイルができているので、デスクトップにコピーしておきます。
ここからは実際にNugetパッケージを使う工程です。
10.作成したnugetパッケージを使いたいプロジェクトファイルをVisualStudioで開く
11.プロジェクトのNugetパッケージの管理を開く
data:image/s3,"s3://crabby-images/7cab4/7cab480802b35144fc232db28ac1ea8e5ef9bc94" alt=""
12.Nugetパッケージの管理のページ上部のタブから「ソースの構成」を選択
data:image/s3,"s3://crabby-images/50055/50055d6dd1d5525d09ec94a98512b73728a60a92" alt=""
13.Nuget>ソースを選択後、追加を押す
data:image/s3,"s3://crabby-images/48085/48085ac823194fca8da12a5d0836e7caf5a5e9de" alt=""
14.名前にDesktopと入力、場所にデスクトップのパスを入れ、ソースを追加を押す
(ユーザー名とパスワードは未入力でOK)
data:image/s3,"s3://crabby-images/277f2/277f223e260d31b070f4901099e5ecb2bfe7070a" alt=""
15.再度Nugetパッケージの管理のページを表示すると上部のタブから「Desktop」が選択できるようになるので選択
16.先ほど作成し、デスクトップにコピーしたNugetパッケージが選択できるようになっているので選択し、パッケージを追加する
17.追加したパッケージが使えるようになるので先ほど作った「MyBoxView」を使ってみる
<ContentPage
xmlns="http://xamarin.com/schemas/2014/forms"
xmlns:x="http://schemas.microsoft.com/winfx/2009/xaml"
x:Class="test1.MainPage"
xmlns:nugetTest="clr-namespace:NugetTest;assembly=NugetTest">
<StackLayout
HorizontalOptions="FillAndExpand"
VerticalOptions="FillAndExpand">
<nugetTest:MyBoxView
BackgroundColor="Aqua"
WidthRequest="100"
HeightRequest="100"
HorizontalOptions="CenterAndExpand"
VerticalOptions="CenterAndExpand"/>
</StackLayout>
</ContentPage>
xmlns:nugetTest=”clr-namespace:NugetTest;assembly=NugetTest”
↑ここのnamespaceとassemblyには自分がNugetパッケージを作る際に設定したプロジェクト名(namespace)を記述してください。
このようにして自分で作ったコントロール等をnuget化し使うことができます。
実際に動かしてみると
↓ページ表示
data:image/s3,"s3://crabby-images/bb8bc/bb8bc88128d6b5aa823f79289734e2b2dc0ccf1e" alt=""
↓Boxをタップ
data:image/s3,"s3://crabby-images/3dce3/3dce3013600951cd530c301f69572a7daa9f7609" alt=""
ちゃんと動きました。