小猪的Android入门之路 Day 4 - part 4

Android事件处理机制之——事件处理机制拾遗

------------转载请注明出处——coder-pig


本节引言:

在前面三个部分中,对于android的事件处理机制的学习已经学得七七八八了,

基于监听与回调的时间处理机制,以及使用Handler传递信息的机制都已经学了;

在最后这个部分中会对一些小的知识点进行补充,比如触摸事件的两种形式,

Configuration类以及异步任务AsyncTask进行讲解,好了,开始本节的课程吧!哭



本节学习路线图:





正文:


触摸事件


对于触摸事件,有以下两种形式来实现,一个是基于监听的,一个是基于回调的,下面通过

简单的示例进行讲解:



①基于监听的TouchListener

效果图:



代码如下:

main.xml:

[html]   view plain copy print ?
  1. <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"  
  2.     xmlns:tools="http://schemas.android.com/tools"  
  3.     android:layout_width="match_parent"  
  4.     android:layout_height="match_parent"  
  5.     android:paddingLeft="@dimen/activity_horizontal_margin"  
  6.     android:paddingRight="@dimen/activity_horizontal_margin"  
  7.     android:paddingTop="@dimen/activity_vertical_margin"  
  8.     android:paddingBottom="@dimen/activity_vertical_margin"  
  9.     tools:context=".MyActivity">  
  10.   
  11.     <ImageView  
  12.         android:layout_width="wrap_content"  
  13.         android:layout_height="wrap_content"  
  14.         android:id="@+id/imgtouch"  
  15.         android:background="@drawable/touch"/>  
  16. </RelativeLayout>  


MainAcitivity.java

[java]   view plain copy print ?
  1. package example.jay.com.touch1;  
  2.   
  3. import android.support.v7.app.ActionBarActivity;  
  4. import android.os.Bundle;  
  5. import android.view.Menu;  
  6. import android.view.MenuItem;  
  7. import android.view.MotionEvent;  
  8. import android.view.View;  
  9. import android.widget.ImageView;  
  10. import android.widget.TextView;  
  11. import android.widget.Toast;  
  12.   
  13.   
  14. public class MyActivity extends ActionBarActivity {  
  15.   
  16.     private ImageView imgtouch;  
  17.   
  18.     @Override  
  19.     protected void onCreate(Bundle savedInstanceState) {  
  20.         super.onCreate(savedInstanceState);  
  21.         setContentView(R.layout.activity_my);  
  22.   
  23.         imgtouch = (ImageView)findViewById(R.id.imgtouch);  
  24.   
  25.         imgtouch.setOnTouchListener(new View.OnTouchListener() {  
  26.             @Override  
  27.             public boolean onTouch(View v, MotionEvent event) {  
  28.                 Toast.makeText(getApplicationContext(),"你通过监听器模式:OnTouchListener摸了伦家~",Toast.LENGTH_LONG).show();  
  29.                 return true;  
  30.             }  
  31.         });  
  32.     }  
  33. }  


代码解析:

就是简单的设置一个ImageView,然后setOnTouchListener,重写onTouch方法即可!很简单,其实这个在帧布局那一节已经有

个例子了:随手指移动的萌妹子


最后还要说下OnTouchListener的一些相关方法与属性:

onTouch(View v, MotionEvent event):这里面的参数依次是触发触摸事件的组件,触碰事件event

               封装了触发事件的详细信息,同样包括事件的类型、触发时间等信息。比如event.getX(),event.getY()

我们也可以对触摸的动作类型进行判断,使用event.getAction( )再进行判断;如:

event.getAction == MotionEvent.ACTION_DOWN,按下事件

event.getAction == MotionEvent.ACTION_MOVE:移动事件

event.getAction == MotionEvent.ACTION_UP:弹起事件

当然除了这几个还有多指触碰的,更多相关可查看开发文档,这里就不一一列出了!






②基于回调的onTouchEvent( )方法

同样式触碰事件,但是onTouchEvent更多的是用于自定义的view,所有的view类中都重写了该方法,而这种触摸事件是基于回调的,也就是说:

