197 lines
6.7 KiB
Kotlin
197 lines
6.7 KiB
Kotlin
/*
|
|
* Copyright (C) 2021 The Android Open Source Project
|
|
*
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
* you may not use this file except in compliance with the License.
|
|
* You may obtain a copy of the License at
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
* See the License for the specific language governing permissions and
|
|
* limitations under the License.
|
|
*/
|
|
|
|
package com.example.testapp
|
|
|
|
import android.graphics.Bitmap
|
|
import android.renderscript.Allocation
|
|
import android.renderscript.Element
|
|
import android.renderscript.RenderScript
|
|
import android.renderscript.Script
|
|
import android.renderscript.ScriptIntrinsicHistogram
|
|
import android.renderscript.Type
|
|
import android.renderscript.toolkit.Range2d
|
|
|
|
/**
|
|
* Does a Histogram operation using the RenderScript Intrinsics.
|
|
*/
|
|
fun intrinsicHistogram(
|
|
context: RenderScript,
|
|
inputArray: ByteArray,
|
|
vectorSize: Int,
|
|
sizeX: Int,
|
|
sizeY: Int,
|
|
restriction: Range2d?
|
|
): IntArray {
|
|
val element = renderScriptVectorElementForU8(context, vectorSize)
|
|
val scriptHistogram = ScriptIntrinsicHistogram.create(context, element)
|
|
val builder = Type.Builder(context, element)
|
|
builder.setX(sizeX)
|
|
builder.setY(sizeY)
|
|
val arrayType = builder.create()
|
|
val inputAllocation = Allocation.createTyped(context, arrayType)
|
|
val outAllocation =
|
|
Allocation.createSized(
|
|
context,
|
|
renderScriptVectorElementForI32(context, vectorSize),
|
|
256
|
|
)
|
|
inputAllocation.copyFrom(inputArray)
|
|
scriptHistogram.setOutput(outAllocation)
|
|
if (restriction != null) {
|
|
val options = Script.LaunchOptions()
|
|
options.setX(restriction.startX, restriction.endX)
|
|
options.setY(restriction.startY, restriction.endY)
|
|
scriptHistogram.forEach(inputAllocation, options)
|
|
} else {
|
|
scriptHistogram.forEach(inputAllocation)
|
|
}
|
|
|
|
val intrinsicOutArray = IntArray(256 * paddedSize(vectorSize))
|
|
outAllocation.copyTo(intrinsicOutArray)
|
|
inputAllocation.destroy()
|
|
outAllocation.destroy()
|
|
arrayType.destroy()
|
|
scriptHistogram.destroy()
|
|
return intrinsicOutArray
|
|
}
|
|
|
|
fun intrinsicHistogram(
|
|
context: RenderScript,
|
|
bitmap: Bitmap,
|
|
restriction: Range2d?
|
|
): IntArray {
|
|
val baseElement = renderScriptElementForBitmap(context, bitmap)
|
|
val scriptHistogram = ScriptIntrinsicHistogram.create(context, baseElement)
|
|
val inputAllocation = Allocation.createFromBitmap(context, bitmap)
|
|
inputAllocation.copyFrom(bitmap)
|
|
val vectorSize = vectorSizeOfBitmap(bitmap)
|
|
val outAllocation =
|
|
Allocation.createSized(
|
|
context,
|
|
renderScriptVectorElementForI32(context, vectorSize),
|
|
256
|
|
)
|
|
scriptHistogram.setOutput(outAllocation)
|
|
if (restriction != null) {
|
|
val options = Script.LaunchOptions()
|
|
options.setX(restriction.startX, restriction.endX)
|
|
options.setY(restriction.startY, restriction.endY)
|
|
scriptHistogram.forEach(inputAllocation, options)
|
|
} else {
|
|
scriptHistogram.forEach(inputAllocation)
|
|
}
|
|
|
|
val intrinsicOutArray = IntArray(256 * vectorSize)
|
|
outAllocation.copyTo(intrinsicOutArray)
|
|
inputAllocation.destroy()
|
|
outAllocation.destroy()
|
|
scriptHistogram.destroy()
|
|
return intrinsicOutArray
|
|
}
|
|
|
|
fun intrinsicHistogramDot(
|
|
context: RenderScript,
|
|
inputArray: ByteArray,
|
|
vectorSize: Int,
|
|
sizeX: Int,
|
|
sizeY: Int,
|
|
coefficients: FloatArray?,
|
|
restriction: Range2d?
|
|
): IntArray {
|
|
val element = renderScriptVectorElementForU8(context, vectorSize)
|
|
val scriptHistogram = ScriptIntrinsicHistogram.create(context, element)
|
|
val builder = Type.Builder(context, element)
|
|
builder.setX(sizeX)
|
|
builder.setY(sizeY)
|
|
val arrayType = builder.create()
|
|
val inputAllocation = Allocation.createTyped(context, arrayType)
|
|
val outAllocation =
|
|
Allocation.createSized(context, Element.I32(context), 256)
|
|
inputAllocation.copyFrom(inputArray)
|
|
|
|
if (coefficients != null) {
|
|
require(coefficients.size == vectorSize) {
|
|
"RenderScriptToolkit tests. $vectorSize coefficients are required for histogram. " +
|
|
"${coefficients.size} provided."
|
|
}
|
|
scriptHistogram.setDotCoefficients(
|
|
coefficients[0],
|
|
if (vectorSize > 1) coefficients[1] else 0f,
|
|
if (vectorSize > 2) coefficients[2] else 0f,
|
|
if (vectorSize > 3) coefficients[3] else 0f
|
|
)
|
|
}
|
|
scriptHistogram.setOutput(outAllocation)
|
|
if (restriction != null) {
|
|
val options = Script.LaunchOptions()
|
|
options.setX(restriction.startX, restriction.endX)
|
|
options.setY(restriction.startY, restriction.endY)
|
|
scriptHistogram.forEach_Dot(inputAllocation, options)
|
|
} else {
|
|
scriptHistogram.forEach_Dot(inputAllocation)
|
|
}
|
|
val intrinsicOutArray = IntArray(256)
|
|
outAllocation.copyTo(intrinsicOutArray)
|
|
inputAllocation.destroy()
|
|
outAllocation.destroy()
|
|
arrayType.destroy()
|
|
scriptHistogram.destroy()
|
|
return intrinsicOutArray
|
|
}
|
|
|
|
fun intrinsicHistogramDot(
|
|
context: RenderScript,
|
|
bitmap: Bitmap,
|
|
coefficients: FloatArray?,
|
|
restriction: Range2d?
|
|
): IntArray {
|
|
val baseElement = renderScriptElementForBitmap(context, bitmap)
|
|
val scriptHistogram = ScriptIntrinsicHistogram.create(context, baseElement)
|
|
val inputAllocation = Allocation.createFromBitmap(context, bitmap)
|
|
inputAllocation.copyFrom(bitmap)
|
|
val outAllocation =
|
|
Allocation.createSized(context, Element.I32(context), 256)
|
|
|
|
if (coefficients != null) {
|
|
require(coefficients.size == 4) {
|
|
"RenderScriptToolkit tests. Four coefficients are required for histogram. " +
|
|
"${coefficients.size} provided."
|
|
}
|
|
scriptHistogram.setDotCoefficients(
|
|
coefficients[0],
|
|
coefficients[1],
|
|
coefficients[2],
|
|
coefficients[3]
|
|
)
|
|
}
|
|
scriptHistogram.setOutput(outAllocation)
|
|
if (restriction != null) {
|
|
val options = Script.LaunchOptions()
|
|
options.setX(restriction.startX, restriction.endX)
|
|
options.setY(restriction.startY, restriction.endY)
|
|
scriptHistogram.forEach_Dot(inputAllocation, options)
|
|
} else {
|
|
scriptHistogram.forEach_Dot(inputAllocation)
|
|
}
|
|
val intrinsicOutArray = IntArray(256)
|
|
outAllocation.copyTo(intrinsicOutArray)
|
|
inputAllocation.destroy()
|
|
outAllocation.destroy()
|
|
scriptHistogram.destroy()
|
|
return intrinsicOutArray
|
|
}
|