Android Studio 触摸屏事件


触屏事件

  • 三类简单触屏事件:
    • 单击事件: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滑动手指,可以时时显示坐标。

« »

发表评论

电子邮件地址不会被公开。 必填项已用*标注

昵称 *