Android学习自定义View(四)——继承控件(滑动时ListView的Item出现删除按钮)

简介: MainActivity如下: package cc.testviewstudy4;import java.util.ArrayList;import java.

MainActivity如下:

package cc.testviewstudy4;

import java.util.ArrayList;
import java.util.HashMap;
import cc.testviewstudy4.ListViewSubClass.OnDeleteListener;
import android.os.Bundle;
import android.widget.SimpleAdapter;
import android.app.Activity;
/**
 * Demo描述:
 * 关于自定义View的学习(四)
 * 
 * 自定义View的实现方式大概可以分为三种:
 * 自绘控件、组合控件、以及继承控件
 * 在此Demo中实现继承控件:
 * 自定义ListView.在ListView的Item上滑动时可出现一个
 * 删除View.点击它,可删除ListView中的该条数据
 * 
 * 学习资料:
 * http://blog.csdn.net/guolin_blog/article/details/17357967
 * Thank you very much
 * 
 */
public class MainActivity extends Activity {
    private ListViewSubClass mListView;
    private SimpleAdapter mSimpleAdapter;
    private ArrayList<HashMap<String, Object>> mArrayList;
	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.main);
		init();
	}
	
	private void init(){
		mListView=(ListViewSubClass) findViewById(R.id.listView);
		mArrayList=new ArrayList<HashMap<String,Object>>();
      	HashMap<String, Object> hashMap=null;
      	for (int i = 0; i <12; i++) {
      		hashMap=new HashMap<String, Object>();
      		hashMap.put("name", "小明"+i);
        	mArrayList.add(hashMap);
		}
      mSimpleAdapter=new SimpleAdapter(this, mArrayList, R.layout.listviewitem, 
    		                           new String []{"name"}, new int[]{R.id.name});
      mListView.setAdapter(mSimpleAdapter);
      mListView.setOnDeleteListener(new OnDeleteListener() {
		@Override
		public void onDelete(int index) {
			mArrayList.remove(index);
			mSimpleAdapter.notifyDataSetChanged();
		}
	});
	}
}


ListViewSubClass如下:

package cc.testviewstudy4;

import android.content.Context;
import android.util.AttributeSet;
import android.view.GestureDetector;
import android.view.GestureDetector.OnGestureListener;
import android.view.LayoutInflater;
import android.view.MotionEvent;
import android.view.View;
import android.view.View.OnTouchListener;
import android.view.ViewGroup;
import android.widget.ListView;
import android.widget.RelativeLayout;

public class ListViewSubClass extends ListView implements OnGestureListener,OnTouchListener {
	private GestureDetector mGestureDetector;
	private OnDeleteListener mDeleteListener;
	private View mDeleteView;
	private ViewGroup mListViewItemViewGroup;
	private int selectedItem;
	private boolean isDeleteShowing;
	
	public ListViewSubClass(Context context) {
		super(context);
	}
	
	public ListViewSubClass(Context context, AttributeSet attrs) {
		super(context, attrs);
		// 监听Touch
		this.setOnTouchListener(this);
		// 手势
		mGestureDetector = new GestureDetector(context, this);
	}
	
	public ListViewSubClass(Context context, AttributeSet attrs, int defStyle) {
		super(context, attrs, defStyle);
	}

	
	public void setOnDeleteListener(OnDeleteListener onDeleteListener){
		mDeleteListener=onDeleteListener;
	}

	//定义一个接口
	public interface OnDeleteListener {
		void onDelete(int index);
	}
	
	//------>以下方法为OnTouchListener接口的实现
	@Override
	public boolean onTouch(View v, MotionEvent event) {
		//if-->当有删除View的时候.我们触摸该ListView时将其消失
		if (isDeleteShowing) {
			mListViewItemViewGroup.removeView(mDeleteView);
			mDeleteView = null;
			isDeleteShowing = false;
			return false;
	    //else-->其余时候交给GestureDetector处理
		} else {
			return mGestureDetector.onTouchEvent(event);
		}

	}
	//------>以下方法为OnTouchListener接口的实现
	
	

	
	//------>以下方法为OnGestureListener接口的实现
	@Override
	public boolean onDown(MotionEvent e) {
		if (!isDeleteShowing) {
			selectedItem = pointToPosition((int) e.getX(), (int) e.getY());
		}
		return false;
	}

	@Override
	public boolean onFling(MotionEvent e1, MotionEvent e2, float velocityX,float velocityY) {
		//当删除View没有显示并且是水平滑动时我们显示删除View
		if (!isDeleteShowing && Math.abs(velocityX) > Math.abs(velocityY)) {
			mDeleteView = LayoutInflater.from(getContext()).inflate(R.layout.delete, null);
			mDeleteView.setOnClickListener(new OnClickListener() {
				@Override
				public void onClick(View v) {
					mListViewItemViewGroup.removeView(mDeleteView);
					mDeleteView = null;
					isDeleteShowing = false;
					mDeleteListener.onDelete(selectedItem);
				}
			});
			//找到当前的Item
			mListViewItemViewGroup = (ViewGroup) getChildAt(selectedItem-getFirstVisiblePosition());
			RelativeLayout.LayoutParams params = new 
			RelativeLayout.LayoutParams(LayoutParams.WRAP_CONTENT, LayoutParams.WRAP_CONTENT);
			params.addRule(RelativeLayout.ALIGN_PARENT_RIGHT);
			params.addRule(RelativeLayout.CENTER_VERTICAL);
			mListViewItemViewGroup.addView(mDeleteView, params);
			isDeleteShowing = true;
		}
		
		return false;

	}

