Giter Site home page Giter Site logo

composecamerasample's Introduction

Compose Basic Camera Sample Code

개요

Compose Custom Camera View가 필요한 경우 참조하기 위해 작성한 샘플 코드입니다.

목표

  • Jetpack Compose를 사용하여 기본적인 카메라 기능을 구현합니다.
  • CameraX를 사용하여 카메라 프리뷰를 표시하고 사진을 촬영합니다.
  • 전면/후면 카메라 전환 기능을 구현합니다.
  • 촬영한 사진의 Bitmap을 가져오는 기능을 구현합니다.
  • (옵션) 촬영한 사진을 파일로 저장하는 기능을 구현합니다.

빌드 환경

Android Studio

  • Android Studio Hedgehog | 2023.1.1 Patch 1
  • Build #AI-231.9392.1.2311.11255304, built on December 27, 2023

Android SDK

  • Android SDK Build-Tools 35-rc2
  • Android SDK Platform-Tools 34.0.5

Java

  • Java Version: 17

Kotlin

  • kotlin Version: 1.9.0

Compose Compiler

  • Kotlin Compose Compiler: 1.5.1

Gradle

  • Android Gradle Plugin Version: 8.1.2
  • Gradle Version: 8.2

기술 스택

  • Jetpack Compose
  • MVI pattern
  • Hilt
  • Android CameraX
  • Coil (추가 예정)

구성

Component의 기능 확인 목적의 샘플 코드로, presentation layer에 해당하는 ui패키지를 중심으로 구성되어 있습니다.

├── BasicCamera.kt
├── MainActivity.kt
└── ui

ui 구성

└── ui
    ├── components
    │   ├── CameraComponent.kt
    │   ├── CameraComponentModel.kt
    │   └── CheckPermissionComponent.kt
    ├── screen.camera
    │   ├── CameraEvent.kt
    │   ├── CameraState.kt
    │   ├── CameraScreen.kt
    │   └── CameraViewModel.kt
    └── theme
  • Screen의 경우 Compose의 원활한 구성을 위해 MVI 패턴을 바탕으로 구성하였습니다.
  • CameraComponent는 Bitmap 후처리를 위한 viewModel을 가지고 있습니다.

기능 목록

1. 후면 카메라

  • 후면 카메라(default)로 화면이 시작됩니다.

  • 촬영 버튼을 누르면 사진이 촬영되고, 촬영한 사진이 화면에 표시됩니다.

  • 전환 버튼을 누르면 전면 카메라로 전환됩니다.


2. 전방 카메라

  • 전면 카메라로 전환되면 화면이 시작됩니다.

  • 촬영 버튼을 누르면 사진이 촬영되고, 촬영한 사진이 화면에 표시됩니다.

  • 전환 버튼을 누르면 후면 카메라로 전환됩니다.


composecamerasample's People

Contributors

parade621 avatar

Watchers

 avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.