Rename color filter to filter to be more generic

This commit is contained in:
Ming Ming 2022-09-06 13:39:42 +08:00
parent 839ef8bb03
commit a4f2fb0bce
13 changed files with 35 additions and 35 deletions

View file

@ -189,7 +189,7 @@ class _ImageEditorState extends State<ImageEditor> {
}
Future<void> _onSavePressed(BuildContext context) async {
await ImageProcessor.colorFilter(
await ImageProcessor.filter(
"${widget.account.url}/${widget.file.path}",
widget.file.filename,
4096,

View file

@ -88,9 +88,9 @@ class ImageProcessorChannelHandler(context: Context) :
}
}
"colorFilter" -> {
"filter" -> {
try {
colorFilter(
filter(
call.argument("fileUrl")!!,
call.argument("headers"),
call.argument("filename")!!,
@ -174,7 +174,7 @@ class ImageProcessorChannelHandler(context: Context) :
}
)
private fun colorFilter(
private fun filter(
fileUrl: String, headers: Map<String, String>?, filename: String,
maxWidth: Int, maxHeight: Int, filters: List<Map<String, Any>>,
result: MethodChannel.Result
@ -184,7 +184,7 @@ class ImageProcessorChannelHandler(context: Context) :
filters.mapTo(l, { HashMap(it) })
method(
fileUrl, headers, filename, maxWidth, maxHeight,
ImageProcessorService.METHOD_COLOR_FILTER, result,
ImageProcessorService.METHOD_FILTER, result,
onIntent = {
it.putExtra(ImageProcessorService.EXTRA_FILTERS, l)
}
@ -196,7 +196,7 @@ class ImageProcessorChannelHandler(context: Context) :
result: MethodChannel.Result
) {
var img = Rgba8Image.fromJson(rgba8)
for (f in filters.map(ColorFilter::fromJson)) {
for (f in filters.map(ImageFilter::fromJson)) {
img = f.apply(img)
}
result.success(img.toJson())
@ -226,9 +226,9 @@ class ImageProcessorChannelHandler(context: Context) :
private var eventSink: EventChannel.EventSink? = null
}
interface ColorFilter {
interface ImageFilter {
companion object {
fun fromJson(json: Map<String, Any>): ColorFilter {
fun fromJson(json: Map<String, Any>): ImageFilter {
return when (json["type"]) {
"brightness" -> Brightness((json["weight"] as Double).toFloat())
"contrast" -> Contrast((json["weight"] as Double).toFloat())

View file

@ -30,7 +30,7 @@ class ImageProcessorService : Service() {
const val METHOD_DEEP_LAP_PORTRAIT = "DeepLab3Portrait"
const val METHOD_ESRGAN = "Esrgan"
const val METHOD_ARBITRARY_STYLE_TRANSFER = "ArbitraryStyleTransfer"
const val METHOD_COLOR_FILTER = "ColorFilter"
const val METHOD_FILTER = "Filter"
const val EXTRA_FILE_URL = "fileUrl"
const val EXTRA_HEADERS = "headers"
const val EXTRA_FILENAME = "filename"
@ -49,7 +49,7 @@ class ImageProcessorService : Service() {
METHOD_ARBITRARY_STYLE_TRANSFER,
)
val EDIT_METHODS = listOf(
METHOD_COLOR_FILTER,
METHOD_FILTER,
)
private const val ACTION_CANCEL = "cancel"
@ -126,7 +126,7 @@ class ImageProcessorService : Service() {
METHOD_ARBITRARY_STYLE_TRANSFER -> onArbitraryStyleTransfer(
startId, intent.extras!!
)
METHOD_COLOR_FILTER -> onColorFilter(startId, intent.extras!!)
METHOD_FILTER -> onFilter(startId, intent.extras!!)
else -> {
logE(TAG, "Unknown method: $method")
// we can't call stopSelf here as it'll stop the service even if
@ -170,12 +170,12 @@ class ImageProcessorService : Service() {
)
}
private fun onColorFilter(startId: Int, extras: Bundle) {
private fun onFilter(startId: Int, extras: Bundle) {
val filters = extras.getSerializable(EXTRA_FILTERS)!!
.asType<ArrayList<Serializable>>()
.map { it.asType<HashMap<String, Any>>() }
return onMethod(
startId, extras, METHOD_COLOR_FILTER,
startId, extras, METHOD_FILTER,
args = mapOf(
"filters" to filters,
)

View file

@ -1,8 +1,8 @@
package com.nkming.nc_photos.plugin.image_processor
import com.nkming.nc_photos.plugin.ColorFilter
import com.nkming.nc_photos.plugin.ImageFilter
class BlackPoint(val weight: Float) : ColorFilter {
class BlackPoint(val weight: Float) : ImageFilter {
override fun apply(rgba8: Rgba8Image) = Rgba8Image(
applyNative(rgba8.pixel, rgba8.width, rgba8.height, weight),
rgba8.width, rgba8.height

View file

@ -1,8 +1,8 @@
package com.nkming.nc_photos.plugin.image_processor
import com.nkming.nc_photos.plugin.ColorFilter
import com.nkming.nc_photos.plugin.ImageFilter
class Brightness(val weight: Float) : ColorFilter {
class Brightness(val weight: Float) : ImageFilter {
override fun apply(rgba8: Rgba8Image) = Rgba8Image(
applyNative(rgba8.pixel, rgba8.width, rgba8.height, weight),
rgba8.width, rgba8.height

View file

@ -1,8 +1,8 @@
package com.nkming.nc_photos.plugin.image_processor
import com.nkming.nc_photos.plugin.ColorFilter
import com.nkming.nc_photos.plugin.ImageFilter
class Contrast(val weight: Float) : ColorFilter {
class Contrast(val weight: Float) : ImageFilter {
override fun apply(rgba8: Rgba8Image) = Rgba8Image(
applyNative(rgba8.pixel, rgba8.width, rgba8.height, weight),
rgba8.width, rgba8.height

View file

@ -1,8 +1,8 @@
package com.nkming.nc_photos.plugin.image_processor
import com.nkming.nc_photos.plugin.ColorFilter
import com.nkming.nc_photos.plugin.ImageFilter
class Cool(val weight: Float) : ColorFilter {
class Cool(val weight: Float) : ImageFilter {
override fun apply(rgba8: Rgba8Image) = Rgba8Image(
applyNative(rgba8.pixel, rgba8.width, rgba8.height, weight),
rgba8.width, rgba8.height

View file

@ -5,15 +5,15 @@ import android.graphics.Bitmap
import android.net.Uri
import com.nkming.nc_photos.plugin.BitmapResizeMethod
import com.nkming.nc_photos.plugin.BitmapUtil
import com.nkming.nc_photos.plugin.ColorFilter
import com.nkming.nc_photos.plugin.ImageFilter
import com.nkming.nc_photos.plugin.use
class ColorFilterProcessor(
class ImageFilterProcessor(
context: Context, maxWidth: Int, maxHeight: Int,
filters: List<Map<String, Any>>
) {
companion object {
const val TAG = "ColorFilterProcessor"
const val TAG = "ImageFilterProcessor"
}
fun apply(imageUri: Uri): Bitmap {
@ -24,7 +24,7 @@ class ColorFilterProcessor(
Rgba8Image(TfLiteHelper.bitmapToRgba8Array(it), it.width, it.height)
}
for (f in filters.map(ColorFilter::fromJson)) {
for (f in filters.map(ImageFilter::fromJson)) {
img = f.apply(img)
}
return img.toBitmap()

View file

@ -1,8 +1,8 @@
package com.nkming.nc_photos.plugin.image_processor
import com.nkming.nc_photos.plugin.ColorFilter
import com.nkming.nc_photos.plugin.ImageFilter
class Saturation(val weight: Float) : ColorFilter {
class Saturation(val weight: Float) : ImageFilter {
override fun apply(rgba8: Rgba8Image) = Rgba8Image(
applyNative(rgba8.pixel, rgba8.width, rgba8.height, weight),
rgba8.width, rgba8.height

View file

@ -1,8 +1,8 @@
package com.nkming.nc_photos.plugin.image_processor
import com.nkming.nc_photos.plugin.ColorFilter
import com.nkming.nc_photos.plugin.ImageFilter
class Tint(val weight: Float) : ColorFilter {
class Tint(val weight: Float) : ImageFilter {
override fun apply(rgba8: Rgba8Image) = Rgba8Image(
applyNative(rgba8.pixel, rgba8.width, rgba8.height, weight),
rgba8.width, rgba8.height

View file

@ -1,8 +1,8 @@
package com.nkming.nc_photos.plugin.image_processor
import com.nkming.nc_photos.plugin.ColorFilter
import com.nkming.nc_photos.plugin.ImageFilter
class Warmth(val weight: Float) : ColorFilter {
class Warmth(val weight: Float) : ImageFilter {
override fun apply(rgba8: Rgba8Image) = Rgba8Image(
applyNative(rgba8.pixel, rgba8.width, rgba8.height, weight),
rgba8.width, rgba8.height

View file

@ -1,8 +1,8 @@
package com.nkming.nc_photos.plugin.image_processor
import com.nkming.nc_photos.plugin.ColorFilter
import com.nkming.nc_photos.plugin.ImageFilter
class WhitePoint(val weight: Float) : ColorFilter {
class WhitePoint(val weight: Float) : ImageFilter {
override fun apply(rgba8: Rgba8Image) = Rgba8Image(
applyNative(rgba8.pixel, rgba8.width, rgba8.height, weight),
rgba8.width, rgba8.height

View file

@ -113,7 +113,7 @@ class ImageProcessor {
"weight": weight,
});
static Future<void> colorFilter(
static Future<void> filter(
String fileUrl,
String filename,
int maxWidth,
@ -121,7 +121,7 @@ class ImageProcessor {
List<ImageFilter> filters, {
Map<String, String>? headers,
}) =>
_methodChannel.invokeMethod("colorFilter", <String, dynamic>{
_methodChannel.invokeMethod("filter", <String, dynamic>{
"fileUrl": fileUrl,
"headers": headers,
"filename": filename,