Android触摸事件_wpf触摸屏点击事件

Android触摸事件_wpf触摸屏点击事件<Buttonandroid:layout_width="wrap_content"android:layout_height="wrap_content"android:id="@+id/start"android:text="开始"/>

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

触屏事件

  • 三类简单触屏事件:
    • 单击事件:OnClickListener
    • 长按事件:OnLongClickListener
    • 触摸事件:OnTouchListener
  • 这些方法都是View类的,所以像TextView这样看似不是按钮的组件也可以使用这些监听。
  • 这三类触屏事件都是View中的接口,其定义如下:
    public static interface View.OnClickListener { 
         
        void onClick(View v);
    }
    public static interface View.OnLongClickListener { 
         
        boolean onLongClick(View v);
    }
    public interface View.OnTouchListener { 
         
        boolean onTouch(View v, MotionEvent event);
    }
    

    由此我们可以知道,要实现监听,就是要覆盖这个接口的方法,实现多态。

单击事件

  • 单击事件有以下几种种实现方法:
    • Activity本身作为事件监听器类: 直接在class MainActivity extends Activity后面加上implements OnClickListener,不推荐,会使程序结构混乱。
    • 内部类作为事件监听器: 在MainActivity中定义内部类,在内部类中覆盖接口,然后在setOnClickListener参数表中创建这个类。
    • 匿名内部类作为事件监听器: 原理和上面一个方法相同,但是可以用Java的语法简化,参照Java匿名内部类。
    • 外部类作为事件监听器: 在MainActivity外部定义一个辅助类,和内部类相似,但是不能访问组件信息,不建议使用。
    • 直接绑定到标签: 这是单击事件独有的方法,在xml中为组件绑定事件处理方法 android:onClick=“clickName”
      然后直接在类中声明方法:public void clickName(View view)即可

长按事件

  • 长按事件有单击事件的前四种方法,但是没有最后一种方法。
  • 长按事件的返回值是boolean而不是void,所以最后要返回 true或 false。
  • 返回值的含义:

    当我们长按时,会触发长按操作,那么如果我们同时也设置了点击监听,我们会不会也触发了点击监听?当返回true,表示消耗掉了这次事件,也就是说不会有单击的效果。如果返回法false,则在松手的时候会触发单击事件。

触摸事件

  • 触摸事件有onTouch方法有参数MotionEvent event,通过对象event方法getX()和getY()可以获取触摸出横纵坐标。
  • 触摸事件第一下必须点在组件上,之后手指可以滑向组件之外,并且可以得到时时的坐标。
  • 简单地说,为一个飞机加上监听之后,我们必须手指放在飞机上才可以拖动飞机。

实例

  • 我们在最上方设置一个TextView,用于显示我们的操作。
  • 练习一下TableLayout,设置4个按键,分别用Button和TextView,用多种方法加上监听器。
  • 对最上面的TextView加上触摸监听器,并显示坐标。
  • xml代码:
    <?xml version="1.0" encoding="utf-8"?><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"  android:paddingBottom="@dimen/activity_vertical_margin"  android:paddingLeft="@dimen/activity_horizontal_margin"  android:paddingRight="@dimen/activity_horizontal_margin"  android:paddingTop="@dimen/activity_vertical_margin"  tools:context="com.example.myapplication.MainActivity">  <TextView      android:layout_width="match_parent"      android:layout_height="wrap_content"      android:id="@+id/title"      android:textSize="25dp"/>  <TableLayout      android:layout_width="match_parent"      android:layout_height="wrap_content"      android:layout_below="@+id/title">      <TableRow>          <Button              android:text="1"              android:textSize="25dp"              android:layout_weight="1"              android:id="@+id/button1"/>          <Button              android:text="2"              android:textSize="25dp"              android:layout_weight="1"              android:onClick="onClick2" />      </TableRow>      <TableRow>          <TextView              android:id="@+id/textView3"              android:text="3"              android:textSize="25dp"              android:layout_weight="1"              android:gravity="center"/>          <TextView              android:text="4"              android:textSize="25dp"              android:layout_weight="1"              android:gravity="center"              android:onClick="onClick4"/>      </TableRow>  </TableLayout></RelativeLayout>
  • java代码
