java.Lang.RuntimeException, setParameters falló en la versión de Android (4.1.1)
He desarrollado una aplicación que captura una foto cuando se pincha en ese momento. Está funcionando bien en la pestaña de Acer (captura de imagen y guarda en sdcard). Ahora, cuando ejecuto la misma aplicación en Samsung Galaxy (Android-4.1.1) Mi aplicación está obteniendo el mensaje "Desafortunadamente, la aplicación se ha detenido" cuando hago clic en pinchar. Mi código está aquí.
// ClockIn functionality
clockin_btn.setOnClickListener(new View.OnClickListener() {
public void onClick(View v) {
clockin_btn.setEnabled(false);
camera.stopPreview();
capturePhoto(0);
// showing one error here in log cat
previewing = false;
clockin_label.setText(String.format(session_msg,logout_seconds));
ticker.setBase(SystemClock.elapsedRealtime());
ticker.start();
}
});
private String capturePhoto(int clockInOutMode) {
final int mode = clockInOutMode;
img_file = String.format("%d.jpg", System.currentTimeMillis());
Camera.PictureCallback mCall = new Camera.PictureCallback() {
public void onPictureTaken(byte[] data, Camera camera) {
try {
Bitmap mBitmap = BitmapFactory.decodeByteArray(data, 0, data.length);
File file = new File(Constants.EMP_IMG_LOCATION, img_file);
FileOutputStream fOut = new FileOutputStream(file);
mBitmap.compress(Bitmap.CompressFormat.JPEG, 80, fOut);
fOut.flush();
fOut.close();
if ( mode == 0) {
clockIn(img_file);
} else {
clockOut(img_file);
}
} catch (FileNotFoundException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
}
};
Camera.Parameters cameraParams = camera.getParameters();
List<Camera.Size> sizes = cameraParams.getSupportedPictureSizes();
Camera.Size result = null;
for (int i=0;i<sizes.size();i++){
result = (Size) sizes.get(i);
Log.i("PictureSize", "Supported Size.Width: " + result.width + "height: " +result.height);
}
cameraParams.setPictureSize(640, 480);
camera.setParameters(cameraParams);
System.gc();
camera.setPreviewCallback(null);
camera.takePicture(null, null, mCall);
// showing one error here in logcat
return img_file;
}
Mi Logcat se muestra como:
03-27 04:52:19.273: E/AndroidRuntime(4105): FATAL EXCEPTION: main
03-27 04:52:19.273: E/AndroidRuntime(4105): java.lang.RuntimeException: setParameters failed
03-27 04:52:19.273: E/AndroidRuntime(4105): at android.hardware.Camera.native_setParameters(Native Method)
03-27 04:52:19.273: E/AndroidRuntime(4105): at android.hardware.Camera.setParameters(Camera.java:1452)
y mi archivo android.manifest.xml:
<uses-feature android:name="android.hardware.camera" />
<uses-feature android:name="android.hardware.camera.autofocus" />
<used-feature android:name="android.hardware.location" />
<used-feature android:name="android.hardware.camera.setParameters" />