-
-
Notifications
You must be signed in to change notification settings - Fork 36
Customizing MCamera Screens
Dzisiejsze pokolenie ma mocne głowy i zimne serca.
MCamera
is a view object that contains three screens that are displayed in relation to the state of the camera:
-
ErrorScreen
, which is shown when the user denies any of the required permissions, -
CapturedMediaScreen
, which is presented when the user captures either an image or video (can be disabled), -
CameraScreen
, which contains all of the camera controls that the user can interact with to adjust and capture images or video.
On this page, we are going to learn how to create your own `MCamera' screen(s) and what methods you can use to make this process as easy as possible for you. For this reason, this page is divided into three separate sections that cover this topic and provide a code example to help you easily get started with customizing your own camera screens.
By definition, it's a screen that displays an error message when one or more camera permissions are denied by the user.
The default screen can be replaced by creating a structure conforming to MCameraErrorScreen
and setting it as the error screen during MCamera
initialization.
- Create a struct conforming to
MCameraErrorScreen
struct CustomCameraErrorScreen: MCameraErrorScreen { let error: MCameraError let closeMCameraAction: () -> () var body: some View { Button(action: openAppSettings) { Text("Open Settings") } } }
- Pass the newly created screen as an argument during
MCamera
initialization
struct ContentView: View { var body: some View { MCamera() .setErrorScreen(CustomCameraErrorScreen.init) // MUST BE CALLED! .startSession() } }
-
openAppSettings()
- A method that when triggered, the user will open the application settings.
In a nutshell, it's a screen that displays the captured media. The default screen can be replaced by creating a structure conforming to MCapturedMediaScreen
and setting it as the captured media screen during MCamera
initialization. It's also possible to disable this screen by calling the `setCapturedMediaScreen' method with a nil value.
- Create a struct conforming to
MCapturedMediaScreen
struct CustomCapturedMediaScreen: MCapturedMediaScreen { let capturedMedia: MCameraMedia let namespace: Namespace.ID let retakeAction: () -> () let acceptMediaAction: () -> () var body: some View { VStack(spacing: 0) { Spacer() createContentView() Spacer() createButtons() } } } private extension CustomCapturedMediaScreen { func createContentView() -> some View { ZStack { if let image = capturedMedia.getImage() { createImageView(image) } else { EmptyView() } }} func createButtons() -> some View { HStack(spacing: 24) { createRetakeButton() createSaveButton() } } } private extension CustomCapturedMediaScreen { func createImageView(_ image: UIImage) -> some View { Image(uiImage: image) .resizable() .aspectRatio(contentMode: .fit) .ignoresSafeArea() } func createRetakeButton() -> some View { Button(action: retakeAction) { Text("Retake") } } func createSaveButton() -> some View { Button(action: acceptMediaAction) { Text("Save") } } }
- Pass the newly created screen as an argument during
MCamera
initialization
struct ContentView: View { var body: some View { MCamera() .setCapturedMediaScreen(CustomCapturedMediaScreen.init) // MUST BE CALLED! .startSession() } }
A screen that displays the camera view and manages camera actions. It contains many methods that allow you to easily create a screen that suits your needs. The default screen can be replaced by creating a structure conforming to MCameraScreen
and setting it as the captured media screen during MCamera
initialization.
- Create a struct conforming to
MCameraScreen
struct CustomCameraScreen: MCameraScreen { @ObservedObject var cameraManager: CameraManager let namespace: Namespace.ID let closeMCameraAction: () -> () var body: some View { VStack(spacing: 0) { createNavigationBar() createCameraOutputView() createCaptureButton() } } } private extension CustomCameraScreen { func createNavigationBar() -> some View { Text("This is a Custom Camera View") .padding(.top, 12) .padding(.bottom, 12) } func createCaptureButton() -> some View { Button(action: captureOutput) { Text("Click to capture") } .padding(.top, 12) .padding(.bottom, 12) } }
- Pass the newly created screen as an argument during
MCamera
initialization
struct ContentView: View { var body: some View { MCamera() .setCameraScreen(CustomCameraErrorScreen.init) // MUST BE CALLED! .startSession() } }