fc2ブログ

記事一覧

アプリの設定を保存する方法 | Xamarin.Forms



今回は Xamarin.Forms でアプリの設定情報を保存する方法をご紹介いたします。
アプリを終了しても、再度起動時には保存した設定情報を復元したいことがあると思います。
Asp.net では Web.Config に保存していましたし、.net では app.config に保存していましたように、スマホアプリでは iOS と Android それぞれ独自の保存方法があるようです。



前提条件
・Windows10
・Visual Studio 2015 Community Update3
・Xamarin 4.2.0.719 (NuGet Xamarin.Forms 2.3.2.127)
・macOS Sierra 10.12.1 / Xcode8.1 / Xamarin.iOS 10.2.0.4



1.Modelクラス

PCLプロジェクトに保存する為のModelクラスを作成します。

Settingsinfo.cs
namespace AppName.ViewModels
{
public class SettingsInfo
{
public string StringValue { get; set; }
public int IntegerValue { get; set; }
public bool BooleanValue { get; set; }
public string[] StringArray { get; set; }

#region "コンストラクタ"
public SettingsInfo(string stringValue, int integerValue, bool booleanValue, string[] stringArray)
{
this.StringValue = stringValue;
this.IntegerValue = integerValue;
this.BooleanValue = booleanValue;
this.StringArray = stringArray;
}
#endregion
}
}



2.DependencyService

DependencyServiceにて記述します。
PCLプロジェクトに配置します。

ISettingService.cs
namespace AppName.Services
{
//DependencyServiceから利用する
public interface ISettingService
{
void Save(SettingsInfo setInfo);
SettingsInfo GetSettings();
}
}


Androidプロジェクト内に以下のクラスを配置します。
SettingService.cs
using Android.Content;
[assembly: Dependency(typeof(SettingService))]
namespace AppName.Droid.Services
{
public class SettingService : ISettingService
{
public void Save(SettingsInfo setInfo)
{
var prefs = Forms.Context.GetSharedPreferences("pref", FileCreationMode.Private);
var editor = prefs.Edit();

//文字列型の場合
editor.PutString("StringValue", setInfo.StringValue);
//integer型の場合
editor.PutInt("IntegerValue", setInfo.IntegerValue);
//Boolean型の場合
editor.PutBoolean("BooleanValue", setInfo.BooleanValue);
//文字列配列の場合
editor.PutStringSet("StringArray", setInfo.StringArray.ToList());

editor.Commit();
}

public SettingsInfo GetSettings()
{
var prefs = Forms.Context.GetSharedPreferences("pref", FileCreationMode.Private);

//文字列型の場合
string stringValue = prefs.GetString("StringValue", "");
//integer型の場合
int integerValue = prefs.GetInt("IntegerValue", 0);
//Boolean型の場合
bool booleanValue = prefs.GetBoolean("BooleanValue", false);
//文字列配列の場合
ICollection<string> stringArray = prefs.GetStringSet("StringArray", null);
string[] array = null;
if (array != null)
{
array = stringArray.ToArray();
//Array.Sort(array);
}

SettingsInfo setInfo = new SettingsInfo(stringValue, integerValue, booleanValue, array);

return setInfo;
}
}
}


iOSプロジェクト内に以下のクラスを配置します。
SettingService.cs
using System.Collections.Generic;
using Foundation;
[assembly: Dependency(typeof(SettingService))]
namespace AppName.iOS.Services
{
public class SettingService : ISettingService
{
public void Save(SettingsInfo setInfo)
{
var prefs = NSUserDefaults.StandardUserDefaults;

//文字列型の場合
prefs.SetString(setInfo.StringValue + "", "StringValue");
//integer型の場合
prefs.SetInt(setInfo.IntegerValue, "IntegerValue");
//Boolean型の場合
prefs.SetString(setInfo.BooleanValue.ToString(), "BooleanValue");
//文字列配列の場合
var array1 = new NSMutableArray();
if (setInfo.StringArray != null)
{
foreach (string s in setInfo.StringArray)
{
array1.Add(new NSString(s));
}
}
prefs.SetValueForKey(array1, new NSString("StringArray"));

prefs.Synchronize();
}

public SettingsInfo GetSettings()
{
var prefs = NSUserDefaults.StandardUserDefaults;

//文字列型の場合
string stringValue = prefs.StringForKey("StringValue");
if (stringValue == null)
{
stringValue = String.Empty;
}
//integer型の場合
int integerValue = (int)prefs.IntForKey("IntegerValue");
//Boolean型の場合
string booleanString = prefs.StringForKey("BooleanValue");
if (String.IsNullOrEmpty(booleanValue))
{
//初期値
booleanString = "false";
}
bool booleanValue = false;
if (booleanString.ToLower().Equals("true"))
{
booleanValue = true;
}
//文字列配列の場合
NSObject[] stringCollection = prefs.ArrayForKey("StringArray");
string[] stringArray = null;
List<string> stringList = new List<string>();
if (stringCollection != null)
{
foreach (NSString s in stringCollection)
{
stringList.Add(s);
}
stringArray = stringList.ToArray();
}

//インスタンス作成
SettingsInfo setInfo = new SettingsInfo(stringValue, intValue, booleanValue, stringArray);

return setInfo;
}
}
}

