Android中使用Camera2开发聚焦,前后摄像头切换的拍照功能

使用Camera2开发照相机功能,可以进行重复拍照,刚开始拍照是好的,但是重复拍照的时候就会报错如下,有时候第一次拍照就报错,有时候拍了几十张后报错,报错就是闪退

E/AndroidRuntime: FATAL EXCEPTION: LegacyCameraCallback
    Process: com.ajmd.hais.mobile, PID: 24711
    java.lang.NullPointerException: Attempt to invoke virtual method 'android.view.Surface android.hardware.camera2.params.OutputConfiguration.getSurface()' on a null object reference
        at android.hardware.camera2.impl.CameraDeviceImpl$CameraDeviceCallbacks.onCaptureErrorLocked(CameraDeviceImpl.java:1925)
        at android.hardware.camera2.impl.CameraDeviceImpl$CameraDeviceCallbacks.onDeviceError(CameraDeviceImpl.java:1693)
        at android.hardware.camera2.legacy.CameraDeviceUserShim$CameraCallbackThread$CallbackHandler.handleMessage(CameraDeviceUserShim.java:299)
        at android.os.Handler.dispatchMessage(Handler.java:102)
        at android.os.Looper.loop(Looper.java:154)
        at android.os.HandlerThread.run(HandlerThread.java:61)

1个回答

有可能是内存释放导致返回的流为空导致的,建议拍照之前清一下内容,另外就是拍照以后释放流。

