| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128 |
- /*
- * Copyright (C) 2010 ZXing authors
- *
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
- package com.usai.redant.photo;
- import android.app.Activity;
- import android.content.Context;
- import android.content.SharedPreferences;
- import android.content.res.AssetFileDescriptor;
- import android.media.AudioManager;
- import android.media.MediaPlayer;
- import android.os.Vibrator;
- import android.preference.PreferenceManager;
- import android.util.Log;
- import java.io.IOException;
- /**
- * Manages beeps and vibrations for {@link CaptureActivity}.
- */
- final class BeepManager implements MediaPlayer.OnCompletionListener, MediaPlayer.OnErrorListener {
- private static final String TAG = BeepManager.class.getSimpleName();
- private static final float BEEP_VOLUME = 0.10f;
- private static final long VIBRATE_DURATION = 200L;
- private final Activity activity;
- private MediaPlayer mediaPlayer;
- private boolean playBeep;
- private boolean vibrate;
- BeepManager(Activity activity) {
- this.activity = activity;
- this.mediaPlayer = null;
- updatePrefs();
- }
- synchronized void updatePrefs() {
- SharedPreferences prefs = PreferenceManager.getDefaultSharedPreferences(activity);
- playBeep = shouldBeep(prefs, activity);
- vibrate = prefs.getBoolean(PreferencesActivity.KEY_VIBRATE, false);
- if (playBeep && mediaPlayer == null) {
- // The volume on STREAM_SYSTEM is not adjustable, and users found it too loud,
- // so we now play on the music stream.
- activity.setVolumeControlStream(AudioManager.STREAM_MUSIC);
- mediaPlayer = buildMediaPlayer(activity);
- }
- }
- synchronized void playBeepSoundAndVibrate() {
- Log.i(TAG,"playBeep=========>"+playBeep);
- Log.i(TAG,"mediaPlayer=========>"+mediaPlayer==null?"null":"ok");
- Log.i(TAG,"vibrate=========>"+vibrate);
- if (playBeep && mediaPlayer != null) {
- mediaPlayer.start();
- }
- if (vibrate) {
- Vibrator vibrator = (Vibrator) activity.getSystemService(Context.VIBRATOR_SERVICE);
- vibrator.vibrate(VIBRATE_DURATION);
- }
- }
- private static boolean shouldBeep(SharedPreferences prefs, Context activity) {
- boolean shouldPlayBeep = prefs.getBoolean(PreferencesActivity.KEY_PLAY_BEEP, true);
- if (shouldPlayBeep) {
- // See if sound settings overrides this
- AudioManager audioService = (AudioManager) activity.getSystemService(Context.AUDIO_SERVICE);
- if (audioService.getRingerMode() != AudioManager.RINGER_MODE_NORMAL) {
- shouldPlayBeep = false;
- }
- }
- return shouldPlayBeep;
- }
- private MediaPlayer buildMediaPlayer(Context activity) {
- MediaPlayer mediaPlayer = new MediaPlayer();
- mediaPlayer.setAudioStreamType(AudioManager.STREAM_MUSIC);
- mediaPlayer.setOnCompletionListener(this);
- mediaPlayer.setOnErrorListener(this);
- AssetFileDescriptor file = activity.getResources().openRawResourceFd(R.raw.beep);
- try {
- mediaPlayer.setDataSource(file.getFileDescriptor(), file.getStartOffset(), file.getLength());
- file.close();
- mediaPlayer.setVolume(BEEP_VOLUME, BEEP_VOLUME);
- mediaPlayer.prepare();
- } catch (IOException ioe) {
- Log.w(TAG, ioe);
- mediaPlayer = null;
- }
- return mediaPlayer;
- }
- @Override
- public void onCompletion(MediaPlayer mp) {
- // When the beep has finished playing, rewind to queue up another one.
- mp.seekTo(0);
- }
- @Override
- public synchronized boolean onError(MediaPlayer mp, int what, int extra) {
- if (what == MediaPlayer.MEDIA_ERROR_SERVER_DIED) {
- // we are finished, so put up an appropriate error toast if required and finish
- activity.finish();
- } else {
- // possibly media player error, so release and recreate
- mp.release();
- mediaPlayer = null;
- updatePrefs();
- }
- return true;
- }
- }
|