App Settings.Bundle 花式用法

App Settings.Bundle

写在前边

Settings.Bundle 是App的配置项, 用户和测试可以在外围对于App的部分信息进行修改, 是的App的运行环境变的可配置, 对于测试尤其使用.

我们也可以结合Build Configuration针对不同的编译环境进行个性化设置, 当然, 包括移除Setting(有时候Production版本是不需要Setting的)

本文分为三个部分:

  • Setting 用法: 详细的数据结构
  • 应用场景: 使用注意事项
  • 动态配置: 动态添加Setting

Setting 用法

Settings.Bundle支持六种配置项分别是:

  • TextField
  • MultiValue
  • Title
  • Group
  • Slider
  • ToggleSwitch

TextField

数据结构:

App Settings.Bundle 花式用法_第1张图片
image

字段:

  • Type 类型,默认是 Text Field
  • Title 显示的Title
  • Identifier 标识符,用来获取配置项的配置内容
  • Default Value 默认值
  • Autocorrection Style 自动纠错(我很讨厌这个功能)
  • Autocapitalization Style 大小写类型(字符 句子 全部)

效果:


App Settings.Bundle 花式用法_第2张图片
image

MultiValue

数据结构:

App Settings.Bundle 花式用法_第3张图片
image

字段:

  • Type 类型,默认是 Multi Value
  • Title 显示的Title
  • Identifier 标识符,用来获取配置项的配置内容
  • Default Value 默认值
  • Values 可供选择的值数组
  • Titles 与选择值对应的显示文本

效果:

App Settings.Bundle 花式用法_第4张图片
image

App Settings.Bundle 花式用法_第5张图片
image

Title

数据结构1:

App Settings.Bundle 花式用法_第6张图片
image
  • Type 类型,默认是Title
  • Title 显示的Title
  • Identifier 标识符,用来获取配置项的配置内容
  • Default Value 默认值

效果:

App Settings.Bundle 花式用法_第7张图片
image

数据结构2:


App Settings.Bundle 花式用法_第8张图片
image
  • Values 可供选择的值数组
  • Titles 与选择值对应的显示文本

相对于结构1, 多出了Values和Titles两个字段, 此时要注意的是, Default Value只能取自于Values中的某一个元素, 否则显示为空

效果图:


App Settings.Bundle 花式用法_第9张图片
image

Group

Group可以认为是一个用在做分组的文字, 就像Grouped TableView的效果

数据结构:

image
  • Type 类型,默认是Group
  • Title 显示的Title

效果:

App Settings.Bundle 花式用法_第10张图片
image

ToggleSwitch

选择开关

数据结构:


image
  • Type 类型,默认是 Toggle Switch
  • Title 显示的Title
  • Identifier 标识符,用来获取配置项的配置内容
  • Default Value 默认值
  • Value for OFF 关闭时对应的值(貌似没用)
  • Value for ON 打开时对应的值(貌似没用)

效果图:

App Settings.Bundle 花式用法_第11张图片
image

Slider

数据结构:


App Settings.Bundle 花式用法_第12张图片
image
  • Type 类型,默认是 Slider
  • Title 显示的Title
  • Identifier 标识符,用来获取配置项的配置内容
  • Default Value 默认值
  • Minimum Value:最小值
  • Maximun Value:最大值
  • Min Value Image Filename:最小值端图片
  • Max Value Image Filename:最大值端图片

注意:

Image Filename 不能放在主文件夹中,而是需要放在Settings捆绑包中,才能够通过 Min/Max Value Image Filename 设置使用, 如:

App Settings.Bundle 花式用法_第13张图片
image

效果图:

App Settings.Bundle 花式用法_第14张图片
image

关于字段的官方说明:

[图片上传失败...(image-ff291b-1534505621730)]

应用场景

添加Settings.Bundle的最终目的还是和app进行交互(废话),Settings中的任何选型都可以用代码获得


it is important to understand that until the user actually changes the value of
 the setting nothing is actually set. If you check for the setting in your 
 application it will actually return nil unless you set a default value. 

需要注意的是, 在用户实际修改了setting里的数据之前 , 这时配置数据并没有真正的写入到app的NSUserDefaults中, 此时用NSUserDefaults获取的值都是空的. 比如,直接调用以下代码:


- (void)testSetting {
    NSUserDefaults *defaults  = [NSUserDefaults standardUserDefaults];
    NSString *text = [defaults valueForKey:@"selecter"];
    if (text) {
        NSLog(text);
    } else {
        NSLog(@"nothing");
    }
}

结果将是:

2018-08-17 18:01:27.920247+0800 AppSetting[8672:394359] nothing
App Settings.Bundle 花式用法_第15张图片
image

也就是说此时的setting并未生效, 但是如果用户在setting中修改过selecter(setting中的选项)一个值, 获得的数据将不为空:

