iOS开发笔记--iOS 跳转到系统的设置界面【适用iOS7.1、8.3、9.1】

在项目中,我们经常会碰到使用位置的需求。当用户设置app不允许使用位置的时候,最好的用户体验就是直接调转到系统的位置设置界面,进行设置。

本人已经测试,在5c/6 iOS8.3系统 、6 iOS9.1系统和 5s iOS7.1系统中可以正常跳转

1.跳转到自己的项目中

在需要调转的按钮动作中添加如下的代码,就会跳转到设置中自己的app的设置界面,这里会有通知和位置权限的设置

<code class="hljs ruby has-numbering" style="display: block; padding: 0px; color: inherit; box-sizing: border-box; font-family: 'Source Code Pro', monospace;font-size:undefined; white-space: pre; border-radius: 0px; word-wrap: normal; background: transparent;"><span class="hljs-constant" style="box-sizing: border-box;">NSURL</span> * url = [<span class="hljs-constant" style="box-sizing: border-box;">NSURLURLWithString</span><span class="hljs-symbol" style="color: rgb(0, 102, 102); box-sizing: border-box;">:UIApplicationOpenSettingsURLString</span>];
<span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">if</span>([[<span class="hljs-constant" style="box-sizing: border-box;">UIApplicationsharedApplication</span>] <span class="hljs-symbol" style="color: rgb(0, 102, 102); box-sizing: border-box;">canOpenURL:</span>url]) {
<span class="hljs-constant" style="box-sizing: border-box;">NSURL</span>*url =[<span class="hljs-constant" style="box-sizing: border-box;">NSURLURLWithString</span><span class="hljs-symbol" style="color: rgb(0, 102, 102); box-sizing: border-box;">:UIApplicationOpenSettingsURLString</span>]; [[<span class="hljs-constant" style="box-sizing: border-box;">UIApplicationsharedApplication</span>] <span class="hljs-symbol" style="color: rgb(0, 102, 102); box-sizing: border-box;">openURL:</span>url];
}</code><ul class="pre-numbering" style="box-sizing: border-box; position: absolute; width: 50px; top: 0px; left: 0px; margin: 0px; padding: 6px 0px 40px; border-right-width: 1px; border-right-style: solid; border-right-color: rgb(221, 221, 221); list-style: none; text-align: right; background-color: rgb(238, 238, 238);"><li style="box-sizing: border-box; padding: 0px 5px;">1</li><li style="box-sizing: border-box; padding: 0px 5px;">2</li><li style="box-sizing: border-box; padding: 0px 5px;">3</li><li style="box-sizing: border-box; padding: 0px 5px;">4</li></ul>

**测试注意 
新项目测试,需要请求一下位置权限或者通知权限,才可以跳进自己的app设置里面,如果没有任何权限请求,就只能跳到系统的设置界面**

2.跳转到系统设置的其他界面

在点击跳转的按钮动作中添加如下代码

<code class="hljs lua has-numbering" style="display: block; padding: 0px; color: inherit; box-sizing: border-box; font-family: 'Source Code Pro', monospace;font-size:undefined; white-space: pre; border-radius: 0px; word-wrap: normal; background: transparent;"><span class="hljs-string" style="color: rgb(0, 136, 0); box-sizing: border-box;">[[UIApplication sharedApplication] openURL:[NSURL URLWithString:@"prefs:root=WIFI"]]</span>;</code><ul class="pre-numbering" style="box-sizing: border-box; position: absolute; width: 50px; top: 0px; left: 0px; margin: 0px; padding: 6px 0px 40px; border-right-width: 1px; border-right-style: solid; border-right-color: rgb(221, 221, 221); list-style: none; text-align: right; background-color: rgb(238, 238, 238);"><li style="box-sizing: border-box; padding: 0px 5px;">1</li></ul>

在项目中的info中添加 URL types 
添加 URL Schemes 为 prefs的url 
这里写图片描述 
这样点击就可以跳转到wifi设置界面 
(测试手机 5c 8.3系统 5s 7.1系统)

3.跳转到其他的界面的字段

