アプリに 2 つの問題があります。
- 写真を撮ると
クラッシュする - デバイスを回転させるとクラッシュする
cameraPreview.java:
public class CameraPreview extends Activity implements SurfaceHolder.Callback
{
Camera camera;
SurfaceView preview;
SurfaceHolder holder;
LayoutInflater controlInflater = null;
@Override
protected void onCreate(Bundle savedInstanceState)
{
super.onCreate(savedInstanceState);
requestWindowFeature(Window.FEATURE_NO_TITLE);
getWindow().setFlags(WindowManager.LayoutParams.FLAG_FULLSCREEN,
WindowManager.LayoutParams.FLAG_FULLSCREEN);
setContentView(R.layout.activity_camera_preview);
getWindow().setFormat(PixelFormat.UNKNOWN);
preview = (SurfaceView) findViewById(R.id.surface1);
holder = preview.getHolder();
holder.addCallback(this);
//holder.setType(SurfaceHolder.SURFACE_TYPE_PUSH_BUFFERS);
controlInflater = LayoutInflater.from(getBaseContext());
View viewControl = controlInflater.inflate(R.layout.control, null);
LayoutParams layoutParamsControl = new LayoutParams(LayoutParams.MATCH_PARENT,LayoutParams.MATCH_PARENT);
this.addContentView(viewControl, layoutParamsControl); }
@Override
public void surfaceChanged(SurfaceHolder holder, int format, int width, int height)
{
Camera camera = Camera.open();
Configuration c = getResources().getConfiguration();
if(c.orientation == Configuration.ORIENTATION_PORTRAIT)
{
camera.setDisplayOrientation(90);
}
if(camera!=null)
{
try
{
camera.setPreviewDisplay(holder);
}
catch (IOException e)
{
e.printStackTrace();
}
camera.startPreview();
}}
public void surfaceCreated(SurfaceHolder holder)
{
}
@Override
public void surfaceDestroyed(SurfaceHolder holder)
{
if(camera!=null)
{
camera.stopPreview();
camera.setPreviewCallback(null);
camera.release();
camera=null;
}
}
PictureCallback myPictureCallback_JPG = new PictureCallback()
{
@Override
public void onPictureTaken(byte[] arg0, Camera arg1)
{
Bitmap bitmapPicture = BitmapFactory.decodeByteArray(arg0, 0, arg0.length);
}
};
public void take_picture_onClick(View view)
{
camera.takePicture(null, null, myPictureCallback_JPG);
} }
AndroidManifest.xml:
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.example.paparazzi"
android:versionCode="1"
android:versionName="1.0" >
<uses-sdk
android:minSdkVersion="8"
android:targetSdkVersion="15" />
<uses-permission android:name="android.permission.CAMERA" />
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
<uses-feature android:name="android.hardware.camera" android:required="true"/>
<application
android:icon="@drawable/ic_launcher"
android:label="@string/app_name"
android:theme="@style/AppTheme"
android:debuggable="true" >
<activity
android:name=".MainActivity"
android:label="@string/title_activity_main" >
</activity>
<activity
android:name=".CameraPreview"
android:configChanges="orientation" >
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
</application>
</manifest>
最初は、2 番目の問題はこの部分が不足していることが原因であると考えていました。
public void surfaceDestroyed(SurfaceHolder holder)
{
if(camera!=null)
{
camera.stopPreview();
camera.setPreviewCallback(null);
camera.release();
camera=null;
}
}
しかし、追加しても何も変わりませんでした。
最初の問題に関しては、何が問題なのかわかりません。アプリは 3 つの異なるデバイスでテストされました。提案をいただければ幸いです。
編集
わかりましたので、提案どおりにログを取得しようとしていますが、正しく行っているかどうかはわかりません:
public void take_picture_onClick(View view)
{
try
{
camera.takePicture(null, null, myPictureCallback_JPG);
}
catch(Exception ee)
{
try {
File filename = new File(Environment.getExternalStorageDirectory()+"/logfile4.log");
filename.createNewFile();
String cmd = "logcat -d -f "+filename.getAbsolutePath();
Runtime.getRuntime().exec(cmd);
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
ログ ファイルが作成されますが、ロードするのに少し時間がかかりますが、空です。