※iOSの場合、設定ファイルは以下のディレクトリに保存されるようです。
【シミュレータの場合】
/Users/UserName/Library/Developer/CoreSimulator/Devices/"DeviceID"/data/Containers/Data/Application/"AppD"/Library/Preferences
【実機デバイスの場合】
/var/mobile/Containers/Data/Application/"AppID"/Library/Preferences



3.使用方法

PCLプロジェクトで起動時に保存された設定を取得します。

App.cs
namespace AppName
{
public class App : Application
{
private static SettingsInfo _settings = null;
public static SettingsInfo Settings
{
get
{
if (_settings == null)
{
_settings = DependencyService.Get<ISettingService>().GetSettings();
}
return _settings;
}
}

public App()
{
_settings = DependencyService.Get<ISettingService>().GetSettings();
MainPage = new NavigationPage(new StartPage());
}
}
}


設定情報を保存する際のコードを任意のPageに記述します。

TestPage.xaml.cs
void OnSaveClick(object sender, EventArgs e)
{
App.Settings.StringValue = "test";
DependencyService.Get<ISettingService>().Save(App.Settings);
}


尚、保存した情報は、アプリのデータを削除したり、アプリ自体を削除すると消えてしまいます。(アプリ更新時は消えません。)

settings_01.png


以上で、保存した設定の読み込み及び、保存ができます。



当ブログの内容をまとめた Xamarin逆引きメニュー は以下のURLからご覧になれます。
https://itblog.dynaspo.com/blog-entry-81.html


関連記事

コメント

コメントの投稿

※名前とタイトルが入力されていないコメントでは他のコメントとの区別ができません。

 入力されていないコメントには返信しませんのであらかじめご了承くださいませ。

※ニックネームでも良いので必ずご入力ください。

    

※必ずご入力ください。

    
    

※必ずご入力ください。

※技術的な質問には環境やエラーについて正確かつ詳細にお教えください。

・正確なエラーの内容

・Windowsのバージョン番号

・Visual Studioのバージョン

・機器の型番

・アプリやソフトのバージョン

    

カテゴリ別記事一覧

広告

プロフィール

石河 純


著者名 :石河 純
自己紹介:素人上がりのIT技術者。趣味は卓球・車・ボウリング

IT関連の知識はざっくりとこんな感じです。
【OS関連】
WindowsServer: 2012/2008R2/2003/2000/NT4
Windows: 10/8/7/XP/2000/me/NT4/98
Linux: CentOS RedHatLinux9
Mac: macOS Catalina 10.15 / Mojave 10.14 / High Sierra 10.13 / Sierra 10.12 / OSX Lion 10.7.5 / OSX Snow Leopard 10.6.8
【言語】
VB.net ASP.NET C#.net Java VBA
Xamarin.Forms
【データベース】
Oracle 10g/9i
SQLServer 2016/2008R2/2005/2000
SQLAnywhere 16/11/8
【BI/レポートツール】
Cognos ReportNet (IBM)
Microsoft PowerBI
ActiveReport (GrapeCity)
CrystalReport
【OCX関連】
GrapeCity InputMan SPREAD MultiRow GridView
【ネットワーク関連】
CCNP シスコ技術者認定
Cisco Catalyst シリーズ
Yamaha RTXシリーズ
FireWall関連
【WEB関連】
SEO SEM CSS jQuery IIS6/7 apache2

休みの日は卓球をやっています。
現在、卓球用品通販ショップは休業中です。