Question

J'ai une activité que je peux déclarer dans la catégorie des lanceurs et il lance très bien à partir de l'écran d'accueil. Cependant, lorsque je tente de branchement la même activité dans mon activité de paramètres de SyncAdapter et ouvre de la page Comptes et synchronisation -> MySyncAdapter -.> (Compte tactile liste), il avorte avec un système erreur fatale (redémarrages téléphone)

Pendant ce temps, mon SyncAdapter travaille ailleurs.

Voici le journal au point d'impact:

01-13 12:31:00.976  5024  5038 I ActivityManager: Starting activity: Intent { act=android.provider.Settings.ACTION_SYNC_SETTINGS flg=0x10000000 cmp=com.myapp.android.syncadapter.ui/SyncAdapterSettingsActivity.class (has extras) }
01-13 12:31:00.985  5024  5038 E AndroidRuntime: *** FATAL EXCEPTION IN SYSTEM PROCESS: android.server.ServerThread
01-13 12:31:00.985  5024  5038 E AndroidRuntime: android.content.ActivityNotFoundException: Unable to find explicit activity class {com.myapp.android.syncadapter.ui/SyncAdapterSettingsActivity.class}; have you declared this activity in your AndroidManifest.xml?
01-13 12:31:00.985  5024  5038 E AndroidRuntime:    at android.app.Instrumentation.checkStartActivityResult(Instrumentation.java:1404)
01-13 12:31:00.985  5024  5038 E AndroidRuntime:    at android.app.Instrumentation.execStartActivity(Instrumentation.java:1378)
01-13 12:31:00.985  5024  5038 E AndroidRuntime:    at android.app.ContextImpl.startActivity(ContextImpl.java:622)
01-13 12:31:00.985  5024  5038 E AndroidRuntime:    at android.preference.Preference.performClick(Preference.java:828)
01-13 12:31:00.985  5024  5038 E AndroidRuntime:    at android.preference.PreferenceScreen.onItemClick(PreferenceScreen.java:190)
01-13 12:31:00.985  5024  5038 E AndroidRuntime:    at android.widget.AdapterView.performItemClick(AdapterView.java:284)
01-13 12:31:00.985  5024  5038 E AndroidRuntime:    at android.widget.ListView.performItemClick(ListView.java:3382)
01-13 12:31:00.985  5024  5038 E AndroidRuntime:    at android.widget.AbsListView$PerformClick.run(AbsListView.java:1696)
01-13 12:31:00.985  5024  5038 E AndroidRuntime:    at android.os.Handler.handleCallback(Handler.java:587)
01-13 12:31:00.985  5024  5038 E AndroidRuntime:    at android.os.Handler.dispatchMessage(Handler.java:92)
01-13 12:31:00.985  5024  5038 E AndroidRuntime:    at android.os.Looper.loop(Looper.java:123)
01-13 12:31:00.985  5024  5038 E AndroidRuntime:    at com.android.server.ServerThread.run(SystemServer.java:517)
01-13 12:31:00.985  5024  5038 I Process : Sending signal. PID: 5024 SIG: 9
01-13 12:31:01.005  5019  5019 I Zygote  : Exit zygote because system server (5024) has terminated
01-13 12:31:01.015  1211  1211 E installd: eof

Voici un extrait de mon fichier manifeste:

   <activity android:name="com.myapp.android.syncadapter.ui.SyncAdapterSettingsActivity"
              android:label="@string/title_settings" 
              android:windowSoftInputMode="stateAlwaysHidden|adjustPan">
        <intent-filter>
            <action android:name="android.intent.action.VIEW" />
            <action android:name="android.intent.action.MAIN" />
            <action android:name="android.provider.Settings.ACTION_SYNC_SETTINGS"/>
            <category android:name="android.intent.category.DEFAULT" />
            <category android:name="android.intent.category.LAUNCHER" />
        </intent-filter>
    </activity>

J'oublié le fichier de ressources XML (account_preferences.xml) qui est référencé. Il fournit un autre niveau d'indirection référence au nom de l'activité. Je peux le manipuler pour obtenir l'entrée du journal des changements en conséquence. Donc, je pense qui est une allusion à la solution. Le package cible et la classe cible se concaténés pour définir le nom de l'activité pour commencer. Ce que je remarqué dans le journal est qu'il ya une barre oblique (/) dans le nom de chemin et je pense que c'est la raison pour laquelle il est incapable de trouver l'activité. Par exemple, si je prends la ( .ui ) de l'emballage et le mettre dans la cible activité, puis la barre oblique se déplace pour être avant la balise .ui dans la chemin d'accès.

account_preferences.xml:

 <?xml version="1.0" encoding="utf-8"?>
<PreferenceScreen
  xmlns:android="http://schemas.android.com/apk/res/android">
    <PreferenceCategory android:title="@string/format_auth_preferences" />
    <PreferenceScreen
         android:key="key_syncadapter_auth"
         android:title="@string/key_syncadapter_auth_action"
         android:summary="@string/key_syncadapter_auth_summary">
         <intent
             android:action="android.provider.Settings.ACTION_SYNC_SETTINGS"
             android:targetPackage="com.myapp.android.syncadapter.ui"
             android:targetClass=".SyncAdapterSettingsActivity" />
     </PreferenceScreen>
 </PreferenceScreen>

extrait de journal:

01-14 14:34:34.270 E/AndroidRuntime( 6374): *** FATAL EXCEPTION IN SYSTEM PROCESS: android.server.ServerThread
01-14 14:34:34.270 E/AndroidRuntime( 6374): android.content.ActivityNotFoundException: Unable to find explicit activity class {com.myapp.android.syncadapter.ui/.SyncAdapterSettingsActivity}; have you declared this activity in your AndroidManifest.xml?
Était-ce utile?

La solution

Je l'ai! En gros, le package est le package racine et la classe cible est le nom complet.

     <intent
         android:action="android.provider.Settings.ACTION_SYNC_SETTINGS"
         android:targetPackage="com.myapp.android.syncadapter"
         android:targetClass="com.myapp.android.syncadapter.ui.SyncAdapterSettingsActivity" />

J'ai aussi dû vérifier soigneusement mon AndroidManifest être certain que les valeurs ainsi qu'ils orthographe pouvaient correspondre et que j'avais un filtre intention qui avait un sens pour l'activité à répondre.

Maintenant, je dois mettre en œuvre les paramètres de configuration activité et formater le résultat dans une intention correctement. Je sens une autre question venant de moi:)

Licencié sous: CC-BY-SA avec attribution
Non affilié à StackOverflow
scroll top