如何通过代码控制手机振动??
下面来看一个例子
1》在Manifest.xml文件中加入使用权限
<!-- 设置手机震动权限 -->
<uses-permission android:name="android.permission.VIBRATE" />
完整的文件内容如下:
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.linkcube.vibrateactivity"
android:versionCode="1"
android:versionName="1.0" >
<uses-sdk
android:minSdkVersion="8"
android:targetSdkVersion="20" />
<application
android:allowBackup="true"
android:icon="@drawable/ic_launcher"
android:label="@string/app_name"
android:theme="@style/AppTheme" >
<activity
android:name=".MainActivity"
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-permission android:name="android.permission.VIBRATE" />
</manifest>
2》程序运行效果如下图所示:
布局文件activity_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>
3》程序完整代码如下(包含详细注示)
package com.linkcube.vibrateactivity;
import android.app.Service;
import android.os.Bundle;
import android.os.Vibrator;
import android.support.v7.app.ActionBarActivity;
import android.view.Menu;
import android.view.MenuItem;
import android.widget.CompoundButton;
import android.widget.CompoundButton.OnCheckedChangeListener;
import android.widget.TextView;
import android.widget.ToggleButton;
public class MainActivity extends ActionBarActivity {
// 声明控件
private ToggleButton tb1 = null;
private ToggleButton tb2 = null;
private TextView tv1 = null;
private TextView tv2 = null;
private Vibrator vibrator = null;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
init();
}
// 初始化
private void init() {
// 得到相应控件的引用
tb1 = (ToggleButton) findViewById(R.id.tb1);
tv1 = (TextView) findViewById(R.id.tv1);
tb2 = (ToggleButton) findViewById(R.id.tb2);
tv2 = (TextView) findViewById(R.id.tv2);
// 注册事件
tb1.setOnCheckedChangeListener(listener);
tb2.setOnCheckedChangeListener(listener);
vibrator = (Vibrator) getSystemService(Service.VIBRATOR_SERVICE);
}
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则表示不重复震动
// 第一个参数:等待1秒,震动2秒,等待1秒,震动3秒 ,等待1秒,震动5秒
// 第二个参数:-1表示不重复, 如果不是-1, 比如改成1, 表示从前面这个long数组的下标为1的元素开始重复.
vibrator.vibrate(new long[] { 1000, 2000, 1000, 3000, 1000,
5000 }, 0);
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;
}
}
};
@Override
public boolean onCreateOptionsMenu(Menu menu) {
// Inflate the menu; this adds items to the action bar if it is present.
getMenuInflater().inflate(R.menu.main, menu);
return true;
}
@Override
public boolean onOptionsItemSelected(MenuItem item) {
// Handle action bar item clicks here. The action bar will
// automatically handle clicks on the Home/Up button, so long
// as you specify a parent activity in AndroidManifest.xml.
int id = item.getItemId();
if (id == R.id.action_settings) {
return true;
}
return super.onOptionsItemSelected(item);
}
}