如果我们返回的值是false的话,那么事件会继续向外传播,由外面的容器或者Activity进行处理!当然还涉及到了手势(Gesture),这个我们

会在后面进行详细的讲解!onTouchEvent其实和onTouchListener是类似的,只是处理机制不用,前者是回调,后者是监听模式!


简单的代码示例:随手指移动的小球

自定义View

MyView.java

[java]   view plain copy print ?
  1. package example.jay.com.touch2;  
  2.   
  3.   
  4. import android.content.Context;  
  5. import android.graphics.Canvas;  
  6. import android.graphics.Color;  
  7. import android.graphics.Paint;  
  8. import android.util.AttributeSet;  
  9. import android.view.MotionEvent;  
  10. import android.view.View;  
  11.   
  12.   
  13. public class MyView extends View{  
  14.     public float X = 50;  
  15.     public float Y = 50;  
  16.   
  17.     //创建画笔  
  18.     Paint paint = new Paint();  
  19.   
  20.     public MyView(Context context,AttributeSet set)  
  21.     {  
  22.         super(context,set);  
  23.     }  
  24.   
  25.     @Override  
  26.     public void onDraw(Canvas canvas) {  
  27.         super.onDraw(canvas);  
  28.         paint.setColor(Color.BLUE);  
  29.         canvas.drawCircle(X,Y,30,paint);  
  30.     }  
  31.   
  32.     @Override  
  33.     public boolean onTouchEvent(MotionEvent event) {  
  34.         this.X = event.getX();  
  35.         this.Y = event.getY();  
  36.         //通知组件进行重绘  
  37.         this.invalidate();  
  38.         return true;  
  39.     }  
  40. }  


main.xml布局文件:

[java]   view plain copy print ?
  1. <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"  
  2.     xmlns:tools="http://schemas.android.com/tools"  
  3.     android:layout_width="match_parent"  
  4.     android:layout_height="match_parent"  
  5.   
  6.     tools:context=".MyActivity">  
  7.   
  8.     <example.jay.com.touch2.MyView  
  9.         android:layout_width="wrap_content"  
  10.         android:layout_height="wrap_content" />  
  11.   
  12. </RelativeLayout>  


运行截图:

用手指触摸进行移动~




响应系统设置的事件:Configuration类


Configuration类的使用:

该类是专门用于描述手机设备上的配置信息,比如屏幕方向,触摸屏的触摸方式等等

用法:①获取系统的Configuration对象

Configuration cfg = getResources().getConfiguration();

②接着要获取什么属性就cfg.XXX就可以了,用的较多就是屏幕的判断,其他需要时再来查表

fontScale:获取当前用户设置的字体的缩放因子。

keyboard:获取当前设备所关联的键盘类型。该属性的返回值:KEYBOARD_12KEY(只有12个键的小键盘)、KEYBOARD_NOKEYS、KEYBOARD_QWERTY(普通键盘)

keyboardHidden:该属性返回一个boolean值用于标识当前键盘是否可用。该属性不仅会判断系统的硬件键盘,也会判断系统的软键盘(位于屏幕)。

locale:获取用户当前的Locale.

mcc:获取移动信号的国家码

mnc:获取移动信号的网络码     

ps:国家代码和网络代码共同确定当前手机网络运营商

navigation:判断系统上方向导航设备的类型。该属性的返回值:NAVIGATION_NONAV(无导航)、NAVIGATION_DPAD(DPAD导航)

                    NAVIGATION_TRACKBALL(轨迹球导航)、NAVIGATION_WHEEL(滚轮导航)

orientation:获取系统屏幕的方向。该属性的返回值:ORIENTATION_LANDSCAPE(横向屏幕)ORIENTATION_PORTRAIT(竖向屏幕)

touchscreen:获取系统触摸屏的触摸方式。该属性的返回值:TOUCHSCREEN_NOTOUCH(无触摸屏)、TOUCHSCREEN_STYLUS(触摸笔式触摸屏)、
                     TOUCHSCREEN_FINGER(接收手指的触摸屏)




重写onConfigurationChanged响应系统设置更改


