android 简书 手势动画,Android开发(九)| android手势开发

2024-03-26 13:50

本文主要是介绍android 简书 手势动画,Android开发(九)| android手势开发,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

类似于java IO(输入输出)的编程,Android为文件IO提供了openFileOutput和openFileInput两个便捷方法。此外,Android还提供了一种“另类”IO:手势支持。

Android的手势支持体现在两方面:手势检测与手势识别,前者属于事件自动处理方面,后者属于系统IO方面。熟练运用手势支持可以开发出更新奇更智能的应用。

手势(Gesture)

ff95ee6322f7?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

手势识别

所谓手势,其实是用户手指或触摸笔在触摸屏上的连续触屏行为。比如在屏幕上从左至右划出的一个动作或者画出一个圆圈,都是手势。

Android既支持手势检测,也允许开发者添加手势并提供了相应的API识别用户手势。结合实例,我们来分别探究这两种手势行为。

1)基本手势检测

Android为手势检测提供了一个GestureDetector类,GestureDetector实例代表一个手势检测器,创建时需要传入一个GestureDetector.OnGestureListener实例,负责对用户手势行为提供响应。

GestureDetector.OnGestureListener包含了许多事件处理方法。如:用户手指在触摸屏上按下触发、长按时触发、手指在屏幕上“滚动”触发等等。

使用Android手势检测只需两个步骤:

·1 创建一个GestureDetector对象,创建时必须实现监听器实例。

·2 为应用程序的Activity的TouchEvent事件绑定监听器,把它交给GestureDetector处理。

各种方法的触发时机仅从文字上表述显得抽象,我们用一个最简单实例来测试用户的不同动作到底触发了哪种手势动作。

public class MainActivity extends Activity

implements OnGestureListener

{

// 定义手势检测器实例

GestureDetector detector;

@Override

public void onCreate(Bundle savedInstanceState)

{

super.onCreate(savedInstanceState);

setContentView(R.layout.activity_main);

//创建手势检测器

detector = new GestureDetector(this, this);

}

//将该Activity上的触碰事件交给GestureDetector处理

@Override

public boolean onTouchEvent(MotionEvent me)

{

return detector.onTouchEvent(me);

}

@Override

public boolean onDown(MotionEvent arg0)

{

//当触碰事件按下时触发该方法

Toast.makeText(this,"onDown"

, Toast.LENGTH_SHORT).show();

return false;

}

@Override

public boolean onFling(MotionEvent e1, MotionEvent e2

, float velocityX, float velocityY)

{

//当用户手指在触摸屏上“拖过”时触发该方法

Toast.makeText(this , "onFling"

, Toast.LENGTH_SHORT).show();

return false;

}

@Override

public void onLongPress(MotionEvent e)

{

//当用户手指在屏幕上长按时触发该方法

Toast.makeText(this ,"onLongPress"

, Toast.LENGTH_SHORT).show();

}

@Override

public boolean onScroll(MotionEvent e1, MotionEvent e2

, float distanceX, float distanceY)

{

//当用户手指在屏幕上“滚动”时触发该方法

Toast.makeText(this ,"onScroll" ,

Toast.LENGTH_SHORT).show();

return false;

}

@Override

public void onShowPress(MotionEvent e)

{

//当用户手指在触摸屏上按下,且未移动、松开时触发该方法

Toast.makeText(this ,"onShowPress"

, Toast.LENGTH_SHORT).show();

}

@Override

public boolean onSingleTapUp(MotionEvent e)

{

//当用户手指在触摸屏上轻击事件将触发该方法

Toast.makeText(this ,"onSingleTapUp"

, Toast.LENGTH_SHORT).show();

return false;

}

}

现在运行程序,当用户随意在屏幕上触碰时,程序将会检测用户执行的手势。如长按屏幕,将显示如图信息:

ff95ee6322f7?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

2)手势滑动翻页

增加手势翻页,不仅让应用更加灵活、美观,还很好的丰富了信息量。

具体的手势检测思路还是一样,把Activity的TouchEvent交给GestureDetector处理。这个程序的特殊之处在于:使用了一个ViewFlipper组件,ViewFlipper可使用动画控制多个组件之间的切换效果。

