C# 访问Xamarin.iOS设置。捆绑包?

C# 访问Xamarin.iOS设置。捆绑包?,c#,ios,iphone,xamarin,settings.bundle,C#,Ios,Iphone,Xamarin,Settings.bundle,我一直在努力寻找一个解决问题的方法,这个方法应该是非常直接的。 我想要的是在应用程序未运行时可以在iPhone设置菜单中编辑的变量。基本上是一个包装在iOS GUI中的配置文件 这应该是iOS中的内置功能,虽然我可以找到一些与之相关的方法,但我找不到实际的解决方案 我最接近于得到我想要的东西的地方是它与任何其他变量一样工作的地方:在应用程序启动时为空,在应用程序关闭时再次被刮伤。在iPhone设置窗口中仍然不可见 这是我的代码: private void LoadSettingsFromIOS(

我一直在努力寻找一个解决问题的方法,这个方法应该是非常直接的。 我想要的是在应用程序未运行时可以在iPhone设置菜单中编辑的变量。基本上是一个包装在iOS GUI中的配置文件

这应该是iOS中的内置功能,虽然我可以找到一些与之相关的方法,但我找不到实际的解决方案

我最接近于得到我想要的东西的地方是它与任何其他变量一样工作的地方:在应用程序启动时为空,在应用程序关闭时再次被刮伤。在iPhone设置窗口中仍然不可见

这是我的代码:

private void LoadSettingsFromIOS()
{
    // This is where it works like any other variable. Aka. gets scratched on app closing.
    _thisUser.SetValueForKey(new NSString("Blargh"), new NSString("SaveCredentials"));
    string stringForKey = _thisUser.StringForKey("SaveCredentials");

    // This is where I'm supposed to be able to load the data from settings and set the checkbox's 'On' state to the value. Currently it always returns False.
    bool saveCredentials = _thisUser.BoolForKey("SaveCredentials");
    chckBoxRememberMe.On = saveCredentials;
}
和我的设置。Bundle Root.pList文件:

  <?xml version="1.0" encoding="UTF-8"?>
  <!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
  <plist version="1.0">
  <dict>
      <key>PreferenceSpecifiers</key>
      <array>
          <dict>
              <key>Type</key>
              <string>PSToggleSwitchSpecifier</string>
              <key>Title</key>
              <string>Credentials</string>
              <key>Key</key>
              <string>SaveCredentials</string>
              <key>DefaultValue</key>
              <true/>
          </dict>
      </array>
      <key>StringsTable</key>
      <string>Root</string>
  </dict>
  </plist>

偏好说明符
类型
psToggleSwitch说明符
标题
资格证书
钥匙
保存凭据
默认值
StringsTable
根
有没有人曾经玩过Xamarin iOS并且知道它是如何工作的?

试试这个:

NSBundle.MainBundle.PathForResource ("Settings", @"bundle");

编辑:这里是Xamarin的一个工作项目:

首先,您需要使您的视图在iPhone设置窗口中可见

为此,您需要在应用程序包的顶级目录中创建一个名为“Settings.bundle”的文件夹。然后,创建名为“Root.plist”的新文件。文件必须是属性列表类型的。 通过右键单击Settings.bundle,然后添加->新建文件…->iOS(在左窗格上)->属性列表。如果您添加一个空文件,然后将其重命名为.plist,它将不会显示在iPhone的设置中

Root.plist中的第一个元素必须是数组,并且必须包含字典

您可以在此处找到有关如何构建设置视图的更多信息:

请注意图4-2(不需要字符串文件名)。另外,在Xamarin编辑器中编辑Root.plist文件更容易

要从新创建的设置中获取值,可以使用此类(根据需要添加任意数量的属性):

公共类设置
{
公共静态字符串ApiPath{get;private set;}
const string API\u PATH\u KEY=“serverAddress”;//这需要是Root.plist中字段的标识符
公共静态无效SetUpByPreferences()
{
var testVal=NSUserDefaults.StandardUserDefaults.StringForKey(API_路径_键);
if(testVal==null)
LoadDefaultValues();
其他的
LoadEditedValues();
SavePreferences();
}
静态void LoadDefaultValues()
{
var settingsDict=new NSDictionary(NSBundle.MainBundle.PathForResource(“Settings.bundle/Root.plist”,null));
如果(设置信息量!=null)
{
var prefSpecifierArray=settingsDict[(NSString)“PreferenceSpecifiers”]作为NSArray;
if(prefSpecifierArray!=null)
{
foreach(NSArray.FromArray(prefSpecifierArray)中的变量prefItem)
{
var key=prefItem[(NSString)“key”]作为NSString;
if(key==null)
继续;
var值=前缀项[(NSString)“DefaultValue”];
如果(值==null)
继续;
开关(key.ToString())
{
案例API_路径_密钥:
ApiPath=value.ToString();
打破
违约:
打破
}
}
}
}
}
静态void LoadEditedValues()
{
ApiPath=NSUserDefaults.StandardUserDefaults.StringForKey(API_路径_键);
}
//将新首选项保存到设置
静态void SavePreferences()
{
var appDefaults=NSDictionary.FromObjectsAndKeys(新对象[]){
新NSString(ApiPath)
},新对象[]{
API_路径_密钥
});
NSUserDefaults.StandardUserDefaults.RegisterDefaults(appDefaults);
NSUserDefaults.StandardUserDefaults.Synchronize();
}
}
只需调用
SetUpByPreferences()
(这是唯一的公共方法),然后从类中的属性获取值

public class Settings
{
    public static string ApiPath { get; private set; }

    const string API_PATH_KEY = "serverAddress"; //this needs to be the Identifier of the field in the Root.plist

    public static void SetUpByPreferences()
    {
        var testVal = NSUserDefaults.StandardUserDefaults.StringForKey(API_PATH_KEY);

        if (testVal == null)
            LoadDefaultValues();
        else
            LoadEditedValues();

        SavePreferences();
    }

    static void LoadDefaultValues()
    {
        var settingsDict = new NSDictionary(NSBundle.MainBundle.PathForResource("Settings.bundle/Root.plist", null));

        if (settingsDict != null)
        {
            var prefSpecifierArray = settingsDict[(NSString)"PreferenceSpecifiers"] as NSArray;

            if (prefSpecifierArray != null)
            {
                foreach (var prefItem in NSArray.FromArray<NSDictionary>(prefSpecifierArray))
                {
                    var key = prefItem[(NSString)"Key"] as NSString;

                    if (key == null)
                        continue;

                    var value = prefItem[(NSString)"DefaultValue"];

                    if (value == null)
                        continue;

                    switch (key.ToString())
                    {
                        case API_PATH_KEY:
                            ApiPath = value.ToString();
                            break;
                        default:
                            break;
                    }
                }
            }
        }
    }

    static void LoadEditedValues()
    {
        ApiPath = NSUserDefaults.StandardUserDefaults.StringForKey(API_PATH_KEY);
    }

    //Save new preferences to Settings
    static void SavePreferences()
    {
        var appDefaults = NSDictionary.FromObjectsAndKeys(new object[] {
            new NSString(ApiPath)
        }, new object[] {
            API_PATH_KEY
        });

        NSUserDefaults.StandardUserDefaults.RegisterDefaults(appDefaults);
        NSUserDefaults.StandardUserDefaults.Synchronize();
    }
}