	@Override
	public void onLongPress(MotionEvent e) {

	}

	@Override
	public boolean onScroll(MotionEvent e1, MotionEvent e2, float distanceX,float distanceY) {
		return false;
	}

	@Override
	public void onShowPress(MotionEvent e) {

	}

	@Override
	public boolean onSingleTapUp(MotionEvent e) {
		return false;
	}
	//------>以上方法为OnGestureListener接口的实现

}


main.xml如下:

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
     >

    <cc.testviewstudy4.ListViewSubClass
        android:id="@+id/listView"
        android:layout_width="fill_parent"
        android:layout_height="fill_parent"
     />
</RelativeLayout>

delete.xml如下:

<?xml version="1.0" encoding="utf-8"?>
<Button xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/deleteButton"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:background="@drawable/deletebutton" >
</Button>


listviewitem如下:

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="fill_parent"
    android:layout_height="70dip"
     >

    <TextView
        android:id="@+id/name"
        android:layout_width="100dip"
        android:layout_height="wrap_content"
        android:textSize="25sp"
        android:layout_centerVertical="true"
     />

</RelativeLayout>




相关文章
|
1月前
|
Android开发 开发者
安卓应用开发中的自定义视图
【9月更文挑战第37天】在安卓开发的海洋中,自定义视图犹如一座座小岛,等待着勇敢的探索者去发现其独特之处。本文将带领你踏上这段旅程,从浅滩走向深海,逐步揭开自定义视图的神秘面纱。
33 3
|
27天前
|
数据可视化 Android开发 开发者
安卓应用开发中的自定义View组件
【10月更文挑战第5天】在安卓应用开发中,自定义View组件是提升用户交互体验的利器。本篇将深入探讨如何从零开始创建自定义View,包括设计理念、实现步骤以及性能优化技巧,帮助开发者打造流畅且富有创意的用户界面。
59 0
|
2天前
|
搜索推荐 前端开发 Android开发
安卓应用开发中的自定义视图实现
【10月更文挑战第30天】在安卓开发的海洋中,自定义视图是那抹不可或缺的亮色,它为应用界面的个性化和交互体验的提升提供了无限可能。本文将深入探讨如何在安卓平台创建自定义视图,并展示如何通过代码实现这一过程。我们将从基础出发,逐步引导你理解自定义视图的核心概念,然后通过一个实际的代码示例,详细讲解如何将理论应用于实践,最终实现一个美观且具有良好用户体验的自定义控件。无论你是想提高自己的开发技能,还是仅仅出于对安卓开发的兴趣,这篇文章都将为你提供价值。
|
3天前
|
Android开发 开发者 UED
安卓开发中自定义View的实现与性能优化
【10月更文挑战第28天】在安卓开发领域,自定义View是提升应用界面独特性和用户体验的重要手段。本文将深入探讨如何高效地创建和管理自定义View,以及如何通过代码和性能调优来确保流畅的交互体验。我们将一起学习自定义View的生命周期、绘图基础和事件处理,进而探索内存和布局优化技巧,最终实现既美观又高效的安卓界面。
15 5
|
2月前
|
Java Maven 开发工具
第一个安卓项目 | 中国象棋demo学习
本文是作者关于其第一个安卓项目——中国象棋demo的学习记录,展示了demo的运行结果、爬坑记录以及参考资料,包括解决Android Studio和maven相关问题的方法。
第一个安卓项目 | 中国象棋demo学习
|
27天前
|
XML 前端开发 Java
安卓应用开发中的自定义View组件
【10月更文挑战第5天】自定义View是安卓应用开发的一块基石,它为开发者提供了无限的可能。通过掌握其原理和实现方法,可以创造出既美观又实用的用户界面。本文将引导你了解自定义View的创建过程,包括绘制技巧、事件处理以及性能优化等关键步骤。
|
2月前
|
Android开发 开发者
安卓开发中的自定义视图:从入门到精通
【9月更文挑战第19天】在安卓开发的广阔天地中,自定义视图是一块充满魔力的土地。它不仅仅是代码的堆砌,更是艺术与科技的完美结合。通过掌握自定义视图,开发者能够打破常规,创造出独一无二的用户界面。本文将带你走进自定义视图的世界,从基础概念到实战应用,一步步展示如何用代码绘出心中的蓝图。无论你是初学者还是有经验的开发者,这篇文章都将为你打开一扇通往创意和效率的大门。让我们一起探索自定义视图的秘密,将你的应用打造成一件艺术品吧!
58 10
|
25天前
|
Web App开发 编解码 视频直播
视频直播技术干货(十二):从入门到放弃,快速学习Android端直播技术
本文详细介绍了Android端直播技术的全貌,涵盖了从实时音视频采集、编码、传输到解码与播放的各个环节。文章还探讨了直播中音视频同步、编解码器选择、传输协议以及直播延迟优化等关键问题。希望本文能为你提供有关Andriod端直播技术的深入理解和实践指导。
35 0