mirror of
https://github.com/SimpleMobileTools/Simple-Flashlight.git
synced 2025-06-05 21:59:19 +02:00
removing a redundant interface
This commit is contained in:
@ -1,12 +1,90 @@
|
||||
package com.simplemobiletools.flashlight.helpers
|
||||
|
||||
interface CameraFlash {
|
||||
fun initialize()
|
||||
fun toggleFlashlight(enable: Boolean)
|
||||
fun changeTorchBrightness(level: Int) {}
|
||||
fun getMaximumBrightnessLevel(): Int = DEFAULT_BRIGHTNESS_LEVEL
|
||||
fun supportsBrightnessControl(): Boolean = false
|
||||
fun getCurrentBrightnessLevel(): Int = DEFAULT_BRIGHTNESS_LEVEL
|
||||
fun unregisterListeners(){}
|
||||
fun release(){}
|
||||
import android.content.Context
|
||||
import android.hardware.camera2.CameraCharacteristics
|
||||
import android.hardware.camera2.CameraManager
|
||||
import android.os.Handler
|
||||
import com.simplemobiletools.commons.extensions.showErrorToast
|
||||
import com.simplemobiletools.commons.helpers.isTiramisuPlus
|
||||
import com.simplemobiletools.flashlight.extensions.config
|
||||
import com.simplemobiletools.flashlight.models.Events
|
||||
import org.greenrobot.eventbus.EventBus
|
||||
|
||||
internal class CameraFlash(
|
||||
private val context: Context,
|
||||
private var cameraTorchListener: CameraTorchListener? = null,
|
||||
) {
|
||||
private val manager = context.getSystemService(Context.CAMERA_SERVICE) as CameraManager
|
||||
private var cameraId: String? = null
|
||||
|
||||
private val torchCallback = object : CameraManager.TorchCallback() {
|
||||
override fun onTorchModeChanged(cameraId: String, enabled: Boolean) {
|
||||
cameraTorchListener?.onTorchEnabled(enabled)
|
||||
}
|
||||
}
|
||||
|
||||
init {
|
||||
try {
|
||||
cameraId = manager.cameraIdList[0] ?: "0"
|
||||
} catch (e: Exception) {
|
||||
context.showErrorToast(e)
|
||||
}
|
||||
}
|
||||
|
||||
fun toggleFlashlight(enable: Boolean) {
|
||||
try {
|
||||
if (supportsBrightnessControl() && enable) {
|
||||
val brightnessLevel = getCurrentBrightnessLevel()
|
||||
changeTorchBrightness(brightnessLevel)
|
||||
} else {
|
||||
manager.setTorchMode(cameraId!!, enable)
|
||||
}
|
||||
} catch (e: Exception) {
|
||||
context.showErrorToast(e)
|
||||
val mainRunnable = Runnable {
|
||||
EventBus.getDefault().post(Events.CameraUnavailable())
|
||||
}
|
||||
Handler(context.mainLooper).post(mainRunnable)
|
||||
}
|
||||
}
|
||||
|
||||
fun changeTorchBrightness(level: Int) {
|
||||
if (isTiramisuPlus()) {
|
||||
manager.turnOnTorchWithStrengthLevel(cameraId!!, level)
|
||||
}
|
||||
}
|
||||
|
||||
fun getMaximumBrightnessLevel(): Int {
|
||||
return if (isTiramisuPlus()) {
|
||||
val characteristics = manager.getCameraCharacteristics(cameraId!!)
|
||||
characteristics.get(CameraCharacteristics.FLASH_INFO_STRENGTH_MAXIMUM_LEVEL) ?: MIN_BRIGHTNESS_LEVEL
|
||||
} else {
|
||||
MIN_BRIGHTNESS_LEVEL
|
||||
}
|
||||
}
|
||||
|
||||
fun supportsBrightnessControl(): Boolean {
|
||||
val maxBrightnessLevel = getMaximumBrightnessLevel()
|
||||
return maxBrightnessLevel > MIN_BRIGHTNESS_LEVEL
|
||||
}
|
||||
|
||||
fun getCurrentBrightnessLevel(): Int {
|
||||
var brightnessLevel = context.config.brightnessLevel
|
||||
if (brightnessLevel == DEFAULT_BRIGHTNESS_LEVEL) {
|
||||
brightnessLevel = getMaximumBrightnessLevel()
|
||||
}
|
||||
return brightnessLevel
|
||||
}
|
||||
|
||||
fun initialize() {
|
||||
manager.registerTorchCallback(torchCallback, Handler(context.mainLooper))
|
||||
}
|
||||
|
||||
fun unregisterListeners() {
|
||||
manager.unregisterTorchCallback(torchCallback)
|
||||
}
|
||||
|
||||
fun release() {
|
||||
cameraTorchListener = null
|
||||
}
|
||||
}
|
||||
|
Reference in New Issue
Block a user