2012-10-17 20 views
5

Zajmuję się tworzeniem aplikacji SMS i potrzebuję wymieniać wiadomości SMS. Znalazłem problem podczas próby uzyskania dostępu do dostawcy treści przy użyciu URI content://mms-sms/conversations/. To działa dobrze na Androida 2.3, ale gdy uruchomić na Androidzie 4.0.3 Samsung Galaxy Tab 2 zwróci błąd:treść: // mms-sms/rozmowy/zwrot NullPointerException na Androidzie ICS Samsung

10-17 09:04:51.035: E/AndroidRuntime(22600): FATAL EXCEPTION: main 
10-17 09:04:51.035: E/AndroidRuntime(22600): 
java.lang.RuntimeException: Unable to start activity 
ComponentInfo{com.yooi/com.yooi.ui.MainActivity}: 
android.view.InflateException: Binary XML file line #6: Error 
inflating class fragment 10-17 09:04:51.035: E/AndroidRuntime(22600): 
    at 
android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1970) 
10-17 09:04:51.035: E/AndroidRuntime(22600): at 
android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1995) 
10-17 09:04:51.035: E/AndroidRuntime(22600): at 
android.app.ActivityThread.access$600(ActivityThread.java:128) 10-17 
09:04:51.035: E/AndroidRuntime(22600):  at 
android.app.ActivityThread$H.handleMessage(ActivityThread.java:1161) 
10-17 09:04:51.035: E/AndroidRuntime(22600): at 
android.os.Handler.dispatchMessage(Handler.java:99) 10-17 
09:04:51.035: E/AndroidRuntime(22600):  at 
android.os.Looper.loop(Looper.java:137) 10-17 09:04:51.035: 
E/AndroidRuntime(22600): at 
android.app.ActivityThread.main(ActivityThread.java:4514) 10-17 
09:04:51.035: E/AndroidRuntime(22600):  at 
java.lang.reflect.Method.invokeNative(Native Method) 10-17 
09:04:51.035: E/AndroidRuntime(22600):  at 
java.lang.reflect.Method.invoke(Method.java:511) 10-17 09:04:51.035: 
E/AndroidRuntime(22600): at 
com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:790) 
10-17 09:04:51.035: E/AndroidRuntime(22600): at 
com.android.internal.os.ZygoteInit.main(ZygoteInit.java:557) 10-17 
09:04:51.035: E/AndroidRuntime(22600):  at 
dalvik.system.NativeStart.main(Native Method) 10-17 09:04:51.035: 
E/AndroidRuntime(22600): Caused by: android.view.InflateException: 
Binary XML file line #6: Error inflating class fragment 10-17 
09:04:51.035: E/AndroidRuntime(22600):  at 
android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:697) 
10-17 09:04:51.035: E/AndroidRuntime(22600): at 
android.view.LayoutInflater.rInflate(LayoutInflater.java:739) 10-17 
09:04:51.035: E/AndroidRuntime(22600):  at 
android.view.LayoutInflater.inflate(LayoutInflater.java:489) 10-17 
09:04:51.035: E/AndroidRuntime(22600):  at 
android.view.LayoutInflater.inflate(LayoutInflater.java:396) 10-17 
09:04:51.035: E/AndroidRuntime(22600):  at 
android.view.LayoutInflater.inflate(LayoutInflater.java:352) 10-17 
09:04:51.035: E/AndroidRuntime(22600):  at 
com.android.internal.policy.impl.PhoneWindow.setContentView(PhoneWindow.java:273) 
10-17 09:04:51.035: E/AndroidRuntime(22600): at 
android.app.Activity.setContentView(Activity.java:1835) 10-17 
09:04:51.035: E/AndroidRuntime(22600):  at 
com.yooi.ui.MainActivity.onCreate(MainActivity.java:17) 10-17 
09:04:51.035: E/AndroidRuntime(22600):  at 
android.app.Activity.performCreate(Activity.java:4465) 10-17 
09:04:51.035: E/AndroidRuntime(22600):  at 
android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1053) 
10-17 09:04:51.035: E/AndroidRuntime(22600): at 
android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1934) 
10-17 09:04:51.035: E/AndroidRuntime(22600): ... 11 more 10-17 
09:04:51.035: E/AndroidRuntime(22600): Caused by: 
java.lang.NullPointerException 10-17 09:04:51.035: 
E/AndroidRuntime(22600): at 
android.os.Parcel.readException(Parcel.java:1334) 10-17 09:04:51.035: 
E/AndroidRuntime(22600): at 
android.database.DatabaseUtils.readExceptionFromParcel(DatabaseUtils.java:181) 
10-17 09:04:51.035: E/AndroidRuntime(22600): at 
android.database.DatabaseUtils.readExceptionFromParcel(DatabaseUtils.java:135) 
10-17 09:04:51.035: E/AndroidRuntime(22600): at 
android.content.ContentProviderProxy.query(ContentProviderNative.java:358) 
10-17 09:04:51.035: E/AndroidRuntime(22600): at 
android.content.ContentResolver.query(ContentResolver.java:311) 10-17 
09:04:51.035: E/AndroidRuntime(22600):  at 
com.yooi.ui.SmsThreadListActivity.getThreadListCursor(SmsThreadListActivity.java:146) 
10-17 09:04:51.035: E/AndroidRuntime(22600): at 
com.yooi.ui.SmsThreadListActivity.onCreateView(SmsThreadListActivity.java:95) 
10-17 09:04:51.035: E/AndroidRuntime(22600): at 
android.app.FragmentManagerImpl.moveToState(FragmentManager.java:806) 
10-17 09:04:51.035: E/AndroidRuntime(22600): at 
android.app.FragmentManagerImpl.moveToState(FragmentManager.java:1010) 
10-17 09:04:51.035: E/AndroidRuntime(22600): at 
android.app.FragmentManagerImpl.addFragment(FragmentManager.java:1108) 
10-17 09:04:51.035: E/AndroidRuntime(22600): at 
android.app.Activity.onCreateView(Activity.java:4243) 10-17 
09:04:51.035: E/AndroidRuntime(22600):  at 
android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:673) 
10-17 09:04:51.035: E/AndroidRuntime(22600): ... 21 more 

