Android实现手机振动设置的方法

本文实例讲述了Android实现手机振动设置的方法。分享给大家供大家参考。具体如下:

main.xml布局文件:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  android:orientation="vertical" android:layout_width="fill_parent"
  android:layout_height="fill_parent">
  <LinearLayout android:orientation="horizontal"
    android:layout_width="fill_parent"
    android:layout_height="wrap_content">
    <ToggleButton android:id="@+id/tb1"
      android:textOn="关闭振动"
      android:textOff="启动振动"
      android:checked="false"
      android:layout_width="wrap_content"
      android:layout_height="wrap_content" />
    <TextView android:id="@+id/tv1"
      android:text="振动已关闭"
      android:layout_width="wrap_content"
      android:layout_height="wrap_content" />
  </LinearLayout>
  <LinearLayout android:orientation="horizontal"
    android:layout_width="fill_parent"
    android:layout_height="wrap_content">
    <ToggleButton android:id="@+id/tb2"
      android:textOn="关闭振动"
      android:textOff="启动振动"
      android:checked="false"
      android:layout_width="wrap_content"
      android:layout_height="wrap_content" />
    <TextView android:id="@+id/tv2"
      android:text="振动已关闭"
      android:layout_width="wrap_content"
      android:layout_height="wrap_content" />
  </LinearLayout>
</LinearLayout>

清单文件:

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
  package="com.ljq.activity" android:versionCode="1"
  android:versionName="1.0">
  <application android:icon="@drawable/icon"
    android:label="@string/app_name">
    <activity android:name=".VibrateActivity"
      android:label="@string/app_name">
      <intent-filter>
        <action android:name="android.intent.action.MAIN" />
        <category
          android:name="android.intent.category.LAUNCHER" />
      </intent-filter>
    </activity>
  </application>
  <uses-sdk android:minSdkVersion="7" />
  <!-- 设置手机震动权限 -->
  <uses-permission android:name="android.permission.VIBRATE" />
</manifest>

VibrateActivity类:

package com.ljq.activity;
import android.app.Activity;
import android.app.Service;
import android.os.Bundle;
import android.os.Vibrator;
import android.widget.CompoundButton;
import android.widget.TextView;
import android.widget.ToggleButton;
import android.widget.CompoundButton.OnCheckedChangeListener;
public class VibrateActivity extends Activity {
  private Vibrator vibrator=null;
  private ToggleButton tb1=null, tb2=null;
  private TextView tv1=null, tv2=null;
  @Override
  public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.main);
    //注意模拟器是模拟不了震动的,得真机测试哦
    //创建vibrator对象
    vibrator=(Vibrator)getSystemService(Service.VIBRATOR_SERVICE);
    tv1=(TextView)findViewById(R.id.tv1);
    tv2=(TextView)findViewById(R.id.tv2);
    tb1=(ToggleButton)findViewById(R.id.tb1);
    tb2=(ToggleButton)findViewById(R.id.tb2);
    tb1.setOnCheckedChangeListener(listener);
    tb2.setOnCheckedChangeListener(listener);
  }
  OnCheckedChangeListener listener=new OnCheckedChangeListener(){
    public void onCheckedChanged(CompoundButton buttonView, boolean isChecked) {
      ToggleButton toggleButton=(ToggleButton)buttonView;
      switch (toggleButton.getId()) {
      case R.id.tb1:
        if(isChecked){
          //根据指定的模式进行震动
          //第一个参数:该数组中第一个元素是等待多长的时间才启动震动,
          //之后将会是开启和关闭震动的持续时间,单位为毫秒
          //第二个参数:重复震动时在pattern中的索引,如果设置为-1则表示不重复震动
          vibrator.vibrate(new long[]{1000,50,50,100,50}, -1);
          tv1.setText("振动已启动");
        }else {
          //关闭震动
          vibrator.cancel();
          tv1.setText("震动已关闭");
        }
        break;
      case R.id.tb2:
        if(isChecked){
          //启动震动,并持续指定的时间
          vibrator.vibrate(3500);
          tv2.setText("振动已启动");
        }else {
          //关闭启动
          vibrator.cancel();
          tv2.setText("震动已关闭");
        }
        break;
      }
    }
  };
}

运行结果:

希望本文所述对大家的Android程序设计有所帮助。

(0)