我们还是用实例讲解,通过GestureDetector检测手势动作,并根据手势控制ViewFlipper包含的View组件的切换,来实现翻页。

界面布局的代码很简单,定义一个:ViewFlipper

xmlns:tools="http://schemas.android.com/tools"

android:layout_width="match_parent"

android:layout_height="match_parent"

android:orientation="vertical" >

android:id="@+id/viewFlipper"

android:layout_width="match_parent"

android:layout_height="match_parent" />

主程序仅需实现GestureDetector.OnGestureListener的onFling()方法。然后在该方法中加入判断逻辑。当用户手势从左(右)向右(左)滑动,设置ViewFlipper采用动画方式切换为下一个View——实现翻页。

ff95ee6322f7?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

部分源码截图

现在运行程序,并在屏幕上连续滑动,即可看到图片无缝切换效果:

ff95ee6322f7?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

第一张图

ff95ee6322f7?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

从左向右滑动 切换至第二张图

ff95ee6322f7?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

继续向右滑动 切换至第三张图

3)增加手势

强大的Android除了提供手势检测外,还允许应用程序把用户手势(多个持续的触摸事件在屏幕上形成特定的形状)添加到指定文件中。如果程序需要,当用户下次再画出该手势时,系统可自动识别。涉及的知识点如下:

·1 加载手势库

Android使用GestureLibrary代表手势库,并提供了static GestureLibraries.fromFile(File path)方法从path代表的文件中加载手势库。

·2 添加手势

一旦程序获得了GestureLibrary对象,该对象提供了void addGesture(String entryName,Gesture gesture) 方法来添加一个名为entryName的手势。

·3 手势编辑组件

GestureOverlayView是专门的手势编辑组件,用户可以在此组件上绘制手势。

为了监听该组件上的手势事件,android为它提供了OnGesturePerformedListener 监听器接口,用于在手势完成时提供响应。

我们在应用的activity_main.xml中使用GestureOverlayView:

android:orientation="vertical"

android:layout_width="match_parent"

android:layout_height="match_parent"

android:gravity="center_horizontal">

android:layout_width="match_parent"

android:layout_height="wrap_content"

android:textSize="22dp"

android:text="请在下面屏幕上绘制手势"/>

android:id="@+id/gesture"

android:layout_width="match_parent"

android:layout_height="match_parent"

android:gestureStrokeType="multiple" />

当一个手势可以一笔完成时,android:gestureStrokeType参数设为single,否则设为multiple。

在主活动中为GestureOverlayView绑定监听器后,当手势完成时将提供响应——打开一个对话框。该对话框布局code如下:

android:orientation="vertical"

android:layout_width="match_parent"

android:layout_height="match_parent">

android:orientation="horizontal"

android:layout_width="match_parent"

android:layout_height="wrap_content">

android:layout_width="wrap_content"

android:layout_height="wrap_content"

android:layout_marginRight="8dip"

android:text="请输入手势名" />

android:id="@+id/gesture_name"

android:layout_width="match_parent"

android:layout_height="wrap_content"/>

android:id="@+id/show"

android:layout_width="128dp"

android:layout_height="128dp"

android:layout_marginTop="10dp" />

主活动连同整个工程代码已打包上传:《android增加自定义手势》

现在运行程序,将看到如下界面。

ff95ee6322f7?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

添加手势

用户可在界面中随意“绘制”手势,绘制完成后OnGesturePerformedListener 监听器会打开下图所示的对话框。

ff95ee6322f7?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

保存手势

当用户单击“保存”按钮后,程序会调用GestureLibrary的addGesture()方法来添加手势,并调用save()方法保存手势。

一旦用户通过该程序建立自己的手势库,接下来就可在其他程序中使用该手势库了。(下一章提供调用实例)

【注:上面的程序需要将手势库保存在SD卡上,因此还需要授予该应用程序读写SD的权限。】

本章小结:

本节主要是结合实例,介绍Android提供的“另类”IO:手势支持。程序不但可以识别手势,还能添加、识别用户自定义的手势,并被其他程序调用。

加入手势识别后的应用,就可以按照用户的手势完成相应操作,功能更加智能界面更加精美。

