編輯:關於Android編程
package com.example.listdelectdemo;
import java.util.ArrayList;
import android.content.Context;
import android.view.LayoutInflater;
import android.view.View;
import android.view.View.OnClickListener;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.Button;
import android.widget.TextView;
import android.widget.Toast;
public class MyDataAdapter extends BaseAdapter {
private Context mContext;
private ArrayList<String> mStrings;
private LayoutInflater mInflater;
private String mStrData;
public MyDataAdapter(Context c, ArrayList<String> s) {
mContext = c;
mStrings = s;
mInflater = LayoutInflater.from(c);
}
@Override
public int getCount() {
return mStrings.size();
}
@Override
public Object getItem(int position) {
return mStrings.get(position);
}
@Override
public long getItemId(int position) {
return position;
}
@Override
public View getView(int position, View convertView, ViewGroup parent) {
MyViewHolder viewHolder = null;
if (convertView == null) {
convertView = mInflater.inflate(R.layout.item, null);
viewHolder = new MyViewHolder();
viewHolder.item_button_test = (Button) convertView.findViewById(R.id.item_button_test);
viewHolder.item_textView_content = (TextView) convertView.findViewById(R.id.item_textView_content);
convertView.setTag(viewHolder);
} else {
viewHolder = (MyViewHolder) convertView.getTag();
}
//這裡拿出來數據集合裡的當前這一項mStrData
mStrData = mStrings.get(position);
viewHolder.item_textView_content.setText(mStrData);
viewHolder.item_button_test.setText("點擊");
//這裡給item的button設置了點擊監聽事件
viewHolder.item_button_test.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
//這裡toast出來的mStrData卻不是點擊的那一項
Toast.makeText(mContext, "您點擊了-" + mStrData, Toast.LENGTH_LONG).show();
}
});
return convertView;
}
class MyViewHolder {
TextView item_textView_content;
Button item_button_test;
}
}
然後,我們分析一下原因,相信老程序員都可以看出問題的所在: mStrData = mStrings.get(position); getView方法第一次被調用的時候,將集合中的當前項數據拿出來付給了成員變量mStrData,程序繼續往下執行:
viewHolder.item_button_test.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
//這裡toast出來的mStrData卻不是點擊的那一項
Toast.makeText(mContext, "您點擊了-" + mStrData, Toast.LENGTH_LONG).show();
}
});
這裡給item的按鈕添加了監聽事件,但是要注意:程序並不會回調監聽事件中的
@Override
public void onClick(View v) {
//這裡toast出來的mStrData卻不是點擊的那一項
Toast.makeText(mContext, "您點擊了-" + mStrData, Toast.LENGTH_LONG).show();
}
而是會繼續回調getView方法。 等到列表即將被加載完成,也就是最後一次回調getView方法時,成員變量mStrData會被最後一次賦值, 那麼,getView方法每回調一次,mStrData的值就會被重新賦一次。 然後,當我們點擊按鈕,就會回調監聽的onClick方法,這時候執行toast: 1 Toast.makeText(mContext, "您點擊了-" + mStrData, Toast.LENGTH_LONG).show(); 此時的mStrData就是只能是最後一次賦的值了,出錯就是必然的。 那麼,來看一下我的解決方法:
package com.example.listdelectdemo;
import java.util.ArrayList;
import android.content.Context;
import android.view.LayoutInflater;
import android.view.View;
import android.view.View.OnClickListener;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.Button;
import android.widget.TextView;
import android.widget.Toast;
public class MyDataAdapter extends BaseAdapter {
private Context mContext;
private ArrayList<String> mStrings;
private LayoutInflater mInflater;
private String mStrData;
public MyDataAdapter(Context c, ArrayList<String> s) {
mContext = c;
mStrings = s;
mInflater = LayoutInflater.from(c);
}
@Override
public int getCount() {
return mStrings.size();
}
@Override
public Object getItem(int position) {
return mStrings.get(position);
}
@Override
public long getItemId(int position) {
return position;
}
@Override
public View getView(int position, View convertView, ViewGroup parent) {
MyViewHolder viewHolder = null;
if (convertView == null) {
convertView = mInflater.inflate(R.layout.item, null);
viewHolder = new MyViewHolder();
viewHolder.item_button_test = (Button) convertView.findViewById(R.id.item_button_test);
viewHolder.item_textView_content = (TextView) convertView.findViewById(R.id.item_textView_content);
convertView.setTag(viewHolder);
} else {
viewHolder = (MyViewHolder) convertView.getTag();
}
mStrData = mStrings.get(position);
viewHolder.item_textView_content.setText(mStrData);
viewHolder.item_button_test.setText("點擊");
// 給item的按鈕設置點擊監聽,創建一個監聽的實現類,並傳入當前的position
viewHolder.item_button_test.setOnClickListener(new MyAdapterListener(position));
return convertView;
}
class MyViewHolder {
TextView item_textView_content;
Button item_button_test;
}
class MyAdapterListener implements OnClickListener {
private int position;
public MyAdapterListener(int pos) {
position = pos;
}
@Override
public void onClick(View v) {
Toast.makeText(mContext, "您點擊了-" + mStrings.get(position), Toast.LENGTH_LONG).show();
}
}
}
這時候就不會出現問題。不同的地方就在於給item的button添加點擊事件的時候是每次都創建一個新的MyAdapterListener對象來實現這個監聽。那麼在new這個MyAdapterListener對象的時候給他傳入一個position做為標記,這樣每一個item都會有一個屬於自己的監聽類,我們就可以在這個監聽類中做一些自己的邏輯處理,就不會出現錯亂的問題。 這個方案只能作為一個參考方案,有一個弊端就是在列表數據多的時候,會創建很多新的對象,而占用內存。那麼大家有什麼更好的方案可以分享分享。
Android-自定義View(1)
前言已經好長時間沒更新博客了,今天給大家帶來一個橫向滾動的菜單,用的是HorizontalScrollView,但HorizontalScrollView不能在滾動時定位
Android 中 ViewFlipper 的簡單實例
main.xml Main.javapackage com.wty.mydemoviewflipper;import android.app.Activity;im
android 路徑動畫制作
1、前言 今天項目要用到一個類似微信發送麼麼哒,那種屏幕飄表情的功能,所以分析研究了一下,用到的技術應該是路徑動畫,不知道這樣就正不正確,反正就是畫一個路徑線,然後對象根
android 中TextView設置部分文字背景色和文字顏色
通過SpannableStringBuilder來實現,它就像html裡邊的元素改變指定文字的文字顏色或背景色public class MainActivity exte