我必须在列表视图上执行单击,在onItemClick中我获取所选视图的位图。当我手动点击它的工作时,但当我以编程方式执行单击时,视图的高度等于0。 这是我的代码片段
listMedic.performItemClick(
getViewByPosition(position), position, adapter.getItemId(position));
public void onItemClick(AdapterView<?> parent, View v, int position, long id) {
ListElement elem = (ListElement) listMedic.getItemAtPosition(position);
try {
QuantityPopUp quantityPopUp = new QuantityPopUp(context);
quantityPopUp.setImageAndPosition(getBitMapOfView(v), v, this, getResources().getString(R.string.valid_q_text_bt));
quantityPopUp.setQuantity(Float.parseFloat(elem.getqDonn().replace(',', '.')));
quantityPopUp.setListElementAdapter((ListElementAdapter) listMedic.getAdapter());
quantityPopUp.setIndex(position);
contentLayout.addView(quantityPopUp);
popUpI = quantityPopUp;
darkenView();
} catch (NullPointerException e) {
}
}
private Bitmap getBitMapOfView(View v){
//récupérer la vue en tant que bitmap
v.setDrawingCacheEnabled(true);
v.buildDrawingCache();
return Bitmap.createBitmap(v.getDrawingCache(true));
}
public View getViewByPosition(int pos) {
final int firstListItemPosition = listMedic.getFirstVisiblePosition();
final int lastListItemPosition = firstListItemPosition + listMedic.getChildCount() - 1;
if (pos < firstListItemPosition || pos > lastListItemPosition ) {
return listMedic.getAdapter().getView(pos, null, listMedic);
} else {
final int childIndex = pos - firstListItemPosition;
return listMedic.getChildAt(childIndex);
}
}
@Override
public View getView(int position, View convertView, ViewGroup parent) {
if (convertView == null) {
convertView = LayoutInflater.from(getContext()).inflate(R.layout.list_element_layout, parent, false);
}
// récupérer l'item par sa position dans la vue
ListElement listElement = getItem(position);
//récupérer les éléments à remplir
LinearLayout listElementLayout = (LinearLayout) convertView.findViewById(R.id.listElementLayout);
TextView denomMedic = (TextView) convertView.findViewById(R.id.denomMedic);
TextView denom2Medic = (TextView) convertView.findViewById(R.id.denom2Medic);
TextView qPres = (TextView) convertView.findViewById(R.id.qPres);
TextView qDonn = (TextView) convertView.findViewById(R.id.qDonn);
ImageView compIcon = (ImageView) convertView.findViewById(R.id.compIcon);
//définir un touch listener pour afficher l'historique
listElementLayout.setTag(position);
//remplir les elements avec les informations
denomMedic.setText(listElement.getDenomMedic());
denom2Medic.setText(listElement.getDenom2Medic());
qPres.setText(listElement.getqPres());
qDonn.setText(listElement.getqDonn());
compIcon.setImageDrawable(listElement.getIconBac());
//retourner l'élément construit
return convertView;
}
答案 0 :(得分:0)
问题的根本原因在于,在某些情况下,您尝试从View
获取一个从未布局和测量过的位图。
当您通过直接致电getViewByPosition()
在getView()
中获取视图时会发生这种情况。除非你有充分的理由,否则不建议从这样的列表中获取视图。
要解决您的问题,您有两种选择:
1)修复您的getViewByPosition()
以返回已经过测量并准备好绘制到位图的视图(此答案可以帮助您:Converting a view to Bitmap without displaying it in Android?)。
2)只对已经绘制的视图调用getBitMapOfView()
。
答案 1 :(得分:0)
我在Doron Yakovlev-Golani的帮助下找到答案。我实际上添加了一个休眠时间的Thread()。我不知道这是否是最好的答案,但它确实有效。
new Thread(new Runnable() {
@Override
public void run() {
try {
Thread.sleep(500);
runOnUiThread(new Runnable() {
@Override
public void run() {
try {
listMedic.performItemClick(
getViewByPosition(position), position, adapter.getItemId(position));
} catch (NullPointerException e) {
e.printStackTrace();
}
}
});
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}).start();