ja wydano moich poszukiwań razem na google, ale nadal nie znalazłem odpowiedzi. Każdy, kto wie, proszę mi pomóc, utknąłem za ten przykry problem :(

+0

Wydaje się, że zmiana nazwy URI na ścieżce Samsung 2 galaktyki Mój kod działa poprawnie na NexusS z 4.1.2 Ponieważ bezpośredni dostawca dostępu do wiadomości nie jest publicznym sdk, więc musisz z nim wytrzymać Root lub spróbuj znaleźć prawdziwą ścieżkę 'msssms.db' –

+2

Uwaga: Nigdy nie powinieneś * polegać * na 'content: // sms' lub czymkolwiek podobnym, ponieważ ich zachowanie nie jest udokumentowane i dlatego może być zmienione lub usunięte między urządzeniami lub wersjami. – Eric

+0

Dzięki Eric, ale jest to jedyny sposób, aby uzyskać dostęp do bazy danych SMS w tej chwili, prawda? Ścieżka uri działa poprawnie po dodaniu threadID, takich jak: 'content: // mms-sms/conversations/xxx', ale staje się wskaźnikiem pustym, gdy nie ma identyfikatora threadID wspomniana – Jevrier

Odpowiedz

5

Lista rozmów mogą być pobierane za pośrednictwem tego zapytania.

Uri.parse("content://mms-sms/conversations?simple=true"); 
Cursor cursor = context.getApplicationContext().getContentResolver().query(uri, null, null, null, null); 

Keypoint Oto URI content://mms-sms/conversations?simple=true

Look here

+0

Kiedy uruchomię to zapytanie w wersji 4.0 nadrzędnej, zwróci ona tylko 11 kolumn [_id, date, message_count, readcount, recipient_ids, snippet, snippet_cs, read, type, error, has_attachment, status] Potrzebuję thread_id, który dostaję łatwo na działająca treść: // mms-sms/rozmowy/to zapytanie w wersji 2.3.6 systemu operacyjnego, czy możesz mi powiedzieć, co należy zrobić, aby uzyskać pełną kolumnę powyżej 4,0, dzięki za twój problem. –

+1

@kamal_tech_view '_id' to 'thread_id' :) – barmaley

+0

dziękuję Mam to i rozwiązuję też mój problem ... –

Powiązane problemy