package com.example.myapplication;import android.support.v7.app.ActionBarActivity;import android.os.Bundle;import android.view.MotionEvent;import android.view.View;import android.widget.Button;import android.widget.TextView;public class MainActivity extends ActionBarActivity {        @Override    protected void onCreate(Bundle savedInstanceState) {            super.onCreate(savedInstanceState);        setContentView(R.layout.activity_main);        final TextView title = (TextView) findViewById(R.id.title);        //先为四个组件添加单击监听        Button B1 = (Button) findViewById(R.id.button1);        TextView T3 = (TextView) findViewById(R.id.textView3);        //方法一:定义内部接口类        class OnClick1 implements View.OnClickListener {                public void onClick(View view) {     title.setText("Button1被单击");}        }        B1.setOnClickListener(new OnClick1());        //方法二:不定义类,用匿名内部类        T3.setOnClickListener(new View.OnClickListener(){                @Override            public void onClick(View view){     title.setText("TextView3被单击");}        });        //方法三在onCreate函数体外,为xml中注册的函数定义        //为有id的两个组件注册长按监听        B1.setOnLongClickListener(new View.OnLongClickListener(){                @Override            public boolean onLongClick(View view){     title.setText("Button1被长按");return false;}        });        T3.setOnLongClickListener(new View.OnLongClickListener(){                @Override            public boolean onLongClick(View view){     title.setText("TextView3被长按");return true;}        });        //为T3添加触屏监听        title.setOnTouchListener(new View.OnTouchListener(){                @Override            public boolean onTouch(View v, MotionEvent event) {                    title.setText("x坐标为"+event.getX()+"Y坐标为"+event.getY());                return true;            }        });    }    //设置另外两个单击监听    public void onClick2(View view) {            TextView title = (TextView) findViewById(R.id.title);        title.setText("Button2被单击");    }    public void onClick4(View view){            TextView title = (TextView) findViewById(R.id.title);        title.setText("TextView4被单击");    }}

可以试验Button1和TextView3对于长按,一个Button1触发单击,TextView3不触发。从最上方TextView滑动手指,可以时时显示坐标。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/195195.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • ActiveMQ面试题

    ActiveMQ宕机了怎么办官方的解决方案是主从集群(备份)方案zookeeper集群Replicated(瑞pk得)levelDB就是之前在讲消息持久化kahaDB的另一种消息持久化方案,这种方案的性能会比较好activemq集群activemq最起码有三个,因为一个activemq挂了之后可以在另外两个中选取,如果只有两个的话挂了一个就只剩下一个没法选取了,三台activemq只…

  • Java学习之SpringMVC 拦截器

    Java学习之SpringMVC拦截器0x00前言继续SpringMVC最后一点小内容,后面就该学习如何整合SSM框架了。0x01拦截器拦截器和前面提到的一个过滤器类似,但是他们还是

    2021年12月12日
  • idea 20213.3激活码(最新序列号破解)

    idea 20213.3激活码(最新序列号破解),https://javaforall.cn/100143.html。详细ieda激活码不妨到全栈程序员必看教程网一起来了解一下吧!

  • mapminmax 用法

    mapminmax 用法mapminmax是MATLAB实现归一化的工具包,默认:(1)将矩阵的每行分别进行归一化;(2)每行的最大值最小值作为每行归一化的xmin和xmax;(3)将数据归一化到[-1,1].若要将数据归一化到0到1之间,即y∈[0,1],使用b=mapminmax(a,0,1);若给与确定的最大值和最小值作为每行的xmin和xmax,使用:b= mapminmax(a,0,1);PS.xmin…

  • wget下载出现错误 403:Forbidden

    wget下载出现错误 403:Forbidden

    2021年11月22日
  • 监控RuntimeException「建议收藏」

    监控RuntimeException「建议收藏」在线程提前终止的最主要原因就是RuntimeException,由于这些异常表示出现了某种编程错误或者其他不可修复的错误,因此它们通常不会被捕获。它们不会在调用栈中逐层传递,而是默认地在控制台中输出栈追踪信息,并终止线程我们可以通过实现java.lang.Thread.UncaughtExceptionHandler接口来获取RuntimeException异常的信息。

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号