<code class="hljs mathematica has-numbering" style="display: block; padding: 0px; color: inherit; box-sizing: border-box; font-family: 'Source Code Pro', monospace;font-size:undefined; white-space: pre; border-radius: 0px; word-wrap: normal; background: transparent;">About — prefs:root=<span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">General</span>&path=About
Accessibility — prefs:root=<span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">General</span>&path=ACCESSIBILITY
AirplaneModeOn— prefs:root=AIRPLANE_MODE
Auto-Lock — prefs:root=<span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">General</span>&path=AUTOLOCK
Brightness — prefs:root=Brightness
Bluetooth — prefs:root=<span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">General</span>&path=Bluetooth
<span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">Date</span>& Time — prefs:root=<span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">General</span>&path=DATE_AND_TIME
FaceTime — prefs:root=FACETIME
<span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">General</span>— prefs:root=<span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">General</span>
Keyboard — prefs:root=<span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">General</span>&path=Keyboard
iCloud — prefs:root=CASTLE iCloud
Storage & Backup — prefs:root=CASTLE&path=STORAGE_AND_BACKUP
International — prefs:root=<span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">General</span>&path=INTERNATIONAL
Location Services — prefs:root=LOCATION_SERVICES
Music — prefs:root=MUSIC
Music Equalizer — prefs:root=MUSIC&path=EQ
Music VolumeLimit— prefs:root=MUSIC&path=VolumeLimit
Network — prefs:root=<span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">General</span>&path=Network
Nike + iPod — prefs:root=NIKE_PLUS_IPOD
Notes — prefs:root=NOTES
Notification — prefs:root=NOTIFICATIONS_ID
Phone — prefs:root=Phone
Photos — prefs:root=Photos
Profile — prefs:root=<span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">General</span>&path=ManagedConfigurationList
Reset — prefs:root=<span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">General</span>&path=Reset
Safari — prefs:root=Safari Siri — prefs:root=<span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">General</span>&path=Assistant
Sounds — prefs:root=Sounds
SoftwareUpdate— prefs:root=<span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">General</span>&path=SOFTWARE_UPDATE_LINK
Store — prefs:root=STORE
Twitter — prefs:root=TWITTER
Usage — prefs:root=<span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">General</span>&path=USAGE
VPN — prefs:root=<span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">General</span>&path=Network/VPN
Wallpaper — prefs:root=Wallpaper
Wi-Fi — prefs:root=WIFI
<span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">Setting</span>—prefs:root=INTERNET_TETHERING
</code><ul class="pre-numbering" style="box-sizing: border-box; position: absolute; width: 50px; top: 0px; left: 0px; margin: 0px; padding: 6px 0px 40px; border-right-width: 1px; border-right-style: solid; border-right-color: rgb(221, 221, 221); list-style: none; text-align: right; background-color: rgb(238, 238, 238);"><li style="box-sizing: border-box; padding: 0px 5px;">1</li><li style="box-sizing: border-box; padding: 0px 5px;">2</li><li style="box-sizing: border-box; padding: 0px 5px;">3</li><li style="box-sizing: border-box; padding: 0px 5px;">4</li><li style="box-sizing: border-box; padding: 0px 5px;">5</li><li style="box-sizing: border-box; padding: 0px 5px;">6</li><li style="box-sizing: border-box; padding: 0px 5px;">7</li><li style="box-sizing: border-box; padding: 0px 5px;">8</li><li style="box-sizing: border-box; padding: 0px 5px;">9</li><li style="box-sizing: border-box; padding: 0px 5px;">10</li><li style="box-sizing: border-box; padding: 0px 5px;">11</li><li style="box-sizing: border-box; padding: 0px 5px;">12</li><li style="box-sizing: border-box; padding: 0px 5px;">13</li><li style="box-sizing: border-box; padding: 0px 5px;">14</li><li style="box-sizing: border-box; padding: 0px 5px;">15</li><li style="box-sizing: border-box; padding: 0px 5px;">16</li><li style="box-sizing: border-box; padding: 0px 5px;">17</li><li style="box-sizing: border-box; padding: 0px 5px;">18</li><li style="box-sizing: border-box; padding: 0px 5px;">19</li><li style="box-sizing: border-box; padding: 0px 5px;">20</li><li style="box-sizing: border-box; padding: 0px 5px;">21</li><li style="box-sizing: border-box; padding: 0px 5px;">22</li><li style="box-sizing: border-box; padding: 0px 5px;">23</li><li style="box-sizing: border-box; padding: 0px 5px;">24</li><li style="box-sizing: border-box; padding: 0px 5px;">25</li><li style="box-sizing: border-box; padding: 0px 5px;">26</li><li style="box-sizing: border-box; padding: 0px 5px;">27</li><li style="box-sizing: border-box; padding: 0px 5px;">28</li><li style="box-sizing: border-box; padding: 0px 5px;">29</li><li style="box-sizing: border-box; padding: 0px 5px;">30</li><li style="box-sizing: border-box; padding: 0px 5px;">31</li><li style="box-sizing: border-box; padding: 0px 5px;">32</li><li style="box-sizing: border-box; padding: 0px 5px;">33</li><li style="box-sizing: border-box; padding: 0px 5px;">34</li><li style="box-sizing: border-box; padding: 0px 5px;">35</li><li style="box-sizing: border-box; padding: 0px 5px;">36</li></ul>

转自:http://www.jianshu.com/p/19602f48309b

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值