该方法用于监听系统设置的更改,是基于回调的时间处理方法,当系统的设置发生改变时就会自动触发;

但是要注意一点,使用下面的方法监控的话,targetSdkVersion属性最高只能设置为12,高于12的话,该方法不会被激发!

关于监控系统设置的改变,再后面后继续研究,现在暂且先掌握这个!


代码示例:

简单的一个按钮,点击后切换横竖屏,然后Toast提示

效果图如下:



代码如下:

MainActivity.java

[java]   view plain copy print ?
  1. package com.example.configurationchangedemo;  
  2.   
  3. import android.app.Activity;  
  4. import android.content.pm.ActivityInfo;  
  5. import android.content.res.Configuration;  
  6. import android.os.Bundle;  
  7. import android.view.View;  
  8. import android.view.View.OnClickListener;  
  9. import android.widget.Button;  
  10. import android.widget.Toast;  
  11.   
  12. public class MainActivity extends Activity {  
  13.   
  14.     @Override  
  15.     protected void onCreate(Bundle savedInstanceState) {  
  16.         super.onCreate(savedInstanceState);  
  17.         setContentView(R.layout.activity_main);  
  18.           
  19.         Button btn = (Button) findViewById(R.id.btncahange);  
  20.         btn.setOnClickListener(new OnClickListener() {  
  21.               
  22.             @Override  
  23.             public void onClick(View v) {  
  24.                 Configuration config = getResources().getConfiguration();  
  25.                 //如果是横屏的话切换成竖屏  
  26.                 if(config.orientation == Configuration.ORIENTATION_LANDSCAPE)  
  27.                 {  
  28.                     MainActivity.this.setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_PORTRAIT);  
  29.                 }  
  30.                 //如果竖屏的话切换成横屏  
  31.                 if(config.orientation == Configuration.ORIENTATION_PORTRAIT)  
  32.                 {  
  33.                     MainActivity.this.setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_LANDSCAPE);  
  34.                 }  
  35.             }  
  36.         });  
  37.     }  
  38.       
  39.     @Override  
  40.     public void onConfigurationChanged(Configuration newConfig) {  
  41.         super.onConfigurationChanged(newConfig);  
  42.         String screen = newConfig.orientation == Configuration.ORIENTATION_LANDSCAPE?"横屏":"竖屏";  
  43.         Toast.makeText(MainActivity.this"系统屏幕方向发生改变 \n 修改后的方向为" + screen, Toast.LENGTH_SHORT).show();  
  44.     }  
  45. }  

还需要配置以下AndroidManifest.xml文件:

在文件中加入以下代码:

权限:<uses-permission android:name="android.permission.CHANGE_CONFIGURATION" />

在<activity标签中添加:android:configChanges="orientation"

targetSdkVersion改为12以下的,12也可以



AsyncTask异步任务


AsyncTask的引入:



相关方法:



注意事项:



代码示例:

一个简单的进度条+按钮+文本框

因为我们还没讲到网络那块,所以这里用延时线程来模拟下载文件的过程

效果图:



main.xml布局文件:

[html]   view plain copy print ?
  1. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"  
  2.     xmlns:tools="http://schemas.android.com/tools"  
  3.     android:layout_width="match_parent"  
  4.     android:layout_height="match_parent"  
  5.     android:orientation="vertical"  
  6.     tools:context=".MyActivity">  
  7.   
  8.     <TextView  
  9.         android:id="@+id/txttitle"  
  10.         android:layout_width="wrap_content"  
  11.         android:layout_height="wrap_content" />  
  12.   
  13.     <!--设置一个进度条,并且设置为水平方向-->  
  14.     <ProgressBar  
  15.         android:layout_width="fill_parent"  
  16.         android:layout_height="wrap_content"  
  17.         android:id="@+id/pgbar"  
  18.         style="?android:attr/progressBarStyleHorizontal"/>  
  19.   
  20.     <Button  
  21.         android:layout_width="wrap_content"  
  22.         android:layout_height="wrap_content"  
  23.         android:id="@+id/btnupdate"  
  24.         android:text="更新progressBar"/>  
  25. </LinearLayout>  






