こんにちは、私はオンライン チュートリアルを使用して懐中電灯アプリに取り組んでいます。アプリにいくつかの変更を加えました。ユーザーがホーム画面に移動したり、画面をロックしたりしても、懐中電灯が点灯したままになるようにしました。ただし、これを行ってデフォルトのカメラアプリを開き、懐中電灯アプリを再度開くと、懐中電灯が機能しなくなります。
エラーを再現する手順:
- アプリをオンにする(フラッシュを自動的にオンにする)
- ホーム画面ボタンを押します(フラッシュは点灯したままです)
- デフォルトのカメラアプリを開く (Flash オフ)
- 懐中電灯アプリを再度開きます(オン/オフボタンが機能せず、フラッシュはオフのままです)
私のコード:
package ali.simpleflaslight;
import android.app.Activity;
import android.os.Bundle;
import android.app.AlertDialog;
import android.content.DialogInterface;
import android.content.pm.PackageManager;
import android.hardware.Camera;
import android.hardware.Camera.Parameters;
import android.media.MediaPlayer;
import android.media.MediaPlayer.OnCompletionListener;
import android.view.View;
import android.widget.ImageButton;
public class MainActivity extends Activity {
ImageButton btnSwitch;
private Camera camera;
private boolean isFlashOn;
private boolean hasFlash;
Parameters params;
MediaPlayer mp;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
try {
//================================== Flash Switch Button =============================//
btnSwitch = (ImageButton) findViewById(R.id.btnSwitch);
//================================== First Check =====================================//
hasFlash = getApplicationContext().getPackageManager()
.hasSystemFeature(PackageManager.FEATURE_CAMERA_FLASH);
if (!hasFlash) {
AlertDialog alert = new AlertDialog.Builder(MainActivity.this)
.create();
alert.setTitle("Error");
alert.setMessage("Sorry, your device doesn't support a flashlight!");
alert.setButton("OK", new DialogInterface.OnClickListener() {
public void onClick(DialogInterface dialog, int which) {
// closing the application
finish();
}
});
alert.show();
return;
}
getCamera();
toggleButtonImage();
btnSwitch.setOnClickListener(new View.OnClickListener() {@
Override
public void onClick(View v) {
if (isFlashOn) {
// turn off flash
turnOffFlash();
} else {
// turn on flash
turnOnFlash();
}
}
});
} catch (Exception e) {}
}
//====================================== Getting Camera Parameters ===========================//
private void getCamera() {
try {
if (camera == null) {
try {
camera = Camera.open();
params = camera.getParameters();
} catch (Exception e) {}
}
} catch (Exception e) {}
}
//====================================== Turning On Flash ====================================//
private void turnOnFlash() {
try {
if (!isFlashOn) {
if (camera == null || params == null) {
return;
}
//Play Sound
playSound();
params = camera.getParameters();
params.setFlashMode(Parameters.FLASH_MODE_TORCH);
camera.setParameters(params);
camera.startPreview();
isFlashOn = true;
//Changing Button/Switch Image
toggleButtonImage();
}
} catch (Exception e) {}
}
//====================================== Turning Off Flash ===================================//
private void turnOffFlash() {
try {
if (isFlashOn) {
if (camera == null || params == null) {
return;
}
//Play Sound
playSound();
params = camera.getParameters();
params.setFlashMode(Parameters.FLASH_MODE_OFF);
camera.setParameters(params);
camera.stopPreview();
isFlashOn = false;
//Changing Button/Switch Image
toggleButtonImage();
}
} catch (Exception e) {}
}
//====================================== Toggle Image ========================================//
private void toggleButtonImage() {
try {
if (isFlashOn) {
btnSwitch.setImageResource(R.drawable.btn_switch_on);
} else {
btnSwitch.setImageResource(R.drawable.btn_switch_off);
}
} catch (Exception e) {}
}
//====================================== Play Sound ==========================================//
private void playSound() {
try {
if (isFlashOn) {
mp = MediaPlayer.create(MainActivity.this, R.raw.light_switch_off);
} else {
mp = MediaPlayer.create(MainActivity.this, R.raw.light_switch_on);
}
mp.setOnCompletionListener(new OnCompletionListener() {
@Override
public void onCompletion(MediaPlayer mp) {
// TODO Auto-generated method stub
mp.release();
}
});
mp.start();
} catch (Exception e) {}
}
@Override
protected void onDestroy() {
super.onDestroy();
}
@Override
protected void onPause() {
super.onPause();
//================================== On Pause Turn Off The Flash =========================//
//turnOffFlash();
}
@Override
protected void onRestart() {
super.onRestart();
}
@Override
protected void onResume() {
super.onResume();
//================================== On Resume Turn On The Flash =========================//
if (hasFlash) {
turnOnFlash();
}
}
@Override
protected void onStart() {
super.onStart();
//================================== On Starting The App Get The Camera Params============//
getCamera();
}
@Override
protected void onStop() {
super.onStop();
// on stop release the camera
/*if (camera != null) {
camera.release();
camera = null;
}*/
}
}
onStop でコードをコメントすると、アプリが動作しなくなります。上記の手順を実行すると、バックグラウンド フラッシュをサポートしている Playstore のトップ フラッシュライト アプリがすべて動作しなくなるのは驚くべきことです。しかし、私はキャッチフレーズを試したので、アプリは何もしなくなりました。これに対する解決策はありますか?
編集:
getCamera を onResume の前に置いた後のエラー (および上記と同じ手順を実行した後):
05 - 08 19: 41: 10.955 4378 - 4378 / ali.simpleflaslight W / System.err﹕ java.lang.RuntimeException: getParameters failed(empty parameters)
05 - 08 19: 41: 10.955 4378 - 4378 / ali.simpleflaslight W / System.err﹕ at android.hardware.Camera.native_getParameters(Native Method)
05 - 08 19: 41: 10.955 4378 - 4378 / ali.simpleflaslight W / System.err﹕ at android.hardware.Camera.getParameters(Camera.java: 2075)
05 - 08 19: 41: 10.955 4378 - 4378 / ali.simpleflaslight W / System.err﹕ at ali.simpleflaslight.MainActivity.turnOffFlash(MainActivity.java: 114)
05 - 08 19: 41: 10.956 4378 - 4378 / ali.simpleflaslight W / System.err﹕ at ali.simpleflaslight.MainActivity.access$100(MainActivity.java: 15)
05 - 08 19: 41: 10.956 4378 - 4378 / ali.simpleflaslight W / System.err﹕ at ali.simpleflaslight.MainActivity$2.onClick(MainActivity.java: 56)
05 - 08 19: 41: 10.956 4378 - 4378 / ali.simpleflaslight W / System.err﹕ at android.view.View.performClick(View.java: 4764)
05 - 08 19: 41: 10.956 4378 - 4378 / ali.simpleflaslight W / System.err﹕ at android.view.View$PerformClick.run(View.java: 19833)
05 - 08 19: 41: 10.956 4378 - 4378 / ali.simpleflaslight W / System.err﹕ at android.os.Handler.handleCallback(Handler.java: 739)
05 - 08 19: 41: 10.956 4378 - 4378 / ali.simpleflaslight W / System.err﹕ at android.os.Handler.dispatchMessage(Handler.java: 95)
05 - 08 19: 41: 10.956 4378 - 4378 / ali.simpleflaslight W / System.err﹕ at android.os.Looper.loop(Looper.java: 135)
05 - 08 19: 41: 10.956 4378 - 4378 / ali.simpleflaslight W / System.err﹕ at android.app.ActivityThread.main(ActivityThread.java: 5292)
05 - 08 19: 41: 10.956 4378 - 4378 / ali.simpleflaslight W / System.err﹕ at java.lang.reflect.Method.invoke(Native Method)
05 - 08 19: 41: 10.956 4378 - 4378 / ali.simpleflaslight W / System.err﹕ at java.lang.reflect.Method.invoke(Method.java: 372)
05 - 08 19: 41: 10.956 4378 - 4378 / ali.simpleflaslight W / System.err﹕ at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java: 908)
05 - 08 19: 41: 10.956 4378 - 4378 / ali.simpleflaslight W / System.err﹕ at com.android.internal.os.ZygoteInit.main(ZygoteInit.java: 703)