Android:在listview问题中设置图像的可见性

时间:2011-08-31 09:12:15

标签: android listview hidden visible

我有一个列表视图并显示具有图像数量的凸轮图像。我的代码如下:

           TextView imageCountview = (TextView) row.findViewById(R.id.TextViewImageCount); ;
            //checking whether count is zero, if so hiding both image and count
            if(ImageCount.equals("0")){
                imageCountview.setVisibility(8);
                ImageView camimage = (ImageView) row.findViewById(R.id.imageViewlistcam);
                camimage.setVisibility(8);
            }
            else{
                imageCountview.setText(ImageCount);
            }

现在我的问题是,当加载列表时,每次扫描都很好,并且当计数大于零时显示图像。现在我继续向listview添加更多元素,直到它生成滚动条。问题现在开始

当我向上滚动时,部分列表元素位于屏幕后面,这是预期的行为。当我向下滚动凸轮时,即使之前显示过,图像也会消失。它在列表中的表现非常出色。我在这里错过了什么?有人可以帮我吗。

感谢您提前的时间。

我的适配器

class MyIncidentAdapter extends ArrayAdapter{

        public MyIncidentAdapter(Context context, int textViewResourceId,
                ArrayList<String> dbResults) {
            super(context, textViewResourceId, dbResults);
        }

        @Override
        public View getView(int position, View convertView, ViewGroup parent) {
            View row = convertView;
            if (row == null) {
                LayoutInflater inflater = getLayoutInflater();
                row = inflater.inflate(R.layout.row_incident, parent, false);
            }

            TextView incidentID = (TextView) row.findViewById(R.id.label_incident);
            incidentID.setText((db_results.get(position)).toString());

            String Final = null;
            String ImageCount = "0";
            String VideoCount = "0";
            String RecordingCount="0";
            //getting image count
            SQLiteDatabase db10;
            db10 = openOrCreateDatabase("filestore", MODE_PRIVATE, null);
            Cursor cursor = db10.rawQuery(
                    "SELECT count(urls) as numbers FROM files where incident_id='"+((db_results.get(position)).toString())+"'", null);
            while (cursor.moveToNext()) {
                ImageCount = String.valueOf(cursor.getString(cursor
                        .getColumnIndex("numbers")));
            }
            cursor.close();

            //getting video
            Cursor cursor1 = db10.rawQuery(
                    "SELECT count(urls) as numbers FROM videos where incident_id='"+((db_results.get(position)).toString())+"'", null);
            while (cursor1.moveToNext()) {
                VideoCount = String.valueOf(cursor1.getString(cursor1
                        .getColumnIndex("numbers")));
            }
            cursor1.close();

            //getting audio count
            Cursor cursor11 = db10.rawQuery(
                    "SELECT count(urls) as numbers FROM audios where incident_id='"+((db_results.get(position)).toString())+"'", null);
            while (cursor11.moveToNext()) {
                RecordingCount = String.valueOf(cursor11.getString(cursor11
                        .getColumnIndex("numbers")));
            }
            cursor11.close();



            //Final = "Image:"+ImageCount+ "      Video:"+VideoCount+ "      Audio:"+RecordingCount;
            //TextView countinfo = (TextView) row.findViewById(R.id.textViewCount);
            //countinfo.setText(Final);

            TextView imageCountview = (TextView) row.findViewById(R.id.TextViewImageCount); ;
            //checking whether count is zero, if so hiding both image and count
            if(ImageCount.equals("0")){
                imageCountview.setVisibility(8);
                ImageView camimage = (ImageView) row.findViewById(R.id.imageViewlistcam);
                camimage.setVisibility(8);
            }
            else{
                imageCountview.setText(ImageCount);
            }


            TextView videoCountview = (TextView) row.findViewById(R.id.textViewVideoCount);
            if(VideoCount.equals("0")){
                videoCountview.setVisibility(8);
                ImageView imgvid = (ImageView)row.findViewById(R.id.imageViewlistvid);
                imgvid.setVisibility(8);
            }
            else{
                videoCountview.setText(VideoCount);
            }


            TextView audioCountview = (TextView) row.findViewById(R.id.textViewAudioCount);
            if(RecordingCount.equals("0")){
                audioCountview.setVisibility(8);
                ImageView audioimg = (ImageView)row.findViewById(R.id.imageViewlistaud);
                audioimg.setVisibility(8);
            }
            else{
                audioCountview.setText(RecordingCount);
            }

            String InsDate=null;
            Cursor cursor111 = db10.rawQuery(
                    "SELECT incident_date FROM incident where incident_id='"+((db_results.get(position)).toString())+"'", null);
            while (cursor111.moveToNext()) {
                InsDate = String.valueOf(cursor111.getString(cursor111
                        .getColumnIndex("incident_date")));
            }
            cursor111.close();

            TextView incidentDate = (TextView) row.findViewById(R.id.label_date);
            incidentDate.setText(InsDate);

            Cursor cursor1111 = db10.rawQuery(
                    "SELECT description FROM incident where incident_id='"+((db_results.get(position)).toString())+"'", null);
            while (cursor1111.moveToNext()) {
                description = String.valueOf(cursor1111.getString(cursor1111
                        .getColumnIndex("description")));
            }
            cursor1111.close();
            db10.close();
            TextView incidentDesc = (TextView) row.findViewById(R.id.label_des);


            if(description.equals(" ")){
                incidentDesc.setVisibility(8);
            }
            else{
                incidentDesc.setText(description.trim());
            }



            return row;
        }

2 个答案:

答案 0 :(得分:1)

在父参数中传递null以充气api。

row = inflater.inflate(R.layout.row_incident, null, false);

答案 1 :(得分:0)

这个quesiton的答案。简单,我必须再次显示我使用setvisibility方法隐藏。