三星 Galaxy S3 4.1.1 版中的相机强制关闭问题
Posted
技术标签:
【中文标题】三星 Galaxy S3 4.1.1 版中的相机强制关闭问题【英文标题】:Camera Force Closing issue in Samsung Galaxy S3 version 4.1.1 【发布时间】:2013-01-07 20:27:38 【问题描述】:我想捕获图像并将其保存在“我的应用程序”之一的图像视图中。我已经知道如何实现它,并且在除三星 Galaxy S3 之外的所有设备上都能正常工作。
我想要什么:避免三星 Galaxy S3 中出现的强制关闭问题,可能适用于我尚未测试的所有其他设备。
我做了什么:我已经完成了下面的代码来实现我的目标。
BuildInukshk_4 活动:
package com.inukshk.CreateInukshk;
import java.util.Calendar;
import android.app.Activity;
import android.app.AlertDialog;
import android.content.ContentResolver;
import android.content.ContentValues;
import android.content.DialogInterface;
import android.content.DialogInterface.OnDismissListener;
import android.content.Intent;
import android.database.Cursor;
import android.graphics.Bitmap;
import android.graphics.BitmapFactory;
import android.net.Uri;
import android.os.Bundle;
import android.os.Environment;
import android.os.StatFs;
import android.provider.MediaStore;
import android.util.Log;
import android.view.ContextMenu;
import android.view.ContextMenu.ContextMenuInfo;
import android.view.MenuItem;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.ImageView;
import android.widget.TextView;
import android.widget.Toast;
import com.inukshk.R;
import com.inukshk.constant.ImageCurve;
public class BuildInukshk_4 extends Activity implements OnClickListener,
OnDismissListener
String TAG = "BuildInukshk_4";
Button btn_back, btn_upload_picture;
TextView txt_next;
public static Activity BuildInukshk_4Activity;
// Upload Camera
public static String media = null;
public static String media_thumb = null;
public static String media_type = null;
AlertDialog dialog;
String _path, Place = "";
ImageView imageView;
boolean flag = true;
Uri uriVideo = null, mCapturedImageURI = null;
private static final int SELECT_PICTURE = 1;
private String selectedImagePath = "";
Uri selectedImageUri = null;
private String filemanagerstring;
Bitmap mBitmap;
// From Transperant
ContentResolver crThumb;
private static final int CAMERA_PIC_REQUEST = 2500, VIDEO_REQUEST_CODE = 3;
final static int REQUEST_VIDEO_CAPTURED = 2;
BitmapFactory.Options options;
String fileName;
long id, imageid;
Cursor cursor, cursorimage, thumbCursor;
private String selectedthumbpath = "";
boolean finish = false;
// ADDED12324
// private String filemanagerstring;
Bitmap curThumb = null, curThumb1 = null;
String[] thumbColumns = MediaStore.Video.Thumbnails.DATA,
MediaStore.Video.Thumbnails.VIDEO_ID ;
String[] mediaColumns = MediaStore.Video.Media._ID,
MediaStore.Video.Media.DATA ;
String[] imageColumns = MediaStore.Images.Media._ID,
MediaStore.Images.Media.DATA ;
@Override
protected void onCreate(Bundle savedInstanceState)
// TODO Auto-generated method stub
super.onCreate(savedInstanceState);
setContentView(R.layout.buildinukshk_4);
BuildInukshk_4Activity = this;
btn_back = (Button) findViewById(R.id.btn_back);
btn_back.setOnClickListener(this);
btn_upload_picture = (Button) findViewById(R.id.btn_upload_picture);
btn_upload_picture.setOnClickListener(this);
txt_next = (TextView) findViewById(R.id.txt_next);
txt_next.setOnClickListener(this);
imageView = (ImageView) findViewById(R.id.img_upload_pic);
@Override
public void onClick(View v)
// TODO Auto-generated method stub
if (v == txt_next)
if (selectedImagePath.equals(""))
Toast.makeText(BuildInukshk_4.this,
"Please Upload Picture First", 3).show();
else
startActivity(new Intent(BuildInukshk_4.this,
BuildInukshk_5.class));
// this.finish();
else if (v == btn_back)
// startActivity(new Intent(BuildInukshk_4.this,
// BuildInukshk_3.class));
this.finish();
else if (v == btn_upload_picture)
registerForContextMenu(btn_upload_picture);
openContextMenu(btn_upload_picture);
@Override
public void onCreateContextMenu(ContextMenu menu, View v,
ContextMenuInfo menuInfo)
// TODO Auto-generated method stub
Log.i(TAG, "Inside onCreateContextMenu");
super.onCreateContextMenu(menu, v, menuInfo);
if (v == btn_upload_picture)
menu.setHeaderTitle("Upload Media");
menu.add(0, v.getId(), 0, "Photo");
@Override
public boolean onContextItemSelected(MenuItem item)
// TODO Auto-generated method stub
if (item.getTitle() == "Photo")
media_type = "image";
// media_thumb = null;
/*
* Intent intent = new Intent(getApplicationContext(),
* Transperant.class); intent.putExtra("MEDIA_TYPE", media_type);
* startActivity(intent);
*/
ImageChooseOptionDialog();
// ImageChooseOptionDialog();
return super.onContextItemSelected(item);
// Transperant Class
private void ImageChooseOptionDialog()
// finish = true;
Log.i(TAG, "Inside ImageChooseOptionDialog");
dialog = new AlertDialog.Builder(BuildInukshk_4.this).create();
dialog.setTitle("Upload Photo");
dialog.setMessage("Choose your Photo From here.");
dialog.setOnDismissListener(this);
dialog.setButton("Camera", new DialogInterface.OnClickListener()
public void onClick(DialogInterface dialog, int whichButton)
// dialog.dismiss();
Log.i(TAG, "Inside ImageChooseOptionDialog inside camera");
Boolean isSDPresent = android.os.Environment
.getExternalStorageState().equals(
android.os.Environment.MEDIA_MOUNTED);
mCapturedImageURI = null;
if (isSDPresent)
// yes SD-card is present
StatFs stat = new StatFs(Environment
.getExternalStorageDirectory().getPath());
long bytesAvailable = (long) stat.getBlockSize()
* (long) stat.getAvailableBlocks();
long megAvailable = bytesAvailable / (1024 * 1024);
Log.e("", "Available MB : " + megAvailable);
if (megAvailable > 2)
Calendar cal = Calendar.getInstance();
_path = cal.getTimeInMillis() + ".jpg";
String fileName = _path;
// File file = new File(_path);
// mCapturedImageURI = Uri.fromFile(file);
ContentValues values = new ContentValues();
values.put(MediaStore.Images.Media.TITLE, fileName);
mCapturedImageURI = getContentResolver().insert(
MediaStore.Images.Media.EXTERNAL_CONTENT_URI,
values);
Log.d(TAG, "----- path ----- " + _path);
Intent intent = new Intent(
android.provider.MediaStore.ACTION_IMAGE_CAPTURE);
intent.putExtra(MediaStore.EXTRA_OUTPUT,
mCapturedImageURI);
Log.d(TAG, "----- mCapturedImageURI ******----- "
+ mCapturedImageURI);
startActivityForResult(intent, 1212);
flag = false;
else
Toast.makeText(BuildInukshk_4.this,
"No Memory Available", 2).show();
flag = true;
else
// Sorry
// StatFs stat = new StatFs(Environment.getDataDirectory()
// .getPath());
// long bytesAvailable = (long) stat.getBlockSize()
// * (long) stat.getAvailableBlocks();
// long megAvailable = bytesAvailable / (1024 * 1024);
// Log.e("", "Internal MB : " + megAvailable);
// if (megAvailable > 2)
// startActivityForResult(new Intent(Transperant.this,
// VideoRecorder.class), REQUEST_VIDEO_CAPTURED);
//
// flag = false;
// else
Toast.makeText(BuildInukshk_4.this, "No Memory Available",
2).show();
flag = true;
//
// Toast.makeText(Transperant.this, "No External Storage",
// 2)
// .show();
);
dialog.setButton2("Gallery", new DialogInterface.OnClickListener()
public void onClick(DialogInterface dialog, int whichButton)
Log.i(TAG, "Inside Gallary");
Log.i(TAG, "Inside ImageChooseOptionDialog inside camera");
// dialog.dismiss();
Intent intent = new Intent();
intent.setType("image/*");
intent.setAction(Intent.ACTION_GET_CONTENT);
startActivityForResult(
Intent.createChooser(intent, "Select Picture"),
SELECT_PICTURE);
flag = false;
);
dialog.show();
@Override
public void onDismiss(DialogInterface dialog)
// TODO Auto-generated method stub
public String getPath(Uri uri)
String[] projection = MediaStore.Images.Media.DATA ;
Cursor cursor = managedQuery(uri, projection, null, null, null);
if (cursor != null)
// HERE YOU WILL GET A NULLPOINTER IF CURSOR IS NULL
// THIS CAN BE, IF YOU USED OI FILE MANAGER FOR PICKING THE MEDIA
int column_index = cursor
.getColumnIndexOrThrow(MediaStore.Images.Media.DATA);
cursor.moveToFirst();
return cursor.getString(column_index);
else
return null;
public void onActivityResult(int requestCode, int resultCode,
final Intent data)
crThumb = getContentResolver();
options = new BitmapFactory.Options();
options.inSampleSize = 1;
Log.i(TAG, "Inside onActivityResult");
if (requestCode == SELECT_PICTURE)
if (resultCode == RESULT_OK)
Log.i(TAG, "SELECT_PICTURE");
selectedImageUri = data.getData();
// filemanagerstring = selectedImageUri.getPath();
selectedImagePath = getPath(selectedImageUri);
if (selectedImagePath != null)
BuildInukshk_4.media = selectedImagePath;
Log.e("Image path", selectedImagePath);
mBitmap = BitmapFactory.decodeFile(media);
if (mBitmap != null)
Log.i(TAG, "Inside Set Image");
imageView.setImageBitmap(mBitmap);
// selectedthumbpath = null;
// Testimage();
// // curThumb1 = MediaStore.Images.Thumbnails.getThumbnail(
// // crThumb, imageid,
// // MediaStore.Video.Thumbnails.MICRO_KIND, options);
//
// Cursor thumbCursorimage = managedQuery(
// MediaStore.Images.Thumbnails.EXTERNAL_CONTENT_URI,
// imageColumns, MediaStore.Images.Thumbnails.IMAGE_ID
// + "=" + imageid, null, null);
//
// Log.e("Transarerant",
// "--- inside do TEst Image cusor 2nd -- "
// + thumbCursorimage.getCount());
// if (thumbCursorimage.moveToFirst())
// selectedthumbpath = thumbCursorimage
// .getString(thumbCursorimage
// .getColumnIndex(MediaStore.Images.Thumbnails.DATA));
// // selectedthumbpath = new
// Log.e("PathofThumb", selectedthumbpath);
// BuildInukshk_4.media_thumb = selectedthumbpath;
//
else if (requestCode == VIDEO_REQUEST_CODE)
else if (requestCode == REQUEST_VIDEO_CAPTURED)
else if (requestCode == 1212)
if (resultCode == RESULT_OK)
Log.i(TAG, "Inside IF CONDITIONS in Camera");
Log.i(TAG, "mCptureURI :" + mCapturedImageURI);
String[] projection = MediaStore.Images.Media.DATA ;
Cursor cursor = managedQuery(mCapturedImageURI, projection,
null, null, null);
int column_index_data = cursor
.getColumnIndexOrThrow(MediaStore.Images.Media.DATA);
cursor.moveToFirst();
selectedImagePath = cursor.getString(column_index_data);
Log.e("Image path", selectedImagePath);
BuildInukshk_4.media = selectedImagePath;
mBitmap = BitmapFactory.decodeFile(media);
if (mBitmap != null)
Log.i(TAG, "Inside Set Image");
// mBitmap = ImageCurve.GetCurveImage(mBitmap);
imageView.setImageBitmap(mBitmap);
// selectedthumbpath = null;
// Testimage();
// curThumb1 =
// MediaStore.Images.Thumbnails.getThumbnail(crThumb,
// imageid, MediaStore.Video.Thumbnails.MICRO_KIND,
// options);
//
// Cursor thumbCursorimage = managedQuery(
// MediaStore.Images.Thumbnails.EXTERNAL_CONTENT_URI,
// imageColumns, MediaStore.Images.Thumbnails.IMAGE_ID
// + "=" + imageid, null, null);
//
// Log.e("Transarerant",
// "--- inside do TEst Image cusor 2nd -- "
// + thumbCursorimage.getCount());
// if (thumbCursorimage.moveToFirst())
// selectedthumbpath = thumbCursorimage
// .getString(thumbCursorimage
// .getColumnIndex(MediaStore.Images.Thumbnails.DATA));
// // selectedthumbpath = new
// Log.e("PathofThumb", selectedthumbpath);
// BuildInukshk_4.media_thumb = selectedthumbpath;
如果我在这里犯了错误,这也是我的清单文件:
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.inukshk"
android:versionCode="1"
android:versionName="1.0" >
<uses-sdk
android:minSdkVersion="8"
android:targetSdkVersion="15" />
<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" />
<uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" />
<uses-permission android:name="android.permission.INTERNET" />
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
<!-- FOR Camera -->
<uses-permission android:name="android.permission.CAMERA" />
<uses-feature android:name="android.hardware.camera.autofocus" />
<uses-permission android:name="android.permission.VIBRATE" />
<uses-permission android:name="android.permission.FLASHLIGHT" />
<!-- Don't require camera, as this requires a rear camera. This allows it to work on the Nexus 7 -->
<uses-feature
android:name="android.hardware.camera"
android:required="false" />
<uses-feature
android:name="android.hardware.camera.front"
android:required="false" />
<uses-feature
android:name="android.hardware.camera.autofocus"
android:required="false" />
<uses-feature
android:name="android.hardware.camera.flash"
android:required="false" />
<uses-feature android:name="android.hardware.screen.landscape" />
<uses-feature
android:name="android.hardware.wifi"
android:required="false" />
<uses-feature
android:name="android.hardware.touchscreen"
android:required="false" />
<uses-feature android:name="android.hardware.camera" />
<application
android:icon="@drawable/app_icon_final"
android:label="@string/app_name"
android:theme="@android:style/Theme.NoTitleBar" >
<uses-library android:name="com.google.android.maps" />
<activity
android:name=".SplashScreen"
android:label="@string/title_activity_main"
android:screenOrientation="sensorPortait" >
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
<activity
android:name=".MainActivity"
android:screenOrientation="sensorPortait" />
<activity
android:name=".login.LoginActivity"
android:screenOrientation="sensorPortait"
android:windowSoftInputMode="stateHidden" />
<activity
android:name=".WhereAmI.WhereAmI"
android:screenOrientation="sensorPortait" />
<activity
android:name=".WhosNearMe.WhosNearMe"
android:screenOrientation="sensorPortait" />
<activity
android:name=".WhatsNearMe.WhatsNearMe"
android:screenOrientation="sensorPortait" />
<activity
android:name=".CreateInukshk.CreateInukshk"
android:screenOrientation="sensorPortait"
android:windowSoftInputMode="adjustPan" />
<activity
android:name=".CreateInukshk.BuildInukshk_1"
android:screenOrientation="sensorPortait"
android:windowSoftInputMode="adjustPan" />
<activity
android:name=".CreateInukshk.BuildInukshk_2"
android:screenOrientation="sensorPortait"
android:windowSoftInputMode="adjustPan" />
<activity
android:name=".CreateInukshk.BuildInukshk_3"
android:screenOrientation="sensorPortait"
android:windowSoftInputMode="adjustPan" />
<activity
android:name=".CreateInukshk.BuildInukshk_4"
android:screenOrientation="sensorPortait"
android:windowSoftInputMode="adjustPan" />
<activity
android:name=".CreateInukshk.BuildInukshk_5"
android:screenOrientation="sensorPortait"
android:windowSoftInputMode="adjustPan" />
<activity
android:name=".tTab.TabSample"
android:screenOrientation="sensorPortait"
android:windowSoftInputMode="adjustPan" />
<activity
android:name=".register.RegisterActivity"
android:screenOrientation="sensorPortait"
android:windowSoftInputMode="adjustPan" />
<activity
android:name=".Transperant"
android:screenOrientation="sensorPortait" />
<activity
android:name=".HomeActivity"
android:screenOrientation="sensorPortait" />
<activity
android:name=".AfterSplash"
android:screenOrientation="sensorPortait" />
<activity
android:name=".login.ForgotPasswordActivity"
android:screenOrientation="sensorPortait" />
<activity
android:name=".settings.MyProfile"
android:screenOrientation="sensorPortait"
android:windowSoftInputMode="adjustPan" />
<activity
android:name=".settings.MyInterests"
android:screenOrientation="sensorPortait"
android:windowSoftInputMode="adjustPan" />
<activity
android:name=".settings.InukshkSettings"
android:screenOrientation="sensorPortait" />
<activity
android:name=".settings.MyPicture"
android:screenOrientation="sensorPortait" />
<activity
android:name=".settings.MyInukshks"
android:screenOrientation="sensorPortait" />
<activity
android:name=".settings.ChangePassword"
android:screenOrientation="sensorPortait" />
</application>
</manifest>
我在许多 SO 链接中搜索过这个问题,但没有找到适合我的解决方案。请帮助我摆脱困境。
我想在此说明,我没有用于测试此问题的真实设备。 但是我的客户在真实设备上遇到了这个问题。我制作了一个和 S3 一样的模拟器,它在各种场景下都可以毫无顾虑地工作。我不知道为什么这只发生在真实设备上。
提前致谢
已编辑:我已经通过修改以下代码解决了上述问题并将其作为答案。你可以在阅读问题后看看。
【问题讨论】:
@GabeSechan:感谢您的支持。但正如我所说,我没有真正的设备。在模拟器和我拥有的任何真实设备中捕获图像时我没有收到任何错误。但是客户端在仅在三星 Galaxy S3 中捕获图像时遇到问题。 看看这些代码String fileName = _path; File file = new File(fileName); if(!file.exist()) file.createNewFile();
一定能解决你的问题。在将其 Uri 传递给 Camera Intent 之前,您必须制作文件。试试这个,让我知道会发生什么..
看***.com/questions/14295906/…
@Bhavesh:如果用户提交了强制关闭报告,您可以从开发者控制台获取它们。
@Bhavesh:如果您希望有人尝试运行它,请将您的整个项目发布到某个地方并链接它。我会为你在 S3 上运行它,然后告诉你会发生什么。
【参考方案1】:
我已经为这个单一问题花费了很多时间,并且通过如下修改代码使代码在大多数设备中都能正常工作:
以后遇到同样问题的人可以试试下面的代码。
在调用图像捕获意图时:
String storageState = Environment.getExternalStorageState();
if (storageState.equals(Environment.MEDIA_MOUNTED))
Intent intent = new Intent(
MediaStore.ACTION_IMAGE_CAPTURE);
String filename = System.currentTimeMillis() + ".jpg";
ContentValues values = new ContentValues();
values.put(MediaStore.Images.Media.TITLE, filename);
mImageCaptureUri = getContentResolver().insert(
MediaStore.Images.Media.EXTERNAL_CONTENT_URI,
values);
intent.putExtra(
android.provider.MediaStore.EXTRA_OUTPUT,
mImageCaptureUri);
try
startActivityForResult(intent, PICK_FROM_CAMERA);
catch (ActivityNotFoundException e)
e.printStackTrace();
else
new AlertDialog.Builder(BuildInukshk_4_Camera.this)
.setMessage(
"External Storeage (SD Card) is required.\n\nCurrent state: "
+ storageState)
.setCancelable(true).create().show();
else // pick from file
Intent intent = new Intent();
intent.setType("image/*");
intent.setAction(Intent.ACTION_GET_CONTENT);
startActivityForResult(Intent.createChooser(intent,
"Complete action using"), PICK_FROM_FILE);
OnActivityResult 方法内部:
case PICK_FROM_CAMERA:
Log.i("TAG", "Inside PICK_FROM_CAMERA");
// Final Code As Below
try
Log.i("TAG", "inside Samsung Phones");
String[] projection =
MediaStore.Images.Thumbnails._ID, // The columns we want
MediaStore.Images.Thumbnails.IMAGE_ID,
MediaStore.Images.Thumbnails.KIND,
MediaStore.Images.Thumbnails.DATA ;
String selection = MediaStore.Images.Thumbnails.KIND + "=" + // Select
// only
// mini's
MediaStore.Images.Thumbnails.MINI_KIND;
String sort = MediaStore.Images.Thumbnails._ID + " DESC";
// At the moment, this is a bit of a hack, as I'm returning ALL
// images, and just taking the latest one. There is a better way
// to
// narrow this down I think with a WHERE clause which is
// currently
// the selection variable
Cursor myCursor = this.managedQuery(
MediaStore.Images.Thumbnails.EXTERNAL_CONTENT_URI,
projection, selection, null, sort);
long imageId = 0l;
long thumbnailImageId = 0l;
String thumbnailPath = "";
try
myCursor.moveToFirst();
imageId = myCursor
.getLong(myCursor
.getColumnIndexOrThrow(MediaStore.Images.Thumbnails.IMAGE_ID));
thumbnailImageId = myCursor
.getLong(myCursor
.getColumnIndexOrThrow(MediaStore.Images.Thumbnails._ID));
thumbnailPath = myCursor
.getString(myCursor
.getColumnIndexOrThrow(MediaStore.Images.Thumbnails.DATA));
finally
// myCursor.close();
// Create new Cursor to obtain the file Path for the large image
String[] largeFileProjection =
MediaStore.Images.ImageColumns._ID,
MediaStore.Images.ImageColumns.DATA ;
String largeFileSort = MediaStore.Images.ImageColumns._ID
+ " DESC";
myCursor = this.managedQuery(
MediaStore.Images.Media.EXTERNAL_CONTENT_URI,
largeFileProjection, null, null, largeFileSort);
String largeImagePath = "";
try
myCursor.moveToFirst();
// This will actually give yo uthe file path location of the
// image.
largeImagePath = myCursor
.getString(myCursor
.getColumnIndexOrThrow(MediaStore.Images.ImageColumns.DATA));
mImageCaptureUri_samsung = Uri.fromFile(new File(
largeImagePath));
mImageCaptureUri = null;
finally
// myCursor.close();
// These are the two URI's you'll be interested in. They give
// you a
// handle to the actual images
Uri uriLargeImage = Uri.withAppendedPath(
MediaStore.Images.Media.EXTERNAL_CONTENT_URI,
String.valueOf(imageId));
Uri uriThumbnailImage = Uri.withAppendedPath(
MediaStore.Images.Thumbnails.EXTERNAL_CONTENT_URI,
String.valueOf(thumbnailImageId));
// I've left out the remaining code, as all I do is assign the
// URI's
// to my own objects anyways...
catch (Exception e)
mImageCaptureUri_samsung = null;
Log.i("TAG",
"inside catch Samsung Phones exception " + e.toString());
try
Log.i("TAG",
"URI Samsung:" + mImageCaptureUri_samsung.getPath());
catch (Exception e)
Log.i("TAG", "Excfeption inside Samsung URI :" + e.toString());
try
Log.i("TAG", "URI Normal:" + mImageCaptureUri.getPath());
catch (Exception e)
Log.i("TAG", "Excfeption inside Normal URI :" + e.toString());
break;
在代码下方运行后,您将获得两个 URI mImageCaptureUri_samsung
和 mImageCaptureUri
如果您使用简单设备运行应用程序,您将获得 mImageCaptureUri 作为您的路径,如果您使用三星 Galaxy S3 等设备运行,您将在 mImageCaptureUri_samsung 中获得您的 Cpatured Image 路径。
您还可以继续编写您的代码。它适用于我测试过的所有设备。
此外,如果有人对上述代码有疑问,他们可以参考下面的大链接Solution of Samsung Galaxy S3
希望它会有所帮助。
【讨论】:
谢谢,但您在这里发布了大约 500 行代码。你能做些什么来查明具体问题并解决吗? @gcl1 :感谢您的建议。我已经更新了我的答案。 非常感谢您的快速回复。会试一试的,干杯。 我通读了您提供的代码和参考。在哪里/如何测试以确定使用哪个 URI(mImageCaptureUri 与 mImageCaptureUri_samsung)? @gcl1:捕获图片后,您只需检查是否'mImageCaptureUri_samsung==null'?如果是,那么您将不得不使用“mImageCaptureUri”URI。我希望它对你来说很清楚。如果您还有任何问题,请告诉我。以上是关于三星 Galaxy S3 4.1.1 版中的相机强制关闭问题的主要内容,如果未能解决你的问题,请参考以下文章
三星 Galaxy S3 上的 Android 相机预览不正确
三星 Galaxy S3、S4、S5 的 Android 相机/图片方向问题
三星 Galaxy s3 4.1.1 和 4.1.2 上的 Canvas globalCompositeOperation 问题