2012-10-17 67 views
5

我正在開發短信應用程序,並需要列出短信對話。嘗試使用uri content://mms-sms/conversations/訪問內容提供商時發現問題。它運行良好,在Android 2.3,但是當在Android上運行4.0.3三星Galaxy Tab 2也返回錯誤:內容:// mms-sms /對話/返回NullPointerException在Android ICS三星

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 

我一直花了我的時間搜索是在谷歌,但仍然沒有找到答案。任何人誰知道請幫幫我,我堅持了這個惱人的問題:(

+0

看起來'Samsung galaxy tab 2'改變了URI路徑,我的代碼在運行4.1.2的NexusS上運行良好,因爲直接訪問消息傳遞提供程序不是公共sdk,所以你必須忍受它,根或試圖找到真正的路徑'msssms.db' –

+2

只是一個說明:你不應該*依賴*內容://短信或任何類似的行爲沒有記錄,因此可能會改變或刪除設備或版本之間。 – Eric

+0

感謝Eric,但它是現在訪問SMS數據庫的唯一方式,對嗎?當我添加threadID如:content:// mms-sms/conversations/xxx'時,uri路徑工作正常,但當沒有提到threadID時,它會變成空指針 – Jevrier

回答

5

會話列表可以通過這個查詢檢索:

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

關鍵點這裏的URI content://mms-sms/conversations?simple=true

here

+0

當我在4.0操作系統版本上運行這個查詢時,它只返回11列[_id,date,message_count,readcount,recipient_ids,snippet,snippet_cs,read,type,error,has_attachment,status]我需要thread_id,運行內容:// mms-sms /對話/ 2.3.6操作系統版本上的這個查詢,你能告訴我需要做什麼才能得到高於4.0的完整列謝謝你的關注.. –

+1

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

+0

謝謝我解決了我的問題... –

相關問題