我是初学者,我正在开发一个应用,我想在添加新联系人时收到通知。 我尝试了下面的代码但是我遇到了错误,如下面的Logcat跟踪。
我的另一个问题是,一旦我从我的应用程序注册了我的ContentObserver,即使用户退出我的应用程序,或者我应该在服务中编写它并在后台运行它,它也会得到通知。 Plz帮助
public class B extends ContentObserver {
Context ctx;
String ContactId,DisplayName;
final String[] projection = new String[] { ContactsContract.Contacts._ID};
Cursor curval,people;
private static final String TAG = "NewContactTrackService";
@Override
public boolean deliverSelfNotifications() {
// TODO Auto-generated method stub
Log.e(TAG, "Self notification called");
return true;
}
@Override
public void onChange(boolean selfChange) {
// TODO Auto-generated method stub
//super.onChange(selfChange);
Log.e(TAG, "Onchange Called");
people = ctx.getContentResolver().query(ContactsContract.Contacts.CONTENT_URI, null, null, null, null);
while(people.moveToNext())
{
// values.clear();
ContactId = people.getString(people.getColumnIndex(ContactsContract.Contacts._ID));
DisplayName = people.getString(people.getColumnIndex(ContactsContract.Contacts.DISPLAY_NAME));
Log.e(TAG, "New Contact with contact id "+ContactId);
Log.e(TAG, "New Contact Displayname "+DisplayName);
}
}
public B(Handler handler) {
super(handler);
Log.e(TAG, "Handler Called");
// TODO Auto-generated constructor stub
}
public void register(Context ctx)
{
Log.e(TAG, "Registering");
this.ctx=ctx;
curval = ctx.getContentResolver().query(ContactsContract.Contacts.CONTENT_URI, projection, null, null, null);
curval.registerContentObserver(new B(new Handler()));
Log.e(TAG, "Registered");
}
}
这是我创建了上述类
的对象的示例活动public class TrackContactActivity extends Activity {
/** Called when the activity is first created. */
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
B obj=new B(new Handler());
obj.register(getApplicationContext());
}
}
Logcat Trace:
02-29 20:59:59.571: ERROR/AndroidRuntime(324): ERROR: thread attach failed
02-29 20:59:59.951: ERROR/NewContactTrackService(330): Handler Called
02-29 20:59:59.951: ERROR/NewContactTrackService(330): Registering
02-29 21:00:00.050: ERROR/NewContactTrackService(330): Handler Called
02-29 21:00:00.050: ERROR/NewContactTrackService(330): Registered
02-29 21:01:35.270: ERROR/NewContactTrackService(330): Onchange Called
02-29 21:01:35.281: ERROR/AndroidRuntime(330): Uncaught handler: thread main exiting due to uncaught exception
02-29 21:01:35.281: ERROR/AndroidRuntime(330): java.lang.NullPointerException
02-29 21:01:35.281: ERROR/AndroidRuntime(330): at com.sample.B.onChange(B.java:29)
02-29 21:01:35.281: ERROR/AndroidRuntime(330): at android.database.ContentObserver$NotificationRunnable.run(ContentObserver.java:43)
02-29 21:01:35.281: ERROR/AndroidRuntime(330): at android.os.Handler.handleCallback(Handler.java:587)
02-29 21:01:35.281: ERROR/AndroidRuntime(330): at android.os.Handler.dispatchMessage(Handler.java:92)
02-29 21:01:35.281: ERROR/AndroidRuntime(330): at android.os.Looper.loop(Looper.java:123)
02-29 21:01:35.281: ERROR/AndroidRuntime(330): at android.app.ActivityThread.main(ActivityThread.java:4363)
02-29 21:01:35.281: ERROR/AndroidRuntime(330): at java.lang.reflect.Method.invokeNative(Native Method)
02-29 21:01:35.281: ERROR/AndroidRuntime(330): at java.lang.reflect.Method.invoke(Method.java:521)
02-29 21:01:35.281: ERROR/AndroidRuntime(330): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:860)
02-29 21:01:35.281: ERROR/AndroidRuntime(330): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:618)
02-29 21:01:35.281: ERROR/AndroidRuntime(330): at dalvik.system.NativeStart.main(Native Method)
02-29 21:01:35.361: ERROR/dalvikvm(330): Unable to open stack trace file '/data/anr/traces.txt': Permission denied
02-29 21:01:38.641: ERROR/gralloc(65): [unregister] handle 0x3236c0 still locked (state=40000001)
答案 0 :(得分:0)
尝试更改以下行
Context ctx;
与
static Context ctx;
它会起作用。
更好的解决方案是尝试在注册方法中传递应用程序上下文。