在ListView上执行ClickClick返回高度等于0的视图(Android)

时间:2017-04-05 13:51:56

标签: android listview onitemclick

我必须在列表视图上执行单击,在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;
}

2 个答案:

答案 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();