介绍
Vibrator类没有您要查找的isVibrating()
方法。它使用服务,因此您无法轻松地覆盖Vibrator并添加额外的功能。
ManagedVibrator
下面是一个ManagedVibrator类,它是Vibrator类的包装器。所有Vibrator方法都包括在内,还包括额外的isVibrating()
方法。
具有接受long[] pattern
签名的恒定振动方法易于跟踪,因为需要调用cancel()
来结束振动。然而,具有接受long millseconds
签名的一次性振动方法要难得多。
此实现使用ScheduledThreadPoolExecutor
来跟踪一次性振动方法。它在一次性振动方法完成后立即将mIsVibrating
标志设置为false
。
public class ManagedVibrator {
public static final String TAG = ManagedVibrator.class.getSimpleName();
private Context mContext;
private Vibrator mVibrator;
private boolean mIsVibrating = false;
private ScheduledThreadPoolExecutor mExecutor;
private Runnable mVibrationEndRunnable = new Runnable() {
@Override
public void run() {
setVibrating(false);
}
};
public ManagedVibrator(Context context) {
this.mContext = context;
mVibrator = (Vibrator) mContext.getSystemService(Context.VIBRATOR_SERVICE);
mExecutor = new ScheduledThreadPoolExecutor(1);
}
public boolean hasVibrator() {
return mVibrator.hasVibrator();
}
public void vibrate(long milliseconds) {
setVibrating(true);
mVibrator.vibrate(milliseconds);
notifyOnVibrationEnd(milliseconds);
}
public void vibrate(long milliseconds, AudioAttributes attributes) {
setVibrating(true);
mVibrator.vibrate(milliseconds, attributes);
notifyOnVibrationEnd(milliseconds);
}
public void vibrate(long[] pattern, int repeat) {
setVibrating(true);
mVibrator.vibrate(pattern, repeat);
}
public void vibrate(long[] pattern, int repeat, AudioAttributes attributes) {
setVibrating(true);
mVibrator.vibrate(pattern, repeat, attributes);
}
public void cancel() {
mVibrator.cancel();
setVibrating(false);
}
public boolean isVibrating() {
return mIsVibrating;
}
private void setVibrating(boolean isVibrating) {
mIsVibrating = isVibrating;
}
private void notifyOnVibrationEnd(long milliseconds) {
try {
mExecutor.schedule(mVibrationEndRunnable, milliseconds, TimeUnit.MILLISECONDS);
} catch (RejectedExecutionException e) {
Log.e(TAG, e.getMessage());
}
}
}
用法
ManagedVibrator vibrator = new ManagedVibrator(this);
vibrator.vibrate(5000);
...
if (vibrator.isVibrating()) {
}
限制
- 您的应用程序中只能使用一个ManagedVibrator实例。
- ManagedVibrator只能告诉您由您的应用程序引发的振动情况。它不知道其他应用程序或服务引起的振动情况。
- 非常长的振动时间或非常频繁的一次性振动可能会引起问题。