RenderScript 不只能够用来画图,并且能够用来作密集的计算操做。目前的API可使用到的是利用CPU的核心优点来帮咱们作计算。在将来,可能会包括GPU和DSP处理器上作精密计算。html
建立一个Compute 的RenderScript
下面有一张图详细的介绍了勾划了一个Compute 的 RenderScript:java
图解:Andriod 有一个RenderScript Compute 的引擎来支持作精密计算,后期google 会不断扩展这个引擎让其支持更多的精密计算如上面提到的GPU、DSP等等,建立Compute RenderScript 一样的也必须写一个.rs 文件,作运行时生成对象读取调用。以后在Android 上层实现计算功能。另,(必须显示在应用上调用forEach_root或者在RenderScript 运行时运件中.rs,调用rsForEach(),Compute 才会自动调用硬件支持核心来计算) .android
参照DEMO
- 在上层调用forEach_root 计算的DEMO
- 在RenderScript 运行时调用rsForEach计算的DEMO
其实,两个DEMO都实现了同同样的功能,就是将一张图片使用滤镜效果将其变颜色RGB值变成灰尘色,而另外一张则原样显示,该DEMO参考了SDK中的HelloWorldCompute DEMO,而惟一与SDK中不同的地方是在:SDK是在于上层调用forEach_root方法进行计算,而我使用的是在.rs 中调用rsForEach方法进行计算。二者功能相同,实现效果不同而已。ide
在上层调用forEach_root 计算的DEMO
区别的代码在于: ui
SDK DEMO this
.rs文件 :google
#pragma version(1)
#pragma rs java_package_name(com.example.android.rs.hellocompute)
const
static float3 gMonoMult = {
0.299f,
0.587f,
0.114f};
void root(
const uchar4 *v_in, uchar4 *v_out) {
float4 f4 = rsUnpackColor8888(*v_in);
float3 mono = dot(f4.rgb, gMonoMult);
//
dot:[0]*[0]+[1]*[1]+[2]*[2]
*v_out = rsPackColorTo8888(mono);
}
createScript方法:spa
private
void createScript() {
mRS = RenderScript.create(
this);
mInAllocation = Allocation.createFromBitmap(mRS, mBitmapIn,
Allocation.MipmapControl.MIPMAP_NONE,
Allocation.USAGE_SCRIPT);
mOutAllocation = Allocation.createTyped(mRS, mInAllocation.getType());
mScript =
new ScriptC_mono(mRS, getResources(), R.raw.mono);
mScript.forEach_root(mInAllocation, mOutAllocation);//通知RenderScript Compute Runtime
mOutAllocation.copyTo(mBitmapOut);
}
在RenderScript 运行时调用rsForEach计算的DEMO
.rs文件:code
#pragma version(1)
#pragma rs java_package_name(com.xuzhi.renderScriptCompute)
rs_allocation gIn;
rs_allocation gOut;
rs_script gScript;
const
static float3 gMonoMult={
0.299f,
0.587f,
0.114f};
void root(
const uchar4 *v_in, uchar4 *v_out,
const
void *usrData, uint32_t x, uint32_t y){
//
将一个uchar4 的颜色解压为float4
float4 f4=rsUnpackColor8888(*v_in);
//
dot:[0]*[0]+[1]*[1]+[2]*[2]
float3 mono=dot(f4.rgb,gMonoMult);
//
打包uchar4,alpha 默认为1.0
*v_out=rsPackColorTo8888(mono);
}
void filter(){
//
调用RenderScript 进行处理(操做输入的图片而后把处理的结果放到输出结果中),最后把处理完的数据存回bitmap ,在ImageView显示出来
rsForEach(gScript, gIn, gOut);
}
createScript方法:orm
private
void createScript() {
mRS = RenderScript.create(
this);
//
从一个bitmap 建立一个allocation
mInAllocation = Allocation.createFromBitmap(mRS, mBitmapIn,
Allocation.MipmapControl.MIPMAP_NONE, Allocation.USAGE_SCRIPT);
mOutAllocation=Allocation.createTyped(mRS, mInAllocation.getType());
mScript=
new ScriptC_mono(mRS, getResources(), R.raw.mono);
mScript.set_gIn(mInAllocation);
mScript.set_gOut(mOutAllocation);
mScript.set_gScript(mScript);
mScript.invoke_filter();
//通知RenderScript Compute Runtime
mOutAllocation.copyTo(mBitmapOut);
}
总结
两种方法不管怎么变化,最终的上的都是要通知RenderScript Compute 运行时作计算功能。 运行效果:
代码下载:
RenderScript->Compute