區域性重新整理ListView,實現點贊功能
這是我要用的ListView的item。要給ListView設定單個重新整理,實現點選事件。
1.佈局 (不要問我為什麼是絕對佈局,,我開心)
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="#ffffff"
android:orientation="vertical" >
<AbsoluteLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
>
<TextView
android:id="@+id/username"
android:layout_width="350px"
android:layout_height="40px"
android:layout_x="110px"
android:layout_y="25px"
android:text="使用者名稱"
android:textSize="30px"
android:gravity="bottom"
android:textColor="#000000"
></TextView>
<!-- 要用的點贊 icon_comments_praise_un這是一個點讚的圖片-->
<ImageView
android:id = "@+id/image_praise"
android:layout_width ="30px"
android:layout_height = "30px"
android:layout_y = "30px"
android:layout_x = "500px"
android:scaleType="fitXY"
android:src="@drawable/icon_comments_praise_un"
></ImageView>
</AbsoluteLayout>
</LinearLayout>
2.老樣子,在你的Adapter裡面老樣子寫就是啦。
public class CommentAdapter extends BaseAdapter {
private Context context;
private ArrayList<CommentItem> items;
public CommentAdapter(Context context, ArrayList<CommentItem> items) {
this.context = context;
this.items = items;
}
@Override
public int getCount() {
return items.size();
}
@Override
public Object getItem(int position) {
return null;
}
@Override
public long getItemId(int position) {
return 0;
}
@Override
public View getView(final int position, View convertView, ViewGroup parent) {
ViewHolder holder = null;
if (convertView == null) {
holder = new ViewHolder();
convertView = LayoutInflater.from(context).inflate(R.layout.mymessage_item, null);
holder.image_praise = (ImageView) convertView.findViewById(R.id.image_praise);
convertView.setTag(holder);
} else {
holder = (ViewHolder) convertView.getTag();
}
//沒有點選時的手指是灰色手指圖片
holder.image_praise.setImageBitmap(common.readBitMapJpg(context, R.drawable.icon_comments_praise));
final ViewHolder finalHolder = holder;
//給你點讚的控制元件設定點選事件
View.OnTouchListener listener = new View.OnTouchListener() {
private boolean image_record_out;
@Override
public boolean onTouch(View arg0, MotionEvent arg1) {
switch (arg1.getAction()) {
case MotionEvent.ACTION_DOWN:
switch (arg0.getId()) {
case R.id.image_praise:
image_record_out = false;
finalHolder.image_praise.setAlpha(0.5f);
break;
}
break;
case MotionEvent.ACTION_MOVE:
switch (arg0.getId()) {//手指一旦離開點讚的控制元件,就把點選事件取消
case R.id.image_praise:
int x = (int) arg1.getX();
int y = (int) arg1.getY();
if (x < 0 || y < 0 || x > finalHolder.image_praise.getWidth() || y > finalHolder.image_praise.getHeight()) {
image_record_out = true;
}
break;
}
break;
case MotionEvent.ACTION_UP:
switch (arg0.getId()) {
case R.id.image_praise://點贊
finalHolder.image_praise.setAlpha(1.0f);
if (!image_record_out) {
//這裡開始啦
// 得到你點選的item的position;然後請求你的網路介面,你會問這個網路介面是啥子,這麼說:寫後臺那個人給你寫的網路介面。
// commentAttention這個就是我呼叫網路介面的方法,我這裡就直接強轉了。
// commentAttention方法就在InformationActivity類裡面
((InformationActivity) context).commentAttention(position);
}
break;
}
break;
case MotionEvent.ACTION_CANCEL:
switch (arg0.getId()) {
case R.id.image_praise:
finalHolder.image_praise.setAlpha(1.0f);
break;
}
}
return true;
}
};
holder.image_praise.setOnTouchListener(listener);
return convertView;
}
public static class ViewHolder {
public ImageView image_praise;
}
}
3.當你請求網路介面成功後,就可以呼叫這個方法了,這裡注意一下,你請求網路介面的時候肯定是在子執行緒裡面。子執行緒是不能更新UI的。
//實現單個item重新整理 引數就是adapter裡面傳過來的你點選的哪一個ListView的position
private void updateZan(int position) {
//得到你螢幕上第一個顯示的item
int firstVisiblePosition = listView.getFirstVisiblePosition();
//得到你螢幕上最後一個顯示的item
int lastVisiblePosition = listView.getLastVisiblePosition();
if (position >= firstVisiblePosition && position <= lastVisiblePosition) {
//得到你點選的item的view
View view = listView.getChildAt(position - firstVisiblePosition);
if (view.getTag() instanceof CommentAdapter.ViewHolder) {
//拿到view的Tag,強轉成CommentAdapter的ViewHolder
CommentAdapter.ViewHolder holder = (CommentAdapter.ViewHolder) view.getTag();
if (!isComment) {// 這裡我用了一個變數來控制,點第一次時,點贊成功,點贊控制元件顯示藍色的圖示,
// 點選第二次時,取消點贊,點贊控制元件顯示灰色的圖示。
isComment = true;
holder.image_praise.setImageBitmap(common.readBitMapJpg(this, R.drawable.icon_comments_praise_un));
} else {
isComment = false;
holder.image_praise.setImageBitmap(common.readBitMapJpg(this, R.drawable.icon_comments_praise));
}
}
}
}
如果有什麼我還說的不明白,請加群:305156665,我們一起學習討論