mirror of
				https://github.com/SimpleMobileTools/Simple-Camera.git
				synced 2025-06-27 09:02:59 +02:00 
			
		
		
		
	setup the proper video preview size
This commit is contained in:
		| @@ -170,7 +170,7 @@ public class Preview extends ViewGroup implements SurfaceHolder.Callback, View.O | ||||
|                 rotation += 90; | ||||
|             } | ||||
|  | ||||
|             final Camera.Size maxSize = getPictureSize(); | ||||
|             final Camera.Size maxSize = getOptimalPictureSize(); | ||||
|             parameters.setPictureSize(maxSize.width, maxSize.height); | ||||
|             parameters.setRotation(rotation % 360); | ||||
|  | ||||
| @@ -206,8 +206,8 @@ public class Preview extends ViewGroup implements SurfaceHolder.Callback, View.O | ||||
|         } | ||||
|     }; | ||||
|  | ||||
|     private Camera.Size getPictureSize() { | ||||
|         List<Camera.Size> sizes = parameters.getSupportedPictureSizes(); | ||||
|     private Camera.Size getOptimalPictureSize() { | ||||
|         final List<Camera.Size> sizes = parameters.getSupportedPictureSizes(); | ||||
|         Camera.Size maxSize = sizes.get(0); | ||||
|         for (Camera.Size size : sizes) { | ||||
|             final boolean isEightMegapixelsMax = isEightMegapixelsMax(size); | ||||
| @@ -231,6 +231,19 @@ public class Preview extends ViewGroup implements SurfaceHolder.Callback, View.O | ||||
|         return diff < RATIO_TOLERANCE; | ||||
|     } | ||||
|  | ||||
|     private Camera.Size getOptimalVideoSize() { | ||||
|         final List<Camera.Size> sizes = parameters.getSupportedVideoSizes(); | ||||
|         Camera.Size maxSize = sizes.get(0); | ||||
|         for (Camera.Size size : sizes) { | ||||
|             final boolean isSixteenToNine = isSixteenToNine(size); | ||||
|             if (isSixteenToNine) { | ||||
|                 maxSize = size; | ||||
|                 break; | ||||
|             } | ||||
|         } | ||||
|         return maxSize; | ||||
|     } | ||||
|  | ||||
|     private void focusArea() { | ||||
|         if (camera == null) | ||||
|             return; | ||||
| @@ -413,9 +426,13 @@ public class Preview extends ViewGroup implements SurfaceHolder.Callback, View.O | ||||
|  | ||||
|     // VIDEO RECORDING | ||||
|     public void initRecorder() { | ||||
|         if (camera == null) | ||||
|         if (camera == null || recorder != null) | ||||
|             return; | ||||
|  | ||||
|         final Camera.Size preferred = parameters.getPreferredPreviewSizeForVideo(); | ||||
|         parameters.setPreviewSize(preferred.width, preferred.height); | ||||
|         camera.setParameters(parameters); | ||||
|  | ||||
|         isRecording = false; | ||||
|         isVideoMode = true; | ||||
|         recorder = new MediaRecorder(); | ||||
| @@ -434,6 +451,9 @@ public class Preview extends ViewGroup implements SurfaceHolder.Callback, View.O | ||||
|         recorder.setOutputFile(curVideoPath); | ||||
|         recorder.setPreviewDisplay(surfaceHolder.getSurface()); | ||||
|  | ||||
|         final Camera.Size videoSize = getOptimalVideoSize(); | ||||
|         recorder.setVideoSize(videoSize.width, videoSize.height); | ||||
|  | ||||
|         if (currCameraId == Camera.CameraInfo.CAMERA_FACING_FRONT) { | ||||
|             recorder.setOrientationHint(270); | ||||
|         } else { | ||||
| @@ -442,9 +462,8 @@ public class Preview extends ViewGroup implements SurfaceHolder.Callback, View.O | ||||
|  | ||||
|         try { | ||||
|             recorder.prepare(); | ||||
|         } catch (IllegalStateException e) { | ||||
|             Log.e(TAG, "initRecorder " + e.getMessage()); | ||||
|         } catch (IOException e) { | ||||
|         } catch (Exception e) { | ||||
|             Utils.showToast(getContext(), R.string.video_setup_error); | ||||
|             Log.e(TAG, "initRecorder " + e.getMessage()); | ||||
|         } | ||||
|     } | ||||
| @@ -456,7 +475,12 @@ public class Preview extends ViewGroup implements SurfaceHolder.Callback, View.O | ||||
|         } else { | ||||
|             camera.lock(); | ||||
|             camera.unlock(); | ||||
|             try { | ||||
|                 recorder.start(); | ||||
|             } catch (Exception e) { | ||||
|                 Utils.showToast(getContext(), R.string.video_setup_error); | ||||
|                 Log.e(TAG, "toggleRecording " + e.getMessage()); | ||||
|             } | ||||
|             isRecording = true; | ||||
|         } | ||||
|         return isRecording; | ||||
|   | ||||
| @@ -4,6 +4,7 @@ | ||||
|     <string name="camera_open_error">An error occurred at accessing the camera</string> | ||||
|     <string name="video_creating_error">An error occurred at creating the video file</string> | ||||
|     <string name="video_saving_error">An error occurred at saving the video file</string> | ||||
|     <string name="video_setup_error">An error occurred at setting up the recorder</string> | ||||
|     <string name="video_directory">Simple Videos</string> | ||||
|     <string name="photo_directory">Simple Photos</string> | ||||
|     <string name="no_permissions">Not much to do without accessing your camera and storage</string> | ||||
|   | ||||
		Reference in New Issue
	
	Block a user