最近发现pixel bender有两个特殊点:
1、Input Image4,不单单可以用BitmapData来初始化,也可以用Vector.<Number>初始化。
2、ShaderJob,可以使用Vector.<Number>接收pb的运算结果,同时,这个输出结果不限于[0-1]。结果会从上往下一行一行的把每个像素的各通道信息填入到Vector中
基于这两点,就可以发现,可以把复杂的数学运算交给pb。尤其是类似于图像这样二维的信息,例如3d建模中,水面波动的计算。
AS代码:
代码语言:javascript复制var width :int = 3;
var height:int = 3;
var vector:Vector.<Number> = new Vector.<Number>;
var counter:int = 1;
//利用vector作为input,需要从左上角到右下角,逐行逐行把每个像素的3通道信息,以3个Number形式表示
for (var i:int = 0; i < width; i )
{
for (var j:int = 0; j < height; j )
{
vector.push(counter, counter, counter);
counter ;
}
}
//目的是格式化输出,好看。。。
for (var k:int = 0; k < vector.length; k =3* width)
{
var array:Array = new Array();
for (var i2:int = 0; i2 < width ; i2 )
{
array.push(vector[k i2*3] "," vector[k 1 i2*3] "," vector[k 2 i2*3]);
}
trace(array.join(" "));
}
trace ("=====================");
var shader:Shader = new Shader( new PbjClass() as ByteArray );
shader.data.src.input = vector;
shader.data.src.width = width;//这里必须指定width和height,否则出错
shader.data.src.height = height;
var result:Vector.<Number> = new Vector.<Number>();
//这里必须指定width和height,否则出错
var job:ShaderJob = new ShaderJob(shader, result, width, height);
job.start(true);
//目的是格式化输出,好看。。。
for (var k:int = 0; k < result.length; k =3* width)
{
var array:Array = new Array();
for (var i2:int = 0; i2 < width ; i2 )
{
array.push(result[k i2*3] "," result[k 1 i2*3] "," result[k 2 i2*3]);
}
trace(array.join(" "));
}
输出结果:
代码语言:javascript复制1,1,1 2,2,2 3,3,3
4,4,4 5,5,5 6,6,6
7,7,7 8,8,8 9,9,9
=====================
1,1,1 1,1,1 2,2,2
4,4,4 4,4,4 5,5,5
7,7,7 7,7,7 8,8,8
Pixel bender代码:
代码语言:javascript复制<languageVersion : 1.0;>
kernel test
< namespace : "Your Namespace";
vendor : "Your Vendor";
version : 1;
>
{
input image3 src; //注意这里是3,不是4.如果是4的话,就会报错。着色器输入 src 没有足够的数据。因为as代码中初始化输入只是用了3元组
output pixel3 dst;
void
evaluatePixel()
{
float2 coord = outCoord();
pixel3 px = sampleNearest(src, coord float2(-1.0, 0.0));
dst.x = px.x;
dst.y = px.y;
dst.z = px.z;
}
}