将文本设置到ListView中的特定位置上的TextView

问题描述:

我正在使用带有自定义Adapter的ListView。每行内有两个TextView。我只需要更改这些TextView的文本,仅用于我点击的文本视图。我怎样才能实现它?将文本设置到ListView中的特定位置上的TextView

我有我的CustomAdapter内的方法,我初始化TextView

public class MainListAdapter extends BaseAdapter { 

    private static final String TAG = "MainListAdapter"; 

    private Context mContext; 

    private LayoutInflater layoutInflater; 

    private MyViewPager itemViewPager; 

    private View viewMain; 

    private View viewSlide; 

    private TextView cancel; 

    private TextView delete, block; 

    TextView itemName, showResult; 

    int triedOnce; 

    private ArrayList<View> views; 

    private PagerAdapter pagerAdapter; 

    private ArrayList<String> mList; 

    public static final String API_KEY = "MYAPIKEY"; 

    public MainListAdapter(Context context, ArrayList<String> list) { 
     mContext = context; 

     layoutInflater = LayoutInflater.from(mContext); 
     mList = list; 
    } 

    @Override 
    public int getCount() { 
     return mList != null ? mList.size() : 0; 
    } 

    @Override 
    public Object getItem(int position) { 
     return mList != null ? mList.get(position) : null; 
    } 

    @Override 
    public long getItemId(int position) { 
     return position; 
    } 

    @Override 
    public View getView(int position, View convertView, ViewGroup parent) { 
     if (convertView == null) { 
      convertView = layoutInflater.inflate(R.layout.listview_item, null); 
     } 

     if(position%2 == 0){ 
      convertView.setBackgroundResource(R.drawable.lis_bg); 
     }else if(position%2 == 1){ 
      convertView.setBackgroundResource(R.drawable.ls_eppadi_bg); 
     } 

     viewMain = layoutInflater.inflate(R.layout.listview_item_main, null); 
     viewSlide = layoutInflater.inflate(R.layout.listview_item_slide, null); 

     cancel = (TextView)viewSlide.findViewById(R.id.tv_menu_cancel); 
     delete = (TextView)viewSlide.findViewById(R.id.tv_menu_delete); 
     block = (TextView) viewSlide.findViewById(R.id.tv_menu_block); 

     cancel.setOnClickListener(new OnClickListener() { 

       @Override 
       public void onClick(View v) { 
        //perform cancel 
       } 
      }); 

     delete.setOnClickListener(new OnClickListener() { 

       @Override 
       public void onClick(View v) { 
        //perform delete 
       } 
      }); 

     block.setOnClickListener(new OnClickListener() { 
       @Override 
       public void onClick(View v) { 
        //perform block 
       } 
      }); 

     views = new ArrayList<View>(); 
     views.add(viewMain); 
     views.add(viewSlide); 

     itemViewPager = (MyViewPager)convertView.findViewById(R.id.vp_list_item); 
     itemViewPager.setSelfIndex(position); 
     pagerAdapter = new PagerAdapter() { 

      @Override 
      public void destroyItem(ViewGroup container, int position, Object object) { 
       ((MyViewPager)container).removeView(views.get(position)); 
      } 

      @Override 
      public Object instantiateItem(ViewGroup container, int position) { 
       ((MyViewPager)container).addView(views.get(position)); 
       return views.get(position); 
      } 

      @Override 
      public boolean isViewFromObject(View arg0, Object arg1) { 
       return arg0 == arg1; 
      } 

      @Override 
      public int getCount() { 
       return views.size(); 
      } 
     }; 

     fillItemData(convertView, position, viewMain); 
     itemViewPager.setAdapter(pagerAdapter); 
     itemViewPager.setCurrentItem(0); 
     return convertView; 
    } 


    //this is where the textview's are initialised 
    private void fillItemData(View convertView, final int position, View viewMain) { 
     int[] colorCollection = { 
      R.color.green, R.color.royalblue, R.color.violet 
     }; 

     for (int i = 0; i < colorCollection.length; i++) { 
      colorCollection[i] = mContext.getResources().getColor(colorCollection[i]); 
     } 

     int currColor = colorCollection[position % colorCollection.length]; 

     itemName = (TextView)viewMain.findViewById(R.id.tv_item_name); 
     showResult = (TextView)viewMain.findViewById(R.id.tv_show); 

     itemName.setOnClickListener(new OnClickListener() { 
       @Override 
       public void onClick(View v) { 

        new PushTask().execute(position); 
        triedOnce = 0; 

       } 
     }); 

     itemName.setBackgroundColor(currColor); 
     showResult.setBackgroundColor(currColor); 

     itemName.setText(mList.get(position)); 
    } 

