在OnClickListener内部,我不能访问作用域“外部”的大多数变量,如下所示:
findViewById(R.id.Button01).setOnClickListener(new OnClickListener()
{
@Override
public void onClick(View v)
{
Intent mainApps = new Intent(Intent.ACTION_MAIN);
mainApps.addCategory(Intent.CATEGORY_LAUNCHER);
List<ActivityInfo> activities = this.getPackageManager().queryIntentActivities(mainApps, 0);
/*
Intent intent = new Intent("com.sygic.drive/com.sygic/drive/.SygicDriveActivity");
startActivity(intent);*/
}
});
在本例中,我需要获取PacketManager,但由于在OnClickListener中没有可用的上下文,因此无法获取它。
我可以在外面做一个静态引用,然后在里面使用它,但是这样做正确吗?一直这样做看起来很奇怪吗?
发布于 2010-01-16 23:21:25
将代码中的this
替换为MyActivity.this
,其中MyActivity是Activity子类的类名。
说明:当您使用这部分代码时,您正在创建一个匿名内部类:
new OnClickListener() {
匿名内部类具有对创建它们的类的实例的引用。看起来您是在Activity子类中创建它,因为findViewById是一个Activity方法。Activity是一个上下文,所以您需要做的就是使用自动拥有的对它的引用。
发布于 2010-01-17 03:09:33
您还可以在类中实现OnClickListener接口,从而避免对匿名内部类的需要。然后,您可以像这样设置单击侦听器:
findViewById(R.id.Button01).setOnClickListener(this);
如果有多个按钮使用一个侦听器,则可以使用带有view.getId() (对应于R.id中的视图id )的switch语句来区分它们。
发布于 2010-01-16 11:19:59
您可以做一些事情,您可以创建一个实现onClickListener的内部类,并将必要的参数传递给该类的构造函数。我仍然不认为这是最干净的方法。我通常只是创建另一个方法来执行我的操作。所以在onClick(View v)中,我会这样做。
onClick(View v){doMyAction(myParams)}
private void doMyAction(Object params){//do stuff}
并将所需的参数从侦听器方法传递到侦听器外部的方法。
https://stackoverflow.com/questions/2076037
复制相似问题