有一个Activity显示listItems(通过cursorAdapter)。
listItem的XML包含一些按钮。在Cursor Adapter的newView()
方法中,这些按钮获取onClickListener
,而不是匿名声明,有一个实现侦听器的类。如果单击某个按钮,则所有发生的活动应该完成。
在按钮类中调用finish()
不起作用我并不感到惊讶。 activityContext.finish
也不起作用。
那我该如何管理呢?
public class DetailActvityActionBtn implements View.OnClickListener {
private Context context;
@Override
public void onClick(View view){
context = view.getContext();
System.out.println("CONTEXT:" + context);
///Itemroot
LinearLayout root =(LinearLayout) view.getRootView().findViewById(R.id.detailRoot);
///Tag that stores data
ItemViewAndDataHolder holder = (ItemViewAndDataHolder) root.getTag();
System.out.println("HOLDER: " + holder.toString());
//Get id of item
int id = holder.getId();
//Get quantity of item
int quantity = Integer.parseInt(holder.getQuantity().getText().toString().replaceAll("[^0-9]",""));
///Append id to URI
Uri updateItemUri = ContentUris.withAppendedId(InventoryDB_Contract.entries.CONTENT_URI, id);
///To determine the clicked button, get ID as String
String btnIDasString = context.getResources().getResourceName(view.getId());
System.out.println(btnIDasString);
ContentValues values = new ContentValues();
int updatedRow;
switch (btnIDasString){
case "com.example.android.inventoryapp:id/plusBtn":
System.out.println("plus");
values.put(InventoryDB_Contract.entries.COLUMN_PRODUCT_QUANTITY_IN_STOCK, quantity + 1);
context.getContentResolver().update(updateItemUri, values, null, null);
//CRcaller.saleItem(1);
break;
case "com.example.android.inventoryapp:id/minusBtn":
System.out.println("mins");
values.put(InventoryDB_Contract.entries.COLUMN_PRODUCT_QUANTITY_IN_STOCK, quantity - 1);
updatedRow = context.getContentResolver().update(updateItemUri, values, null, null);
break;
case "com.example.android.inventoryapp:id/deleteItemBtn":
System.out.println("delete");
context.getContentResolver().delete(updateItemUri, null, null);
context.finish();
break;
}
}
}
答案 0 :(得分:1)
public class DetailActvityActionBtn implements View.OnClickListener
您没有延伸Activity
或Fragment
或其他任何内容,您没有上下文来执行context.finish();
,因为finish()
是来自{{1}的方法}。
如果从Activity
使用此类,则将该活动的引用传递给类构造函数,如下所示:
Activity
public MainActivity extends Activity{
//You standard onCreate() blah...
DetailActvityActionBtn yourHandlerClass = new DetailActvityActionBtn(this);
}
答案 1 :(得分:1)
将您的活动上下文强制转换为活动。然后调用完成方法
Activity act=(Activity)context;
act.finish();
答案 2 :(得分:0)
就个人而言,我建议将按钮与依赖活动的依赖性脱钩。而不是在Button类中设置onClick的功能,为什么不在控制器中定义功能(Activity)?您可以定义一个onClick方法并使用listview逻辑来确定哪些按钮应具有此功能。
如果您只是简单地控制业务逻辑,那么我个人认为让视图定义控制器生命周期令人费解。控制器可以允许按钮自行解除,但任何其他方式和按钮开始与它可能不应该的东西交谈。也许你正在遵循与MVC不同的范例,所以我可能错了!
我正在思考以下几点:
@Override
public View getView(int position, View v, ViewGroup parent) {
if(condition1){
v.button.setOnClickListener(locallyDefinedOnClickForCondition1);
}
else if(condition2){
v.button.setOnClickListener(locallyDefinedOnClickForCondition2);
}
}
绝对不会说它是最好的解决方案,但也许这可能会让你朝着正确的方向前进。有人有任何批评吗?