    class PushTask extends AsyncTask<Integer, Integer, Integer> { 


     @Override 
     protected void onPreExecute() { 
      itemName.setVisibility(View.GONE); 
      showResult.setVisibility(View.VISIBLE); 
      //set text here based on the position 
      showResult.setText("SENDING"); 
     } 

     @Override 
     protected Integer doInBackground(Integer... position) { 
      int post = position[0]; 
      int respCode = 0; 

      //perform my network operations 

      return respCode; 
     } 

     @Override 
     protected void onPostExecute(Integer response) { 
      switch(response) { 
       case 1: 
        //set text here 
        showResult.setText("SENT"); 
        Handler handler = new Handler(); 
        handler.postDelayed(new Runnable() { 
          @Override 
          public void run() { 
          showResult.setVisibility(View.GONE); 
          itemName.setVisibility(View.VISIBLE); 
          } 
          }, 2000); 
        break; 
       case 2: 
        //set text here 
        showResult.setText("PLEASE WAIT!"); 
        handler = new Handler(); 
        handler.postDelayed(new Runnable() { 
          @Override 
          public void run() { 
          showResult.setVisibility(View.GONE); 
          itemName.setVisibility(View.VISIBLE); 
          } 
          }, 2000); 
        break; 
       case 3: 
        //set text here 
        showResult.setText("FAILED!"); 
        handler = new Handler(); 
        handler.postDelayed(new Runnable() { 
          @Override 
          public void run() { 
          showResult.setVisibility(View.GONE); 
          itemName.setVisibility(View.VISIBLE); 
          } 
          }, 2000); 
        break; 
       case 4: 
        //set text here 
        showResult.setText("FAILED!"); 
        handler = new Handler(); 
        handler.postDelayed(new Runnable() { 
          @Override 
          public void run() { 
          showResult.setVisibility(View.GONE); 
          itemName.setVisibility(View.VISIBLE); 
          } 
          }, 2000); 
        break; 
       default: 
        break; 
      } 

     } 
    } 
} 

现在我需要改变itemNameshowResult“基于位置的用户点击其中s文本。 itemName.setOnClickListener有AsyncTask,我将改变这些textViews的文本。 目前它改变了listView的最后一行。

如何更改所选位置。

在此先感谢。

重写CustomAdapter的getView(...)函数,其中一个参数是int位置。

不要忘记使用convertView,支架和settag/gettag平滑滚动和正确引用

更新:

在getView地说:

convertView.setOnClickListener(new OnClickListener() { 
     @Override 
     public void onClick(View v) { 
      //perform update on textView here 
     } 
    }); 

我们还需要convertView参考在postExecute()中。您可以通过在AsycTask参数或适配器这一套参考的getter setter和获得asyctask postexecute()

+0

请看我的问题编辑并让我知道 –

+0

检查我的答案 – Kay

Pass View in Async Task and then convert into textView and SetText in DoInBackground Method. 

    new PushTask().execute(v); 


    @Override 
     protected Integer doInBackground(final View position) { 
    runOnUiThread(new Runnable() { 
        public void run() { 
         // some code #3 (Write your code here to run in UI thread) 
TextView txtName=(TextView)position; 
     txtname.setText(“android”): 
        } 
       }); 

    } 

创建一个模型(POJO)类第一 与两个字符串和一个布尔值,称之为点击参考asChecked 为其添加getter和setter

将值(列表数据)设置为您的arraylist并将setIsChecked值首次保持为false。这样

ArrayList<model> list = new ArrayList<model>(); 
list.add(new model("string1","string2",false); 
list.add(new model("string11","string22",false); 

现在onItemClickListener使用for循环这样

for(int i = 0 ; i < list.size; i++){ 
list.get(i).setIsChecked(false); 
} 
list.get(itemClickedPosition).setIsChecked(true); 
youradapter.notifyDataSetChanged(); 

现在来到适配器类在那里,只要你想不喜欢你可以设置所选择的TextView这

在getView方法做到这一点

if(list.get(position).getIsChecked()){ 
change your textview 
}else{ 
leave as it is 
} 

完成让我知道它是否可以帮助你