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>




相关文章
|
5月前
|
XML Java Android开发
Android自定义view之网易云推荐歌单界面
本文详细介绍了如何通过自定义View实现网易云音乐推荐歌单界面的效果。首先,作者自定义了一个圆角图片控件`MellowImageView`,用于绘制圆角矩形图片。接着,通过将布局放入`HorizontalScrollView`中,实现了左右滑动功能,并使用`ViewFlipper`添加图片切换动画效果。文章提供了完整的代码示例,包括XML布局、动画文件和Java代码,最终展示了实现效果。此教程适合想了解自定义View和动画效果的开发者。
226 65
Android自定义view之网易云推荐歌单界面
|
5月前
|
XML 前端开发 Android开发
一篇文章带你走近Android自定义view
这是一篇关于Android自定义View的全面教程,涵盖从基础到进阶的知识点。文章首先讲解了自定义View的必要性及简单实现(如通过三个构造函数解决焦点问题),接着深入探讨Canvas绘图、自定义属性设置、动画实现等内容。还提供了具体案例,如跑马灯、折线图、太极图等。此外,文章详细解析了View绘制流程(measure、layout、draw)和事件分发机制。最后延伸至SurfaceView、GLSurfaceView、SVG动画等高级主题,并附带GitHub案例供实践。适合希望深入理解Android自定义View的开发者学习参考。
552 84
|
5月前
|
前端开发 Android开发 UED
讲讲Android为自定义view提供的SurfaceView
本文详细介绍了Android中自定义View时使用SurfaceView的必要性和实现方式。首先分析了在复杂绘制逻辑和高频界面更新场景下,传统View可能引发卡顿的问题,进而引出SurfaceView作为解决方案。文章通过Android官方Demo展示了SurfaceView的基本用法,包括实现`SurfaceHolder.Callback2`接口、与Activity生命周期绑定、子线程中使用`lockCanvas()`和`unlockCanvasAndPost()`方法完成绘图操作。
115 3
|
Shell Android开发 UED
我的Android进阶之旅------&gt;Android中通过adb shell input来模拟滑动、按键、点击事件
今天在维护公司的一个小项目的时候,发现按公司手机的某个物理按键,激活相应的Service后,会在屏幕上模拟的点击了屏幕的某个坐标点。好家伙,原来是之前该项目的版本是按这个物理按键后,会弹出一个对话框,提示用户需要打开某些服务,然后出于良好的用户体验,直接模拟点击事件,点击该对话框,不让用户做多余的操作。
2810 0
|
16天前
|
开发工具 Android开发
X Android SDK file not found: adb.安卓开发常见问题-Android SDK 缺少 `adb`(Android Debug Bridge)-优雅草卓伊凡
X Android SDK file not found: adb.安卓开发常见问题-Android SDK 缺少 `adb`(Android Debug Bridge)-优雅草卓伊凡
212 11
X Android SDK file not found: adb.安卓开发常见问题-Android SDK 缺少 `adb`(Android Debug Bridge)-优雅草卓伊凡
|
26天前
|
Java 开发工具 Maven
【01】完整的安卓二次商业实战-详细的初级步骤同步项目和gradle配置以及开发思路-优雅草伊凡
【01】完整的安卓二次商业实战-详细的初级步骤同步项目和gradle配置以及开发思路-优雅草伊凡
96 6
|
3月前
|
安全 数据库 Android开发
在Android开发中实现两个Intent跳转及数据交换的方法
总结上述内容,在Android开发中,Intent不仅是活动跳转的桥梁,也是两个活动之间进行数据交换的媒介。运用Intent传递数据时需注意数据类型、传输大小限制以及安全性问题的处理,以确保应用的健壯性和安全性。
184 11
|
3月前
|
移动开发 Java 编译器
Kotlin与Jetpack Compose:Android开发生态的演进与架构思考
本文从资深Android工程师视角深入分析Kotlin与Jetpack Compose在Android系统中的技术定位。Kotlin通过空安全、协程等特性解决了Java在移动开发中的痛点,成为Android官方首选语言。Jetpack Compose则引入声明式UI范式,通过重组机制实现高效UI更新。两者结合不仅提升开发效率,更为跨平台战略和现代架构模式提供技术基础,代表了Android开发生态的根本性演进。
115 0
|
7月前
|
JavaScript Linux 网络安全
Termux安卓终端美化与开发实战:从下载到插件优化,小白也能玩转Linux
Termux是一款安卓平台上的开源终端模拟器,支持apt包管理、SSH连接及Python/Node.js/C++开发环境搭建,被誉为“手机上的Linux系统”。其特点包括零ROOT权限、跨平台开发和强大扩展性。本文详细介绍其安装准备、基础与高级环境配置、必备插件推荐、常见问题解决方法以及延伸学习资源,帮助用户充分利用Termux进行开发与学习。适用于Android 7+设备,原创内容转载请注明来源。
1405 77
|
4月前
|
安全 Java Android开发
为什么大厂要求安卓开发者掌握Kotlin和Jetpack?深度解析现代Android开发生态优雅草卓伊凡
为什么大厂要求安卓开发者掌握Kotlin和Jetpack?深度解析现代Android开发生态优雅草卓伊凡
191 0
为什么大厂要求安卓开发者掌握Kotlin和Jetpack?深度解析现代Android开发生态优雅草卓伊凡

热门文章

最新文章