自定义延时线程:

[java]   view plain copy print ?
  1. package example.jay.com.asynctaskdemo;  
  2.   
  3. public class DelayOperator {  
  4.     //延时操作,用来模拟下载  
  5.     public void delay()  
  6.     {  
  7.         try {  
  8.             Thread.sleep(1000);  
  9.         }catch (InterruptedException e){  
  10.             e.printStackTrace();;  
  11.         }  
  12.     }  
  13. }  


自定义AsyncTask

[java]   view plain copy print ?
  1. package example.jay.com.asynctaskdemo;  
  2.   
  3. import android.os.AsyncTask;  
  4. import android.widget.ProgressBar;  
  5. import android.widget.TextView;  
  6.   
  7. /** 
  8.  * Created by Administrator on 8/7/2014. 
  9.  */  
  10. public class MyAsyncTask extends AsyncTask<Integer,Integer,String>  
  11. {  
  12.     private TextView txt;  
  13.     private ProgressBar pgbar;  
  14.   
  15.     public MyAsyncTask(TextView txt,ProgressBar pgbar)  
  16.     {  
  17.         super();  
  18.         this.txt = txt;  
  19.         this.pgbar = pgbar;  
  20.     }  
  21.   
  22.   
  23.     //该方法不运行在UI线程中,主要用于异步操作,通过调用publishProgress()方法  
  24.     //触发onProgressUpdate对UI进行操作  
  25.     @Override  
  26.     protected String doInBackground(Integer... params) {  
  27.         DelayOperator dop = new DelayOperator();  
  28.         int i = 0;  
  29.         for (i = 10;i <= 100;i+=10)  
  30.         {  
  31.             dop.delay();  
  32.             publishProgress(i);  
  33.         }  
  34.         return  i + params[0].intValue() + "";  
  35.     }  
  36.   
  37.     //该方法运行在UI线程中,可对UI控件进行设置  
  38.     @Override  
  39.     protected void onPreExecute() {  
  40.         txt.setText("开始执行异步线程~");  
  41.     }  
  42.   
  43.   
  44.     //在doBackground方法中,每次调用publishProgress方法都会触发该方法  
  45.     //运行在UI线程中,可对UI控件进行操作  
  46.   
  47.   
  48.     @Override  
  49.     protected void onProgressUpdate(Integer... values) {  
  50.         int value = values[0];  
  51.         pgbar.setProgress(value);  
  52.     }  
  53. }  


MainActivity.java

[java]   view plain copy print ?
  1. package example.jay.com.asynctaskdemo;  
  2.   
  3. import android.support.v7.app.ActionBarActivity;  
  4. import android.os.Bundle;  
  5. import android.view.View;  
  6. import android.widget.Button;  
  7. import android.widget.ProgressBar;  
  8. import android.widget.TextView;  
  9.   
  10.   
  11. public class MyActivity extends ActionBarActivity {  
  12.   
  13.     private TextView txttitle;  
  14.     private ProgressBar pgbar;  
  15.     private Button btnupdate;  
  16.   
  17.     @Override  
  18.     protected void onCreate(Bundle savedInstanceState) {  
  19.         super.onCreate(savedInstanceState);  
  20.         setContentView(R.layout.activity_my);  
  21.   
  22.         txttitle = (TextView)findViewById(R.id.txttitle);  
  23.         pgbar = (ProgressBar)findViewById(R.id.pgbar);  
  24.         btnupdate = (Button)findViewById(R.id.btnupdate);  
  25.   
  26.         btnupdate.setOnClickListener(new View.OnClickListener() {  
  27.             @Override  
  28.             public void onClick(View v) {  
  29.                 MyAsyncTask myTask = new MyAsyncTask(txttitle,pgbar);  
  30.                 myTask.execute(1000);  
  31.             }  
  32.         });  
  33.     }  
  34. }  



ps:代码示例都是从网上参考的一些简单的例子,看懂应该不是什么大的问题,先弄懂基本原理,是我们目前要做的;

等以后做项目遇到在深入地去研究~

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值