今回は、
アプリケーションをダウンロードして実行する
iOS版と同様に、
data:image/s3,"s3://crabby-images/58a89/58a893a2efbaa2a78c974a3c34dc7fe30f25c374" alt="Androidのテンプレートをダウンロード Androidのテンプレートをダウンロード"
ダウンロードしたzipを解凍し後フォルダをリネームして、
data:image/s3,"s3://crabby-images/75eab/75eab9887536106f2d3da8c09e1e2402337da016" alt="iOS版のあるフォルダにリネームして展開する iOS版のあるフォルダにリネームして展開する"
Xamarinにて既存のプロジェクトとして追加します。
data:image/s3,"s3://crabby-images/3c4dd/3c4dde62b19f37d22f8354669be0f74e62f196b8" alt="既存のプロジェクトを選択する 既存のプロジェクトを選択する"
data:image/s3,"s3://crabby-images/a204a/a204ab4da93311de6004953ee319e4ea46879871" alt="Androidのcsprojを選択する Androidのcsprojを選択する"
追加したプロジェクトを
data:image/s3,"s3://crabby-images/5ce77/5ce772831d5a5336d8bea621ddd29e3f4b77b26c" alt="スタートアッププロジェクトとして設定 スタートアッププロジェクトとして設定"
Debugを実行し、
data:image/s3,"s3://crabby-images/aa747/aa747360d61dff69b5ff7b9862d96fd317e93fd3" alt="エミュレータを起動 エミュレータを起動"
エミュレータが起動して、
data:image/s3,"s3://crabby-images/4d2ba/4d2ba8f99a8ec2a96aa1fdf270091683d2d44d79" alt="最新の状態に更新 最新の状態に更新"
「device」
data:image/s3,"s3://crabby-images/4ea37/4ea3705c7f1783295648f55279999436e432f9b8" alt="アプリ起動 アプリ起動"
iOS版と異なり、
Androidアプリに画面を追加する
それではiOS版と同じように詳細画面を追加してみましょう。Androidの場合は、
詳細画面のLayoutファイルを追加する
右クリックから
data:image/s3,"s3://crabby-images/de0b3/de0b3b790d70c3850e85c4ddf4d3762c8493f468" alt="新しいファイルを選択する 新しいファイルを選択する"
「Android Layout」
data:image/s3,"s3://crabby-images/cfeae/cfeae6edffcd85d2fdfefcac7f04b819bf3a4fdd" alt="Activity_To_Do_Detailを作成する Activity_To_Do_Detailを作成する"
詳細画面のLayoutファイルを編集する
「Activity_
data:image/s3,"s3://crabby-images/f2e0d/f2e0d1b1aca661124f6a17ab85a87b6aeedf9d55" alt="TextViewを2つ配置する TextViewを2つ配置する"
画面の余白をクリックして、
data:image/s3,"s3://crabby-images/f7aa0/f7aa075b63e0940f69741c0a936dfaeaf5357a9d" alt="horizontalに変更する horizontalに変更する"
「TextView」
data:image/s3,"s3://crabby-images/da9e3/da9e3d5ce14479290a168758aeaf2c48bebe67ac" alt="サイズを変更する サイズを変更する"
Textに
data:image/s3,"s3://crabby-images/18fa3/18fa32bc2a7271acbf2843aeb68b4d909bad32dc" alt="タイトルと入力する タイトルと入力する"
一覧画面を編集する
一覧画面は次のように2つのxamlで構成されています。
data:image/s3,"s3://crabby-images/99c09/99c095502d619c3bc91efbe819c3d4c1dda15b0e" alt="一覧画面の構成 一覧画面の構成"
今回は、
Row_
data:image/s3,"s3://crabby-images/7f417/7f417615bc23945671eaab8f10b93f8e6e7566ef" alt="Textの中身を消す Textの中身を消す"
続いて、
data:image/s3,"s3://crabby-images/6849f/6849f35f2bb3e40cb6cb585e63c79684a35ad5b0" alt="TextViewを追加 TextViewを追加"
このままだとチェックボックスと表示位置がずれるので、
すると良い感じで表示されるようになります。ついでにIdも他とかぶらないように
data:image/s3,"s3://crabby-images/92909/92909a5ca2929642db5de7da6273e9d9fd116a2d" alt="Idを変更する Idを変更する"
一覧画面のイベントを編集する
レイアウトができたので、
public override View GetView (int position, Android.Views.View convertView, Android.Views.ViewGroup parent)
{
var row = convertView;
var currentItem = this [position];
CheckBox checkBox;
TextView textView;
if (row == null) {
var inflater = activity.LayoutInflater;
row = inflater.Inflate (layoutResourceId, parent, false);
checkBox = row.FindViewById <CheckBox> (Resource.Id.checkToDoItem);
checkBox.CheckedChange += async (sender, e) => {
var cbSender = sender as CheckBox;
if (cbSender != null && cbSender.Tag is ToDoItemWrapper && cbSender.Checked) {
cbSender.Enabled = false;
if (activity is ToDoActivity)
await ((ToDoActivity)activity).CheckItem ((cbSender.Tag as ToDoItemWrapper).ToDoItem);
}
};
// textViewのクリックイベントを追加
textView = row.FindViewById<TextView> (Resource.Id.listTitle);
textView.Click += (sender, e) => {
var intent = new Intent(activity, typeof(ToDoDetailActivity));
intent.PutExtra("item", JsonConvert.SerializeObject(currentItem));
activity.StartActivity(intent);
};
} else {
checkBox = row.FindViewById <CheckBox> (Resource.Id.checkToDoItem);
textView = row.FindViewById <TextView> (Resource.Id.listTitle);
}
textView.Text = currentItem.Text;
checkBox.Checked = false;
checkBox.Enabled = true;
checkBox.Tag = new ToDoItemWrapper (currentItem);
return row;
}
この状態でビルドするとエラー画面が表示されます。これはToDoDetailActivityクラスがないなど複数の原因があります。手動でクラスを追加しても良いのですが、
Option+Command+↓を押すとエラーメッセージの箇所にジャンプします。その状態でOption+Enterをおして
data:image/s3,"s3://crabby-images/a596a/a596ae1895095ce3cf94bd9dc8d0487e6037f45e" alt="「using Android.Content」を選択する 「using Android.Content」を選択する"
同様の操作を行い、
data:image/s3,"s3://crabby-images/fa35a/fa35a834fdfbdf9228ee403b2727acebeec05a60" alt="「Create class」を選択します 「Create class」を選択します"
詳細画面のActivityを編集する
新たに作成された
using System;
using System.Collections.Generic;
using Android.App;
using Android.Content;
using Android.OS;
using Android.Views;
using Android.Widget;
using Newtonsoft.Json;
namespace nnasaki_gi
{
[Activity (Label = "ToDoDetailActivity")]
public class ToDoDetailActivity : Activity
{
protected override void OnCreate (Bundle bundle)
{
base.OnCreate (bundle);
// Layoutを関連づける
SetContentView (Resource.Layout.Activity_To_Do_Detail);
// 前の画面のデータをデシリアライズする
var str = this.Intent.Extras.GetString ("item");
var item = JsonConvert.DeserializeObject<ToDoItem> (str);
// タイトルを表示する
var textView2 = FindViewById <TextView> (Resource.Id.textView2);
textView2.Text = item.Text;
}
}
}
これで、
data:image/s3,"s3://crabby-images/ae91e/ae91e1dfdb00378b3a0d44bdbbd59ba995fe4379" alt="詳細画面 詳細画面"