相关推荐

  • 安卓系统中实现摇一摇画面振动效果的方法

    前言     在微信刚流行的时候,在摇一摇还能用来那啥的时候,我也曾深更半夜的拿着手机晃一晃.当时想的最多的就是,我靠,为神马摇一下需要用这么大的力度,当时我想可能腾讯觉得那是个人性的设计,后来才发觉尼马重力加速度设得太高了吧.扯多了,最近项目里需要解决一个振动的问题,因此在学习振动实现的过程中,写了个demo实现了摇一摇振动的效果,这里记录一下. 原理     摇一摇功能的基本原理就是:利用手机的加速度传感器,当加速度到达某个值时,触发某个事件,例如手机振动.UI改变等.这里要实现该功能,首先

  • Android中通知Notification使用实例(振动、灯光、声音)

    本文实例讲解了通知Notification使用方法,此知识点就是用作通知的显示,包括振动.灯光.声音等效果,分享给大家供大家参考,具体内容如下 效果图: MainActivity: import java.io.File; import android.app.Activity; import android.app.Notification; import android.app.NotificationManager; import android.app.PendingIntent; im

  • 鼠标图片振动代码

    <!--代码开始--!> <!---YeJun2605.AnyP.cn-//--> <!---这里只是在图片里加了一点代码进去认真看看--!><P><A title=一切网络资源尽在建站资源情感梦,情感一角欢迎光临! href="http://yejun2605.anyp.cn/" target=_blank><FONT color=#0099ff><FONT size=3><IMG class=

  • 实用的JS正则表达式(手机号码/IP正则/邮编正则/电话等)

    //校验是否全由数字组成 复制代码 代码如下: function isDigit(s) { var patrn=/^[0-9]{1,20}$/; if (!patrn.exec(s)) return false return true } //校验登录名:只能输入5-20个以字母开头.可带数字."_"."."的字串 复制代码 代码如下: function isRegisterUserName(s) { var patrn=/^[a-zA-Z]{1}([a-zA-Z0

  • javascript 手机号码正则表达式验证函数 原创

    复制代码 代码如下: function checkMobile(){     var sMobile = document.mobileform.mobile.value     if(!(/^1[3|4|5|8][0-9]\d{4,8}$/.test(sMobile))){         alert("不是完整的11位手机号或者正确的手机号前七位");         document.mobileform.mobile.focus();         return false;

  • JavaScript手机振动API

    很明显,这个API就是允许mobile程序员使用JavaScript调用手机的振动功能,并且能设定振动的方式和时长. 判断浏览器对振动API的支持情况 一个好的习惯就是在使用之前要检查一下当前你的应用环境.浏览器是否支持振动API.下面就是检测的方法: // Standards ftw! var supportsVibrate = "vibrate" in navigator; 在window.navigator对象里就只有一个关于振动的API:vibrate. 振动API基础应用 这

  • JS判断客户端是手机还是PC的2个代码

    1.第一种: 复制代码 代码如下: function IsPC() {    var userAgentInfo = navigator.userAgent;    var Agents = ["Android", "iPhone",                "SymbianOS", "Windows Phone",                "iPad", "iPod"]; 

  • 利用iOS动画来模拟音量振动条的实现

    iOS动画来模拟音量振动条,即利用CAReplicatorLayer实现,以下将详细的介绍CAReplicatorLayer和实现方法. 音量振动条 效果图: 如何实现? 创建3个layer,按顺序播放y轴缩放动画 利用CAReplicatorLayer实现 1.什么是CAReplicatorLayer? 一种可以复制自己子层的layer,并且复制出来的layer和原生子层有同样的属性,位置,形变,动画. 2.CAReplicatorLayer属性 instanceCount: 子层总数(包括原

  • js和html5实现手机端刮刮卡抽奖效果完美兼容android/IOS

    绝对值得看的来篇,哈哈.本人亲自完成,有错误请大家指出: 现在的手机完美支持html5,所以如果手机端想要做个抽奖模块的话,用刮刮卡抽奖效果,相信这个互动体验是非常棒的 ​ps:由于本人没有wp8系统的手机,所以没法兼容wp8系统的,目前完美兼容android,IOS 如果要在pc浏览的话,得改下js,目前支持谷歌,火狐,ie>=10,如果网友想要的话我就去写个 代码如下: 复制代码 代码如下: <!DOCTYPE html> <html lang="en"&g

  • js 手机号码合法性验证代码集合

    第一个代码: 复制代码 代码如下: function Checkreg() { //验证电话号码手机号码,包含153,159号段 if (document.form.phone.value=="" && document.form.UserMobile.value==""){ alert("电话号码和手机号码至少选填一个阿!"); document.form.phone.focus(); return false; } if (d

随机推荐