高精度やバッテリ節約などに切り替えようとすると、
SecurityExceptionが発生してしまいます。
AndroidManifest.xmlにはandroid.permission.WRITE_SECURE_SETTINGSを付与しており、
署名付きのapkを作成後、adb pushで/system/app/内へインストールしてから実行しています。
該当コードは以下のとおりです。
○コード
android.provider.Settings.Secure.putInt(getContentResolver(), Secure.LOCATION_MODE, Secure.LOCATION_MODE_HIGH_ACCURACY);
○AndroidManifest.xml
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="
http://schemas.android.com/apk/res/android"
package="
com.cotetsu.android.providerswitch"
android:versionCode="1"
android:versionName="1.0" >
<uses-sdk android:minSdkVersion="10" />
<uses-permission android:name="android.permission.WRITE_SETTINGS" />
<uses-permission android:name="android.permission.WRITE_SECURE_SETTINGS" />
<application
android:icon="@drawable/ic_launcher"
android:label="@string/app_name" >
<activity
android:name=".ProviderSwitchActivity"
android:label="@string/app_name" >
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
</application>
</manifest>
エラーログは以下のようになります。
11-27 10:13:11.862: E/DatabaseUtils(790): Writing exception to parcel
11-27
10:13:11.862: E/DatabaseUtils(790): java.lang.SecurityException:
Permission denial: writing to secure settings requires
android.permission.WRITE_SECURE_SETTINGS
11-27 10:13:11.862: E/DatabaseUtils(790): at com.android.providers.settings.SettingsProvider.checkWritePermissions(SettingsProvider.java:282)
11-27 10:13:11.862: E/DatabaseUtils(790): at com.android.providers.settings.SettingsProvider.insertForUser(SettingsProvider.java:914)
11-27 10:13:11.862: E/DatabaseUtils(790): at com.android.providers.settings.SettingsProvider.call(SettingsProvider.java:648)
11-27 10:13:11.862: E/DatabaseUtils(790): at android.content.ContentProvider$Transport.call(ContentProvider.java:325)
11-27 10:13:11.862: E/DatabaseUtils(790): at android.content.ContentProviderNative.onTransact(ContentProviderNative.java:275)
11-27 10:13:11.862: E/DatabaseUtils(790): at android.os.Binder.execTransact(Binder.java:404)
11-27 10:13:11.862: E/DatabaseUtils(790): at dalvik.system.NativeStart.run(Native Method)
ログではandroid.permission.WRITE_SECURE_SETTINGSのパーミッションが必要だと言っている用に思えますが、
すでに付与しているためなぜ発生するのかわかりません。
となたか、ご教授いただけますでしょうか。
よろしくお願い致します。