u013835855
山洼之神 回复zf_1021042350: 相机要考虑适配和内存问题的,拍照很耗费资源,你要注意释放资源,否则就很容易出现闪退的情况,日志应该可以看到内存溢出了
大约 2 个月之前 回复
zf_1021042350
「已注销」 感谢回答,本人是java web开发,最近公司android工程师离职,我是暂时临时顶替的,android这块还不了解,就是网上download了一个demo改一改,但是出来了这个问题,老哥你说的清一下内容是指清什么,是ImageReader,CamearManager,Surface这些对象吗
大约 2 个月之前 回复
Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
关于安卓开发中Camera中切换前后摄像头切换的问题,怎么切换
用的是http://www.cnblogs.com/mengdd/archive/2013/04/06/3002975.html 上的代码 怎么实现 求助,弄了一天没搞懂啊
基于Android camera2的相机开发
最近在开发Android相机,需要调用相机硬件的快门和ISO数据,我曾经用了华为手机来开发,由于双摄像头在录制的时候会崩溃就买了一台小米5来继续开发。令人崩溃的是小米5貌似不开放底层的相机参数,在想要获取ISO及快门的取值范围时返回为空。 现在我有点不知道怎么办了。 下面是我用的代码,就是在这一段出问题,希望有经验的朋友能不能给点意见。 ``` //获取ISO范围 Range<Integer> range1 = characteristics.get(CameraCharacteristics.SENSOR_INFO_SENSITIVITY_RANGE); //获取快门范围 Range<Long> range2 = characteristics.get(CameraCharacteristics.SENSOR_INFO_EXPOSURE_TIME_RANGE); //获取帧间隔范围 Long max3 = characteristics.get(CameraCharacteristics.SENSOR_INFO_MAX_FRAME_DURATION); int max1 = range1.getUpper();//华为P9最大值为3500 int min1 = range1.getLower();//华为P9最小值为100 Long max2 = range2.getUpper()/10 ;//华为P9最大值1s Long min2 = range2.getLower()/200 ;//华为p9最小值100ns int iso = ((Progress[0] * (max1 - min1)) / 100 + min1); Long exposure = ((Progress[1] * (max2 - min2)) / 100 + min2); Long frame = max3 / 1000; //以下分别为ISO,快门,帧间隔 mPreviewBuilder.set(CaptureRequest.SENSOR_SENSITIVITY, iso); mPreviewBuilder.set(CaptureRequest.SENSOR_EXPOSURE_TIME, exposure); mPreviewBuilder.set(CaptureRequest.SENSOR_FRAME_DURATION, frame); ```
android 原生camera app无法正常切换前后置摄像头
平台是RK3399,系统需要兼容CSI摄像头和一个可拔插的UVC摄像头,从驱动层面来讲, 先注册的摄像头是video0,后注册的是video1,因为UVC驱动是以模块的方式加载,所以其 分配到的设备节点是video1,但是camera hal无法正常识别UVC的拔插,如何处理?
android camera2拍照不稳定
在android中使用camera2的API进行拍照,一会儿正常一会儿黑乎乎的,有没有人知道是怎么回事?测试机型是华为mate8.
在手机的Camera已经打开情况下,如何使用adb shell命令切换Camera前后摄像头?
在Android系统中,当Camera已经打开了, 但是想通过adb命令来控制选择前后摄像头,请问有什么办法,命令是多少? 当前知道的adb操作手机命令: 点亮/关闭屏幕 adb shell input keyevent 26 设置手机休眠时间 adb shell settings gett system screen_off_timeout(查看手机休眠时间) adb shell settings put system screen_off_timeout 600000(10分钟) adb shell settings put system screen_off_timeout 2147483647(常亮) 打开camera adb shell am start -a android.media.action.STILL_IMAGE_CAMERA
android是如何打开除前后摄像头外的摄像头的?
android是如何打开除前后摄像头外的摄像头的? android打开摄像头用的是camera类,最终调用到HAL层的camera部分,get_num_of cameras返回成员变量,而这个成员变量只在构造函数处赋值为常量2.所以有上面的疑问。 已知小米pad是可以打开usb摄像头的。
Android Camera2 如何同时前后摄像头录像?
同时预览preview能实现,点击按钮进行同时录像怎么做?(要解决线程问题) ![图片说明](https://img-ask.csdn.net/upload/201903/06/1551844380_957834.jpg) 有酬!
使用Android Camera2如何设置调节摄像头的亮度,饱和度,对比度?
![图片说明](https://img-ask.csdn.net/upload/201608/02/1470118474_515701.png) 如图,使用Camera2Master的demo,上面有调节曝光度的功能,我想对摄像头的亮度,饱和度,对比度进行调节,想问怎么实现?看了看5.0的API中CaptureRequest并没有提供相关的方法,求大神告知
关于安卓摄像头切换问题
bt_change.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { mCamera.stopPreview(); mCamera.release(); mCamera =null; mCamera = Camera.open(1); mPreview.setCamera(mCamera); mCamera.startPreview(); } }); mPreview是一个CameraPreview类 我点击按钮切换摄像头后,预览画面就不动了,定格为一张照片。然后我点击拍照的时候,拍出来的图片我打开后却是用前置摄像头的照片,意思是我切换摄像头后看不到自己的预览画面
android打开系统前置摄像头失败,总是打开后置摄像头
我想直接调用手机系统的前置摄像头,不用自定义相机。 三星、华为不能打开前置摄像头,每次都是打开后置摄像头。 vivo 魅族 小米 oppo可以正常打开前置摄像头。 特此请教各路大神,谢谢! ``` Intent cameraIntent = new Intent(MediaStore.ACTION_IMAGE_CAPTURE); cameraIntent.putExtra("android.intent.extras.CAMERA_FACING", 1);//这里试过值0,1,2 三星,华为均无效 startActivity(cameraIntent); ``` 请大神指点迷津。
Vuforia在8.1.7版本更新时移除了对前置摄像头的支持,该怎样自己切换?
现在使用的是亮风台的G200眼镜,他有两个摄像头,眼镜上的是200w像素,和眼镜连接的手持物体中有个1600W像素的摄像头,现在默认摄像头是200w这个,想切换成另一个摄像头。在Vuforia8.1.7版本更新时移除了对前置摄像头的支持,现在只能访问后置摄像头(Front camera support has been removed. You can now only access the back camera)大家有什么切换的办法吗?
Android Camera2的使用到底是哪里错了?
![图片说明](https://img-ask.csdn.net/upload/201602/25/1456395899_171582.png) 代码如下: public class CameraTwoActivity extends AppCompatActivity implements TextureView.SurfaceTextureListener { @Bind(R.id.textureview) android.view.TextureView mPreviewView; private Handler mHandler; private HandlerThread mThreadHandler; private Size mPreviewSize=null; private CaptureRequest.Builder mPreviewBuilder; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.camera_activity); ButterKnife.bind(this); mThreadHandler = new HandlerThread("CAMERA2"); mThreadHandler.start(); mHandler = new Handler(mThreadHandler.getLooper()); mPreviewView.setSurfaceTextureListener(this); } @TargetApi(Build.VERSION_CODES.LOLLIPOP) public void onSurfaceTextureAvailable(SurfaceTexture surface, int width, int height) { try { //获得CameraManager CameraManager cameraManager = (CameraManager) getSystemService(Context.CAMERA_SERVICE); //获得属性 CameraCharacteristics characteristics = cameraManager.getCameraCharacteristics("0"); //支持的STREAM CONFIGURATION StreamConfigurationMap map = characteristics.get(CameraCharacteristics.SCALER_STREAM_CONFIGURATION_MAP); //显示的size mPreviewSize = map.getOutputSizes(SurfaceTexture.class)[0]; //打开相机 if (ActivityCompat.checkSelfPermission(this, Manifest.permission.CAMERA) != PackageManager.PERMISSION_GRANTED) { // TODO: Consider calling // ActivityCompat#requestPermissions // here to request the missing permissions, and then overriding // public void onRequestPermissionsResult(int requestCode, String[] permissions, // int[] grantResults) // to handle the case where the user grants the permission. See the documentation // for ActivityCompat#requestPermissions for more details. return; } cameraManager.openCamera("0", mCameraDeviceStateCallback, mHandler); } catch (Exception e) { e.printStackTrace(); } } @Override public void onSurfaceTextureSizeChanged(SurfaceTexture surface, int width, int height) { } @Override public boolean onSurfaceTextureDestroyed(SurfaceTexture surface) { return false; } //TextureView.SurfaceTextureListener @Override public void onSurfaceTextureUpdated(SurfaceTexture surface) { } private CameraDevice.StateCallback mCameraDeviceStateCallback = new CameraDevice.StateCallback() { @Override public void onOpened(CameraDevice camera) { try { startPreview(camera); } catch (CameraAccessException e) { e.printStackTrace(); } } @Override public void onDisconnected(CameraDevice camera) { } @Override public void onError(CameraDevice camera, int error) { } }; //开始预览,主要是camera.createCaptureSession这段代码很重要,创建会话 private void startPreview(CameraDevice camera) throws CameraAccessException { SurfaceTexture texture = mPreviewView.getSurfaceTexture(); texture.setDefaultBufferSize(mPreviewSize.getWidth(), mPreviewSize.getHeight()); Surface surface = new Surface(texture); Log.i(getClass().getName(),"1111"); try { mPreviewBuilder = camera.createCaptureRequest(CameraDevice.TEMPLATE_PREVIEW); } catch (CameraAccessException e) { Log.i(getClass().getName(),"2222"); e.printStackTrace(); } Log.i(getClass().getName(),"3333"); mPreviewBuilder.addTarget(surface); camera.createCaptureSession(Arrays.asList(surface), mSessionStateCallback, mHandler); } private CameraCaptureSession.StateCallback mSessionStateCallback = new CameraCaptureSession.StateCallback() { @Override public void onConfigured(CameraCaptureSession session) { try { updatePreview(session); } catch (CameraAccessException e) { e.printStackTrace(); } } @Override public void onConfigureFailed(CameraCaptureSession session) { } }; private void updatePreview(CameraCaptureSession session) throws CameraAccessException { session.setRepeatingRequest(mPreviewBuilder.build(), null, mHandler); } }
android 自定义camera 自动拍照
可以自动拍照的是魅族android版本5.01,不能自动拍照的是android版本5.1。是系统问题吗? 自动拍照功能在一些手机上可以使用,一些不能用。求原因 。坐等答案。 ``` public class CameraActivity extends Activity { private CameraView view; public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); getWindow().clearFlags( WindowManager.LayoutParams.FLAG_FORCE_NOT_FULLSCREEN); getWindow().addFlags(WindowManager.LayoutParams.FLAG_LAYOUT_IN_SCREEN); requestWindowFeature(Window.FEATURE_NO_TITLE);// 设置横屏模式以及全屏模式 view = new CameraView(this);// 通过一个surfaceview的view来实现拍照 view.setId(1); view = new CameraView(this, this); setContentView(R.layout.camera_layout); RelativeLayout relative = (RelativeLayout) this.findViewById(R.id.ly); RelativeLayout.LayoutParams Layout = new RelativeLayout.LayoutParams(3, 3);// 设置surfaceview使其满足需求无法观看预览 Layout.addRule(RelativeLayout.ALIGN_PARENT_BOTTOM, 1); Layout.addRule(RelativeLayout.ALIGN_PARENT_RIGHT, 1); relative.addView(view, Layout); } } (2) CameraView.java package com.camera.test; import java.io.File; import java.io.FileOutputStream; import java.io.IOException; import java.text.SimpleDateFormat; import java.util.Date; import android.app.Activity; import android.content.Context; import android.graphics.Bitmap; import android.graphics.BitmapFactory; import android.graphics.Point; import android.graphics.PointF; import android.hardware.Camera; import android.hardware.Camera.AutoFocusCallback; import android.hardware.Camera.ShutterCallback; import android.media.AudioManager; import android.media.FaceDetector; import android.media.FaceDetector.Face; import android.os.Environment; import android.os.Handler; import android.view.SurfaceHolder; import android.view.SurfaceView; import android.widget.Toast; public class CameraView extends SurfaceView implements SurfaceHolder.Callback, Camera.PictureCallback { private SurfaceHolder holder; private Camera camera; private Camera.Parameters parameters; private Activity act; private Handler handler = new Handler(); private Context context; private SurfaceView surfaceView; private AudioManager audio; private int current; public CameraView(Context context) { super(context); surfaceView = this; audio = (AudioManager) context.getSystemService(Context.AUDIO_SERVICE); final int current = audio.getRingerMode(); audio.setRingerMode(AudioManager.RINGER_MODE_SILENT); this.context = context; holder = getHolder();// 生成Surface Holder holder.addCallback(this); holder.setType(SurfaceHolder.SURFACE_TYPE_PUSH_BUFFERS);// 指定Push Buffer handler.postDelayed(new Runnable() { @Override public void run() { if (camera == null) { handler.postDelayed(this, 1 * 1000);// 由于启动camera需要时间,在此让其等两秒再进行聚焦知道camera不为空 } else { camera.autoFocus(new AutoFocusCallback() { @Override public void onAutoFocus(boolean success, Camera camera) { if (success) { camera.takePicture(new ShutterCallback() {// 如果聚焦成功则进行拍照 @Override public void onShutter() { } }, null, CameraView.this); } else { } } }); } } }, 2 * 1000); } public CameraView(Context context, Activity act) {// 在此定义一个构造方法用于拍照过后把CameraActivity给finish掉 this(context); this.act = act; } @Override public void surfaceCreated(final SurfaceHolder holder) { // TODO Auto-generated method stub camera = Camera.open();// 摄像头的初始化 handler.postDelayed(new Runnable() { @Override public void run() { if (holder != null) { try { camera.setPreviewDisplay(holder); } catch (IOException e) { // TODO Auto-generated catch block e.printStackTrace(); } } else { handler.postDelayed(this, 1 * 1000); } } }, 2 * 1000); } @Override public void surfaceChanged(SurfaceHolder holder, int format, int width, int height) { // TODO Auto-generated method stub parameters = camera.getParameters(); camera.setParameters(parameters);// 设置参数 camera.startPreview();// 开始预览 } @Override public void surfaceDestroyed(SurfaceHolder holder) { // TODO Auto-generated method stub } public void onPictureTaken(byte[] data, Camera camera) {// 拍摄完成后保存照片 try { Date date = new Date(); SimpleDateFormat format = new SimpleDateFormat("yyyyMMddHHmmss"); String time = format.format(date); //在SD卡上创建文件夹 File file = new File(Environment.getExternalStorageDirectory() + "/myCamera/pic"); if (!file.exists()) { file.mkdirs(); } String path = Environment.getExternalStorageDirectory() + "/myCamera/pic/" + time + ".jpg"; data2file(data, path); camera.setPreviewCallback(null); camera.stopPreview(); camera.release(); camera = null; holder.removeCallback(CameraView.this); audio.setRingerMode(current); act.finish(); //uploadFile(path); } catch (Exception e) { } } private void data2file(byte[] w, String fileName) throws Exception {// 将二进制数据转换为文件的函数 FileOutputStream out = null; try { out = new FileOutputStream(fileName); out.write(w); out.close(); } catch (Exception e) { if (out != null) out.close(); throw e; } } // private void uploadFile(String filePath)// 拍照过后上传文件到服务器 // { // } } ```
求助:Android Camera类的onPreviewFrame回调截取ROI区域
Android摄像头项目中需要对onPreviewFrame(byte[] data, Camera camera)回调的data数据直接进行处理(获取其Y分量),并且仅需对获得的每一帧数据的部分区域(ROI)进行处理。求助:如何获取每一帧的ROI区域(不需要保存)进行处理? 例如:我获取的预览帧大小为640*480,我的ROI区域为正中心的50*50区域,我该如何获取这50*50区域的数据? 由于是Android新手,因此概念的理解和问题描述都很混乱,希望各位大神能指点一下!
android camera api2
如何获取相机当前的属性值啊?我想给页面上的SeekBar动态的赋值, 比方说,自动调焦模式下,控制焦距的SeekBar可以跟随自动对焦的焦距值, 不断地刷新变化。 各位大神,这个怎么实现啊?
Camera2 如何同时开启前后摄像头Preview并进行录像?
我按照camera2 谷歌的demo,同时开启两个线程进行相同操作,但是运行时最后一个摄像头能preview出来,前一个停在最后一帧,不能两个同时动。请问如何进行多线程同时操作?本人新手,多线程不太熟悉,求指教! @Override public void onResume() { super.onResume(); if (texture_front.isAvailable()) { openCamera(false,texture_front.getWidth(), texture_front.getHeight()); } else { texture_front.setSurfaceTextureListener(mFrontTextureListener); } if (texture_back.isAvailable()) { openCamera(true,texture_back.getWidth(), texture_back.getHeight()); } else { texture_back.setSurfaceTextureListener(mBackTextureListener); } startBackgroundThread(); } private void startBackgroundThread() { mBackgroundThread_front = new HandlerThread("Camera_front"); mBackgroundThread_front.start(); mHandler_front = new Handler(mBackgroundThread_front.getLooper()); mBackgroundThread_back=new HandlerThread("Camera_back"); mBackgroundThread_back.start(); mHandler_back=new Handler(mBackgroundThread_back.getLooper()); } 接下来OpenCamera方法 private void openCamera(boolean isBack,int width, int height) { if (!hasPermissionsGranted(VIDEO_PERMISSIONS)) { requestVideoPermissions(); return; } final Activity activity = getActivity(); if (null == activity || activity.isFinishing()) { return; } CameraManager manager = (CameraManager) activity.getSystemService(Context.CAMERA_SERVICE); try { L.d("tryAcquire"); if (!getSemaphore(isBack).tryAcquire(2500, TimeUnit.MILLISECONDS)) { throw new RuntimeException("Time out waiting to lock camera opening."); } String cameraId; if (isBack){ cameraId = manager.getCameraIdList()[0]; //0后 1前 // Choose the sizes for camera preview and video recording CameraCharacteristics characteristics = manager.getCameraCharacteristics(cameraId); StreamConfigurationMap map = characteristics .get(CameraCharacteristics.SCALER_STREAM_CONFIGURATION_MAP); mSensorOrientation = characteristics.get(CameraCharacteristics.SENSOR_ORIENTATION); if (map == null) { throw new RuntimeException("Cannot get available preview/video sizes"); } mVideoSize = chooseVideoSize(map.getOutputSizes(MediaRecorder.class)); mPreviewSize = chooseOptimalSize(map.getOutputSizes(SurfaceTexture.class), width, height, mVideoSize); int orientation = getResources().getConfiguration().orientation; if (orientation == Configuration.ORIENTATION_LANDSCAPE) { texture_back.setAspectRatio(mPreviewSize.getWidth(), mPreviewSize.getHeight()); } else { texture_back.setAspectRatio(mPreviewSize.getHeight(), mPreviewSize.getWidth()); } configureTransform(true,width, height); mMediaRecorder = new MediaRecorder(); manager.openCamera(cameraId, mStateCallback_back, null); }else { cameraId = manager.getCameraIdList()[1]; //0后 1前 // Choose the sizes for camera preview and video recording CameraCharacteristics characteristics = manager.getCameraCharacteristics(cameraId); StreamConfigurationMap map = characteristics .get(CameraCharacteristics.SCALER_STREAM_CONFIGURATION_MAP); mSensorOrientation = characteristics.get(CameraCharacteristics.SENSOR_ORIENTATION); if (map == null) { throw new RuntimeException("Cannot get available preview/video sizes"); } mVideoSize = chooseVideoSize(map.getOutputSizes(MediaRecorder.class)); mPreviewSize = chooseOptimalSize(map.getOutputSizes(SurfaceTexture.class), width, height, mVideoSize); int orientation = getResources().getConfiguration().orientation; if (orientation == Configuration.ORIENTATION_LANDSCAPE) { texture_front.setAspectRatio(mPreviewSize.getWidth(), mPreviewSize.getHeight()); } else { texture_front.setAspectRatio(mPreviewSize.getHeight(), mPreviewSize.getWidth()); } configureTransform(false,width, height); mMediaRecorder = new MediaRecorder(); manager.openCamera(cameraId, mStateCallback_front, null); } } catch (CameraAccessException e) { showTip("Cannot access the camera."); activity.finish(); } catch (NullPointerException e) { // Currently an NPE is thrown when the Camera2API is used but not supported on the // device this code runs. ErrorDialog.newInstance(getString(R.string.camera_error)) .show(getChildFragmentManager(), FRAGMENT_DIALOG); } catch (InterruptedException e) { throw new RuntimeException("Interrupted while trying to lock camera opening."); } } #然后到StateCallBack,我分成前后摄像头两个callback private CameraDevice.StateCallback mStateCallback_back = new CameraDevice.StateCallback() { @Override public void onOpened(@NonNull CameraDevice cameraDevice) { mCameraDevice = cameraDevice; startPreview(true); mCameraOpenCloseLock.release(); if (null != texture_back) { configureTransform(true,texture_back.getWidth(), texture_back.getHeight()); } } @Override public void onDisconnected(@NonNull CameraDevice cameraDevice) { mCameraOpenCloseLock.release(); cameraDevice.close(); mCameraDevice = null; } @Override public void onError(@NonNull CameraDevice cameraDevice, int error) { mCameraOpenCloseLock.release(); cameraDevice.close(); mCameraDevice = null; Activity activity = getActivity(); if (null != activity) { activity.finish(); } } }; private CameraDevice.StateCallback mStateCallback_front = new CameraDevice.StateCallback() { @Override public void onOpened(@NonNull CameraDevice cameraDevice) { mCameraDevice = cameraDevice; startPreview(false); mCameraOpenCloseLock_front.release(); if (null != texture_front) { configureTransform(false,texture_front.getWidth(), texture_front.getHeight()); } } @Override public void onDisconnected(@NonNull CameraDevice cameraDevice) { mCameraOpenCloseLock_front.release(); cameraDevice.close(); mCameraDevice = null; } @Override public void onError(@NonNull CameraDevice cameraDevice, int error) { mCameraOpenCloseLock_front.release(); cameraDevice.close(); mCameraDevice = null; Activity activity = getActivity(); if (null != activity) { activity.finish(); } } }; # Callback成功后会返回startPreview()方法 private void startPreview(final Boolean isBack) { if (null == mCameraDevice || !getTexture(isBack).isAvailable() || null == mPreviewSize) { return; } final String threadName; if (isBack){ threadName="Camera_back"; }else { threadName="Camera_front"; } try { closePreviewSession(); SurfaceTexture texture = getTexture(isBack).getSurfaceTexture(); assert texture != null; texture.setDefaultBufferSize(mPreviewSize.getWidth(), mPreviewSize.getHeight()); mPreviewBuilder = mCameraDevice.createCaptureRequest(CameraDevice.TEMPLATE_PREVIEW); Surface previewSurface = new Surface(texture); mPreviewBuilder.addTarget(previewSurface); mCameraDevice.createCaptureSession(Collections.singletonList(previewSurface), new CameraCaptureSession.StateCallback() { @Override public void onConfigured(@NonNull CameraCaptureSession session) { mPreviewSession = session; //updatePreview if (null == mCameraDevice) { return; } try { setUpCaptureRequestBuilder(mPreviewBuilder); HandlerThread thread = new HandlerThread(threadName); thread.start(); mPreviewSession.setRepeatingRequest(mPreviewBuilder.build(), null, mHandler_back); } catch (CameraAccessException e) { e.printStackTrace(); } } @Override public void onConfigureFailed(@NonNull CameraCaptureSession session) { Activity activity = getActivity(); if (null != activity) { Toast.makeText(activity, "Failed", Toast.LENGTH_SHORT).show(); } } }, mHandler_back); } catch (CameraAccessException e) { e.printStackTrace(); } } private AutoFitTextureView getTexture(boolean isBack){ if (isBack){ return texture_back; }else { return texture_front; } } ## 以上是预览的核心代码,录像部分就不贴上去了。试了很多方法,始终不能两个摄像头同时previeew,只能其中一个单独预览。求教 ![图片说明](https://img-ask.csdn.net/upload/201903/05/1551770621_259074.jpg)
Android usb camera框架实现
# 用的是android 4.1平台,现在的平台上面还没有实现USBcamera的功能。 #原来的平台实现,SOC摄像头的框架,如何修改hardware层实现usb摄像头框架,实现预览,拍照的功能? 1、首先我们已经给高通确认过了,高通的框架是不支持这个的。 2、看了平台里面的代码,framework/av/camera/ framework/av/service/camera 这部分跟其他平台的差别不大。 3、主要是 hal里面的东西,高通的hal里面因为要兼容vendor的东西,所以改的东西很多。 4、kernel 里面的v4l2,高通自己修改了一部分的v4l2,但是能生成video 和media节点,并且通用的ioctl都可以用,所以我觉得这部分也是可以的。
怎样在 android 中禁用 camera server?
请问怎么在android中 禁用camera server ,就是在编译的镜像文件里 , ps | grep -nr camera 不让他找到相应的服务项? 谢谢
C# WPF WPFMediaKit 调用USB 2.0 Camera摄像头 不出图像
C# 后台开发语言 WPF 的 WPFMediaKit 控件在前台显示 摄像头视频 前端代码 ``` <StackPanel Name="WP_vce" Grid.Column="0" Grid.Row="1"> <WrapPanel HorizontalAlignment="Center" VerticalAlignment="Center" Background="#F6F6F6"> <WPFMediaKit:VideoCaptureElement Grid.Row="1" x:Name="vce" Stretch="Fill" FPS="30" /> </WrapPanel> </StackPanel> ``` 后端代码 public TakePhoto() { InitializeComponent(); this.vce.Width = (float)System.Windows.SystemParameters.PrimaryScreenWidth - 400; this.vce.Height = (float)System.Windows.SystemParameters.PrimaryScreenHeight - 200; vce.VideoCaptureSource = "ICT Camera"; vce.Play(); } WPF运行效果 ![图片说明](https://img-ask.csdn.net/upload/201910/24/1571922941_159779.png) 注:同上面一样的代码是可以打开 笔记本电脑摄像头 和 USB外接摄像头ICT Camera 并正常显示 图画; 在网上找过一些案例, 有一个Winfrom 的例子在本地是能成功打开 USB 2.0 Camera摄像头 画面显示正确, 没有存在 坏的摄像头情况;
130 个相见恨晚的超实用网站,一次性分享出来
相见恨晚的超实用网站 持续更新中。。。
我花了一夜用数据结构给女朋友写个H5走迷宫游戏
起因 又到深夜了,我按照以往在csdn和公众号写着数据结构!这占用了我大量的时间!我的超越妹妹严重缺乏陪伴而 怨气满满! 而女朋友时常埋怨,认为数据结构这么抽象难懂的东西没啥作用,常会问道:天天写这玩意,有啥作用。而我答道:能干事情多了,比如写个迷宫小游戏啥的! 当我码完字准备睡觉时:写不好别睡觉! 分析 如果用数据结构与算法造出东西来呢? ...
对计算机专业来说学历真的重要吗?
我本科学校是渣渣二本,研究生学校是985,现在毕业五年,校招笔试、面试,社招面试参加了两年了,就我个人的经历来说下这个问题。 这篇文章很长,但绝对是精华,相信我,读完以后,你会知道学历不好的解决方案,记得帮我点赞哦。 先说结论,无论赞不赞同,它本质就是这样:对于技术类工作而言,学历五年以内非常重要,但有办法弥补。五年以后,不重要。 目录: 张雪峰讲述的事实 我看到的事实 为什么会这样 ...
字节跳动视频编解码面经
三四月份投了字节跳动的实习(图形图像岗位),然后hr打电话过来问了一下会不会opengl,c++,shador,当时只会一点c++,其他两个都不会,也就直接被拒了。 七月初内推了字节跳动的提前批,因为内推没有具体的岗位,hr又打电话问要不要考虑一下图形图像岗,我说实习投过这个岗位不合适,不会opengl和shador,然后hr就说秋招更看重基础。我当时想着能进去就不错了,管他哪个岗呢,就同意了面试...
win10系统安装教程(U盘PE+UEFI安装)
一、准备工作 u盘,电脑一台,win10原版镜像(msdn官网) 二、下载wepe工具箱 极力推荐微pe(微pe官方下载) 下载64位的win10 pe,使用工具箱制作启动U盘打开软件, 选择安装到U盘(按照操作无需更改) 三、重启进入pe系统 1、关机后,将U盘插入电脑 2、按下电源后,按住F12进入启动项选择(技嘉主板是F12) 选择需要启...
程序员必须掌握的核心算法有哪些?
由于我之前一直强调数据结构以及算法学习的重要性,所以就有一些读者经常问我,数据结构与算法应该要学习到哪个程度呢?,说实话,这个问题我不知道要怎么回答你,主要取决于你想学习到哪些程度,不过针对这个问题,我稍微总结一下我学过的算法知识点,以及我觉得值得学习的算法。这些算法与数据结构的学习大多数是零散的,并没有一本把他们全部覆盖的书籍。下面是我觉得值得学习的一些算法以及数据结构,当然,我也会整理一些看过...
Python——画一棵漂亮的樱花树(不同种樱花+玫瑰+圣诞树喔)
最近翻到一篇知乎,上面有不少用Python(大多是turtle库)绘制的树图,感觉很漂亮,我整理了一下,挑了一些我觉得不错的代码分享给大家(这些我都测试过,确实可以生成) one 樱花树 动态生成樱花 效果图(这个是动态的): 实现代码 import turtle as T import random import time # 画樱花的躯干(60,t) def Tree(branch, ...
大学四年自学走来,这些私藏的实用工具/学习网站我贡献出来了
大学四年,看课本是不可能一直看课本的了,对于学习,特别是自学,善于搜索网上的一些资源来辅助,还是非常有必要的,下面我就把这几年私藏的各种资源,网站贡献出来给你们。主要有:电子书搜索、实用工具、在线视频学习网站、非视频学习网站、软件下载、面试/求职必备网站。 注意:文中提到的所有资源,文末我都给你整理好了,你们只管拿去,如果觉得不错,转发、分享就是最大的支持了。 一、电子书搜索 对于大部分程序员...
《奇巧淫技》系列-python!!每天早上八点自动发送天气预报邮件到QQ邮箱
将代码部署服务器,每日早上定时获取到天气数据,并发送到邮箱。 也可以说是一个小人工智障。 思路可以运用在不同地方,主要介绍的是思路。
致 Python 初学者
欢迎来到“Python进阶”专栏!来到这里的每一位同学,应该大致上学习了很多 Python 的基础知识,正在努力成长的过程中。在此期间,一定遇到了很多的困惑,对未来的学习方向感到迷茫。我非常理解你们所面临的处境。我从2007年开始接触 python 这门编程语言,从2009年开始单一使用 python 应对所有的开发工作,直至今天。回顾自己的学习过程,也曾经遇到过无数的困难,也曾经迷茫过、困惑过。开办这个专栏,正是为了帮助像我当年一样困惑的 Python 初学者走出困境、快速成长。希望我的经验能真正帮到你
Ol4网格生成以及优化
概述 先描述一下大致场景:以0.05为单元格大小生成网格,并在地图上绘制,绘制的时候需要区分海陆。本文以此需求为契机,简单描述一下该需求的实现以及如何来优化。 效果 实现 优化前 var source = new ol.source.Vector({ features: [] }); var vector = new ol.layer.Vector({ source...
11月19日科技资讯|华为明日发布鸿蒙整体战略;京东宣告全面向技术转型;Kotlin 1.3.60 发布
「极客头条」—— 技术人员的新闻圈! CSDN 的读者朋友们早上好哇,「极客头条」来啦,快来看今天都有哪些值得我们技术人关注的重要新闻吧。扫描上方二维码进入 CSDN App 可以收听御姐萌妹 Style 的人工版音频哟。 一分钟速览新闻点! 6G 专家组成员:速率是 5G 的 10 至 100 倍,预计 2030 年商用 雷军:很多人多次劝我放弃WPS,能坚持下来并不是纯粹的商业决定 ...
C语言魔塔游戏
很早就很想写这个,今天终于写完了。 游戏截图: 编译环境: VS2017 游戏需要一些图片,如果有想要的或者对游戏有什么看法的可以加我的QQ 2985486630 讨论,如果暂时没有回应,可以在博客下方留言,到时候我会看到。 下面我来介绍一下游戏的主要功能和实现方式 首先是玩家的定义,使用结构体,这个名字是可以自己改变的 struct gamerole { char n...
iOS Bug 太多,苹果终于坐不住了!
开源的 Android 和闭源的 iOS,作为用户的你,更偏向哪一个呢? 整理 | 屠敏 出品 | CSDN(ID:CSDNnews) 毋庸置疑,当前移动设备操作系统市场中,Android 和 iOS 作为两大阵营,在相互竞争的同时不断演进。不过一直以来,开源的 Android 吸引了无数的手机厂商涌入其中,为其生态带来了百花齐放的盛景,但和神秘且闭源的 iOS 系统相比,不少网友...
Python语言高频重点汇总
Python语言高频重点汇总 GitHub面试宝典仓库 回到首页 目录: Python语言高频重点汇总 目录: 1. 函数-传参 2. 元类 3. @staticmethod和@classmethod两个装饰器 4. 类属性和实例属性 5. Python的自省 6. 列表、集合、字典推导式 7. Python中单下划线和双下划线 8. 格式化字符串中的%和format 9. 迭代器和生成器 10...
究竟你适不适合买Mac?
我清晰的记得,刚买的macbook pro回到家,开机后第一件事情,就是上了淘宝网,花了500元钱,找了一个上门维修电脑的师傅,上门给我装了一个windows系统。。。。。。 表砍我。。。 当时买mac的初衷,只是想要个固态硬盘的笔记本,用来运行一些复杂的扑克软件。而看了当时所有的SSD笔记本后,最终决定,还是买个好(xiong)看(da)的。 已经有好几个朋友问我mba怎么样了,所以今天尽量客观...
Python爬虫爬取淘宝,京东商品信息
小编是一个理科生,不善长说一些废话。简单介绍下原理然后直接上代码。 使用的工具(Python+pycharm2019.3+selenium+xpath+chromedriver)其中要使用pycharm也可以私聊我selenium是一个框架可以通过pip下载 pip installselenium -ihttps://pypi.tuna.tsinghua.edu.cn/simple/ ...
程序员写了一个新手都写不出的低级bug,被骂惨了。
这种新手都不会范的错,居然被一个工作好几年的小伙子写出来,差点被当场开除了。
Java工作4年来应聘要16K最后没要,细节如下。。。
前奏: 今天2B哥和大家分享一位前几天面试的一位应聘者,工作4年26岁,统招本科。 以下就是他的简历和面试情况。 基本情况: 专业技能: 1、&nbsp;熟悉Sping了解SpringMVC、SpringBoot、Mybatis等框架、了解SpringCloud微服务 2、&nbsp;熟悉常用项目管理工具:SVN、GIT、MAVEN、Jenkins 3、&nbsp;熟悉Nginx、tomca...
2020年,冯唐49岁:我给20、30岁IT职场年轻人的建议
点击“技术领导力”关注∆每天早上8:30推送 作者|Mr.K 编辑| Emma 来源|技术领导力(ID:jishulingdaoli) 前天的推文《冯唐:职场人35岁以后,方法论比经验重要》,收到了不少读者的反馈,觉得挺受启发。其实,冯唐写了不少关于职场方面的文章,都挺不错的。可惜大家只记住了“春风十里不如你”、“如何避免成为油腻腻的中年人”等不那么正经的文章。 本文整理了冯...
程序员该看的几部电影
1、骇客帝国(1999) 概念:在线/离线,递归,循环,矩阵等 剧情简介: 不久的将来,网络黑客尼奥对这个看似正常的现实世界产生了怀疑。 他结识了黑客崔妮蒂,并见到了黑客组织的首领墨菲斯。 墨菲斯告诉他,现实世界其实是由一个名叫“母体”的计算机人工智能系统控制,人们就像他们饲养的动物,没有自由和思想,而尼奥就是能够拯救人类的救世主。 可是,救赎之路从来都不会一帆风顺,到底哪里才是真实的世界?如何...
蓝桥杯知识点汇总:基础知识和常用算法
文章目录基础语法部分:算法竞赛常用API:算法部分数据结构部分 此系列包含蓝桥杯绝大部分所考察的知识点,以及真题题解~ 基础语法部分: 备战蓝桥杯java(一):一般输入输出 和 快速输入输(BufferedReader&amp;BufferedWrite) 备战蓝桥杯java(二):java编程规范和常用数据类型 备战蓝桥杯java(三):常用功能符以及循环结构和分支结构 备战蓝桥杯java(四...
作为一个程序员,CPU的这些硬核知识你必须会!
CPU对每个程序员来说,是个既熟悉又陌生的东西? 如果你只知道CPU是中央处理器的话,那可能对你并没有什么用,那么作为程序员的我们,必须要搞懂的就是CPU这家伙是如何运行的,尤其要搞懂它里面的寄存器是怎么一回事,因为这将让你从底层明白程序的运行机制。 随我一起,来好好认识下CPU这货吧 把CPU掰开来看 对于CPU来说,我们首先就要搞明白它是怎么回事,也就是它的内部构造,当然,CPU那么牛的一个东...
@程序员,如何花式构建线程?
作者 |曾建责编 | 郭芮出品 | CSDN(ID:CSDNnews)在项目和业务的开发中,我们难免要经常使用线程来进行业务处理,使用线程可以保证我们的业务在相互处理之间可以保证原子性...
破14亿,Python分析我国存在哪些人口危机!
一、背景 二、爬取数据 三、数据分析 1、总人口 2、男女人口比例 3、人口城镇化 4、人口增长率 5、人口老化(抚养比) 6、各省人口 7、世界人口 四、遇到的问题 遇到的问题 1、数据分页,需要获取从1949-2018年数据,观察到有近20年参数:LAST20,由此推测获取近70年的参数可设置为:LAST70 2、2019年数据没有放上去,可以手动添加上去 3、将数据进行 行列转换 4、列名...
实现简单的轮播图(单张图片、多张图片)
前言 刚学js没多久,这篇博客就当做记录了,以后还会完善的,希望大佬们多多指点。ps:下面出现的都是直接闪动,没有滑动效果的轮播图。 单张图片的替换 · ...
强烈推荐10本程序员在家读的书
很遗憾,这个春节注定是刻骨铭心的,新型冠状病毒让每个人的神经都是紧绷的。那些处在武汉的白衣天使们,尤其值得我们的尊敬。而我们这些窝在家里的程序员,能不外出就不外出,就是对社会做出的最大的贡献。 有些读者私下问我,窝了几天,有点颓丧,能否推荐几本书在家里看看。我花了一天的时间,挑选了 10 本我最喜欢的书,你可以挑选感兴趣的来读一读。读书不仅可以平复恐惧的压力,还可以对未来充满希望,毕竟苦难终将会...
Linux自学篇——linux命令英文全称及解释
man: Manual 意思是手册,可以用这个命令查询其他命令的用法。 pwd:Print working directory 意思是密码。 su:Swith user 切换用户,切换到root用户 cd:Change directory 切换目录 ls:List files 列出目录下的文件 ps:Process Status 进程状态 mkdir:Make directory ...
Python实战:抓肺炎疫情实时数据,画2019-nCoV疫情地图
今天,群里白垩老师问如何用python画武汉肺炎疫情地图。白垩老师是研究海洋生态与地球生物的学者,国家重点实验室成员,于不惑之年学习python,实为我等学习楷模。先前我并没有关注武汉肺炎的具体数据,也没有画过类似的数据分布图。于是就拿了两个小时,专门研究了一下,遂成此文。
疫情数据接口api
返回json示例 { "errcode":0,//0标识接口正常 "data":{ "date":"2020-01-30 07:47:23",//实时更新时间 "diagnosed":7736,//确诊人数 "suspect":12167,//疑是病例人数 "death":170,//死亡人数 "cur...
相关热词 c# 为空 判断 委托 c#记事本颜色 c# 系统默认声音 js中调用c#方法参数 c#引入dll文件报错 c#根据名称实例化 c#从邮件服务器获取邮件 c# 保存文件夹 c#代码打包引用 c# 压缩效率
立即提问