2018-08-17 18:08:22.177436+0800 AppSetting[8795:404984] 1

App Settings.Bundle 花式用法_第16张图片
image

对此, 我们的处理方案是, 在- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions方法中调用以下函数, 将所有的setting数据注册到app中:

- (void)registerDefaultsFromSettingsBundle
{
    NSString *settingsBundle = [[NSBundle mainBundle] pathForResource:@"Settings" ofType:@"bundle"];
    if(!settingsBundle) {
        NSLog(@"Could not find Settings.bundle");
        return;
    }
    NSDictionary *settings = [NSDictionary dictionaryWithContentsOfFile:[settingsBundle stringByAppendingPathComponent:@"Root.plist"]];
    NSArray *preferences = [settings objectForKey:@"PreferenceSpecifiers"];
    NSMutableDictionary *defaultsToRegister = [[NSMutableDictionary alloc] initWithCapacity:[preferences count]];
    for(NSDictionary *prefSpecification in preferences) {
        NSString *key = [prefSpecification objectForKey:@"Key"];
        if(key) {
            [defaultsToRegister setObject:[prefSpecification objectForKey:@"DefaultValue"] forKey:key];
        }
    }
    [[NSUserDefaults standardUserDefaults] registerDefaults:defaultsToRegister];
}

代码

动态配置

一般情况下, 我的环境配置(Build Configuration)至少分四种:

  • Dev 开发
  • Release 测试
  • Staging 预发布
  • Production 生产
    然后分别给予不同的宏定义, 以保证我们切换编译环境时, 做到代码零修改, Build Configuration配置

1. 创建工程 DynamicSetting

2. 创建相关目录

在工程目录下创建文件夹Setting以及子文件夹ReleaseStaging(一般生产环境不需要setting, 当然这要依据具体的业务需求), 并添加到工程中(不添加到工程也行, 此处只是为了方便修改)

App Settings.Bundle 花式用法_第17张图片
image

3. 创建配置

点击工程文件, 选中info, 在Configurations下点击+, 复制一个Configuration(我一般复制Release, 这样发出去的ipa都去掉日志等不必要的操作 具体依据业务需求修改)

App Settings.Bundle 花式用法_第18张图片
image

4. 添加Setting.bundle

新建Setting.Bundle, 但不要添加到当前Target中, 并分别保存到ReleaseStaging文件夹下:

不要添加到当前Target

不要添加到当前Target

不要添加到当前Target

App Settings.Bundle 花式用法_第19张图片
image

创建完成后的工程, 是这个样子的:

App Settings.Bundle 花式用法_第20张图片
image

运行XCode, 我们在模拟器中的Setting中找不到对应的DynamicSetting(废话, 都没添加到Target, 能显示才怪!!!)

5. 添加拷贝脚本

不添加到Target的原因就是 , 我们要用脚本吧Setting.Bundle拷贝到ipa中.
选中"Target", 切换到Build Phases, 点击+, 选中New Run Script Phase

App Settings.Bundle 花式用法_第21张图片
image

,

添加脚本:

if [ ${CONFIGURATION} = "Debug" ]; then
cp -r ${PROJECT_DIR}/${PROJECT_NAME}/Setting/Release/Settings.bundle ${BUILT_PRODUCTS_DIR}/${PRODUCT_NAME}.app
fi

if [ ${CONFIGURATION} = "Release" ]; then
cp -r ${PROJECT_DIR}/${PROJECT_NAME}/Setting/Release/Settings.bundle ${BUILT_PRODUCTS_DIR}/${PRODUCT_NAME}.app
fi

if [ ${CONFIGURATION} = "Staging" ]; then
cp -r ${PROJECT_DIR}/${PROJECT_NAME}/Setting/Staging/Settings.bundle ${BUILT_PRODUCTS_DIR}/${PRODUCT_NAME}.app
fi
App Settings.Bundle 花式用法_第22张图片
image

6 修改Setting

6.1 开发环境设置

修改Release文件加下的.plist文件 :

App Settings.Bundle 花式用法_第23张图片
image

选中edit scheme, 切换Build Configuration:

App Settings.Bundle 花式用法_第24张图片
image

运行XCode, 在模拟器上查看 Setting:

App Settings.Bundle 花式用法_第25张图片
image

6.1 预发布环境设置

修改Staging文件加下的.plist文件 :

App Settings.Bundle 花式用法_第26张图片
image

选中edit scheme, 切换Build Configuration:

App Settings.Bundle 花式用法_第27张图片
image

运行XCode, 在模拟器上查看 Setting:

App Settings.Bundle 花式用法_第28张图片
image

note: 由于开发环境我们没有添加相应脚本, 所以在Production下运行app, 是没有Setting

代码

参考

Adding a settings bundle to an iPhone App

Application Settings Bundle Part – I

iOS之Settings.Bundle

你可能感兴趣的:(App Settings.Bundle 花式用法)