我们的Android开发之旅又向前迈进了一步,继续努力。下一章还将介绍android的一种“另类”IO:自动朗读,欢迎关注噢。

作者:叶琛

一只痴迷旅行的大三程序狗

这篇关于android 简书 手势动画,Android开发(九)| android手势开发的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/848715

相关文章

基于Python开发电脑定时关机工具

《基于Python开发电脑定时关机工具》这篇文章主要为大家详细介绍了如何基于Python开发一个电脑定时关机工具,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1. 简介2. 运行效果3. 相关源码1. 简介这个程序就像一个“忠实的管家”,帮你按时关掉电脑,而且全程不需要你多做

Java中的Opencv简介与开发环境部署方法

《Java中的Opencv简介与开发环境部署方法》OpenCV是一个开源的计算机视觉和图像处理库,提供了丰富的图像处理算法和工具,它支持多种图像处理和计算机视觉算法,可以用于物体识别与跟踪、图像分割与... 目录1.Opencv简介Opencv的应用2.Java使用OpenCV进行图像操作opencv安装j

基于Qt开发一个简单的OFD阅读器

《基于Qt开发一个简单的OFD阅读器》这篇文章主要为大家详细介绍了如何使用Qt框架开发一个功能强大且性能优异的OFD阅读器,文中的示例代码讲解详细,有需要的小伙伴可以参考一下... 目录摘要引言一、OFD文件格式解析二、文档结构解析三、页面渲染四、用户交互五、性能优化六、示例代码七、未来发展方向八、结论摘要

最好用的WPF加载动画功能

《最好用的WPF加载动画功能》当开发应用程序时,提供良好的用户体验(UX)是至关重要的,加载动画作为一种有效的沟通工具,它不仅能告知用户系统正在工作,还能够通过视觉上的吸引力来增强整体用户体验,本文给... 目录前言需求分析高级用法综合案例总结最后前言当开发应用程序时,提供良好的用户体验(UX)是至关重要

基于Python实现PDF动画翻页效果的阅读器

《基于Python实现PDF动画翻页效果的阅读器》在这篇博客中,我们将深入分析一个基于wxPython实现的PDF阅读器程序,该程序支持加载PDF文件并显示页面内容,同时支持页面切换动画效果,文中有详... 目录全部代码代码结构初始化 UI 界面加载 PDF 文件显示 PDF 页面页面切换动画运行效果总结主

Android数据库Room的实际使用过程总结

《Android数据库Room的实际使用过程总结》这篇文章主要给大家介绍了关于Android数据库Room的实际使用过程,详细介绍了如何创建实体类、数据访问对象(DAO)和数据库抽象类,需要的朋友可以... 目录前言一、Room的基本使用1.项目配置2.创建实体类(Entity)3.创建数据访问对象(DAO

在 VSCode 中配置 C++ 开发环境的详细教程

《在VSCode中配置C++开发环境的详细教程》本文详细介绍了如何在VisualStudioCode(VSCode)中配置C++开发环境,包括安装必要的工具、配置编译器、设置调试环境等步骤,通... 目录如何在 VSCode 中配置 C++ 开发环境:详细教程1. 什么是 VSCode?2. 安装 VSCo

C#图表开发之Chart详解

《C#图表开发之Chart详解》C#中的Chart控件用于开发图表功能,具有Series和ChartArea两个重要属性,Series属性是SeriesCollection类型,包含多个Series对... 目录OverviChina编程ewSeries类总结OverviewC#中,开发图表功能的控件是Char

Android WebView的加载超时处理方案

《AndroidWebView的加载超时处理方案》在Android开发中,WebView是一个常用的组件,用于在应用中嵌入网页,然而,当网络状况不佳或页面加载过慢时,用户可能会遇到加载超时的问题,本... 目录引言一、WebView加载超时的原因二、加载超时处理方案1. 使用Handler和Timer进行超

鸿蒙开发搭建flutter适配的开发环境

《鸿蒙开发搭建flutter适配的开发环境》文章详细介绍了在Windows系统上如何创建和运行鸿蒙Flutter项目,包括使用flutterdoctor检测环境、创建项目、编译HAP包以及在真机上运... 目录环境搭建创建运行项目打包项目总结环境搭建1.安装 DevEco Studio NEXT IDE