Stage3d AGAL GPU处理照片 旧照片效果 sepia || pixelbender
如果看不到下边的flash,请更新flash player到最新版本。
利用AGAL实现旧照片效果,大家可以对照一下之前一篇文章,关于图像处理(pixelbender)。硬件处理肯定会更快,但这里无法表现出来,毕竟图片就这么小。拖拉进度条,可以设置照片旧的程度。
package
{
import com.adobe.utils.AGALMiniAssembler;
import com.bit101.components.HSlider;
import com.bit101.components.PushButton; import flash.display.Bitmap;
import flash.display.BitmapData;
import flash.display.Loader;
import flash.display.Sprite;
import flash.display.Stage3D;
import flash.display.StageAlign;
import flash.display.StageScaleMode;
import flash.display3D.Context3D;
import flash.display3D.IndexBuffer3D;
import flash.display3D.Program3D;
import flash.display3D.VertexBuffer3D;
import flash.display3D.textures.Texture;
import flash.events.Event;
import flash.geom.Matrix;
import flash.geom.Matrix3D;
import flash.net.FileFilter;
import flash.net.FileReference;
import flash.utils.ByteArray; import net.hires.debug.Stats; /**
* 借用了boycy815的代码框架
* @author kenkozheng
*/
[SWF(frameRate="60")]
public class AGAL_Filter extends Sprite
{
private const WIDTH:Number = 512;
private const HEIGHT:Number = 512; //stage3d五巨头
private var _stage3d:Stage3D;
private var _context3d:Context3D;
private var _program3d:Program3D;
private var _index:IndexBuffer3D;
private var _vertex:VertexBuffer3D;
private var _texture:Texture; [Embed(source=("4.jpg"))]
private var ImageSource:Class; private var _vertexProgram:String = "mov op, va0\n" +
"mov v0, va1"; //传递给片段shader坐标值 private var _fragmentProgram:String = "tex ft1, v0, fs0<2d,linear,nomip>\n" +
"m44 ft2, ft1, fc1\n" + //颜色变换
"mul ft2, ft2, fc0.x\n" + //效果图跟原图做multiply,向量float4 * float = float4,类似PixelBender
"mul ft1, ft1, fc0.y\n" +
"add ft2, ft2, ft1\n" +
"mov oc, ft2"; public function AGAL_Filter():void
{
if (stage) init();
else addEventListener(Event.ADDED_TO_STAGE, init);
} private function init(e:Event = null):void
{
stage.scaleMode = StageScaleMode.NO_SCALE;
stage.align = StageAlign.TOP_LEFT;
removeEventListener(Event.ADDED_TO_STAGE, init);
_stage3d = stage.stage3Ds[0];
_stage3d.addEventListener(Event.CONTEXT3D_CREATE, onCreate);
_stage3d.requestContext3D();
addChild(new Stats());
} private function onCreate(e:Event):void
{
e.target.removeEventListener(Event.CONTEXT3D_CREATE, onCreate); _context3d = _stage3d.context3D;
_context3d.enableErrorChecking = true; var agal:AGALMiniAssembler = new AGALMiniAssembler(); var vp:ByteArray = agal.assemble("vertex", _vertexProgram);
var fp:ByteArray = agal.assemble("fragment", _fragmentProgram);
_program3d = _context3d.createProgram();
_program3d.upload(vp, fp);
_context3d.setProgram(_program3d); _context3d.configureBackBuffer(WIDTH, HEIGHT, 0, false);
_context3d.setBlendFactors("one", "zero");
_context3d.setCulling("back"); //两个三角形拼成平面
_index = _context3d.createIndexBuffer(6);
_index.uploadFromVector(new<uint>[0, 1, 2, 0, 2, 3], 0, 6); _vertex = _context3d.createVertexBuffer(4, 4);
//这是由于纹理的坐标原点是左上角,y轴向下,最大值为1最小值为0
//而顶点的坐标原点则是在舞台中央,而且y轴向上,最大值为1最小值为-1
//那么(-1,-1)点对应的纹理就是(0,1)
_vertex.uploadFromVector(new<Number>[
//x, y, u, v
-1, -1, 0, 1,
-1, 1, 0, 0,
1, 1, 1, 0,
1, -1, 1, 1], 0, 4);
_context3d.setVertexBufferAt(0, _vertex, 0, "float2"); //xy坐标
_context3d.setVertexBufferAt(1, _vertex, 2, "float2"); //uv坐标 //纹理位图
var bt:Bitmap = Bitmap(new ImageSource());
var btmap:BitmapData = new BitmapData(WIDTH, HEIGHT);
btmap.draw(bt); //上传纹理
_texture = _context3d.createTexture(btmap.width, btmap.height, "bgra", false);
_texture.uploadFromBitmapData(btmap);
_context3d.setTextureAt(0, _texture);
//multiple比例
_context3d.setProgramConstantsFromVector("fragment", 0, new<Number>[1, 0, 0, 0]);
//颜色矩阵
_context3d.setProgramConstantsFromMatrix("fragment", 1, new Matrix3D(new <Number>[
0.393, 0.768, 0.189, 0,
0.349, 0.686, 0.168, 0,
0.272, 0.534, 0.13, 0,
0, 0, 0, 1
])); _context3d.clear(0, 0, 0, 0);
_context3d.drawTriangles(_index);
_context3d.present(); start();
} private function start():void
{
new PushButton(this, 282, 515, "change", onUpload);
new HSlider(this, 392, 520, onBar).setSliderParams(0, 1, 1);
} private function onBar(e:Event):void
{
var v:Number = e.currentTarget.value;
_context3d.setProgramConstantsFromVector("fragment", 0, new<Number>[v, 1-v, 0, 0]);
_context3d.clear(0, 0, 0, 0);
_context3d.drawTriangles(_index);
_context3d.present();
} private function onUpload(e:Event):void
{
var fr:FileReference = new FileReference();
fr.addEventListener(Event.SELECT, onSelect);
fr.browse([new FileFilter("jpg/png", "*.jpg;*.png")]);
} private function onSelect(e:Event):void
{
e.currentTarget.removeEventListener(Event.SELECT, onSelect);
e.currentTarget.addEventListener(Event.COMPLETE, onComplete);
e.currentTarget.addEventListener(Event.OPEN, function(e:Event):void { } );
e.currentTarget.load();
} private function onComplete(e:Event):void
{
e.currentTarget.removeEventListener(Event.COMPLETE, onComplete);
var loader:Loader = new Loader();
loader.contentLoaderInfo.addEventListener(Event.COMPLETE, loaderOnComplete);
loader.loadBytes(e.currentTarget.data);
} private function loaderOnComplete(e:Event):void
{
e.currentTarget.removeEventListener(Event.COMPLETE, loaderOnComplete); var btmap:BitmapData = new BitmapData(WIDTH, HEIGHT);
var scale:Number = Math.max(WIDTH/e.currentTarget.loader.width, HEIGHT/e.currentTarget.loader.height);
btmap.draw(e.currentTarget.loader, new Matrix(scale, 0, 0, scale), null, null, null, true); _texture.uploadFromBitmapData(btmap); _context3d.clear(0, 0, 0, 0);
_context3d.drawTriangles(_index);
_context3d.present();
}
} }
Stage3d AGAL GPU处理照片 旧照片效果 sepia || pixelbender的更多相关文章
- Android ColorMatrix类图像颜色处理-黑白老照片、泛黄旧照片、高对比度等效果
在Android中,对图像进行颜色方面的处理,如黑白老照片.泛黄旧照片.高对比度.低饱和度等效果,都可以通过使用颜色矩阵(ColorMatrix)来实现. 1.颜色矩阵(ColorMatrix)介绍 ...
- 微软开源的 AI 工具,让旧照片焕发新生
原文地址:Bringing Old Photos Back to Life 原文作者:Ziyu Wan 译者 & 校正:HelloGitHub-小鱼干 & 鸭鸭 写在前面 在 GitH ...
- css: 照片有如层叠效果
显示上面照片效果css <!DOCTYPE html> <!--headTrap<body></body><head></head>& ...
- 使用CoreAnimation 实现相机拍摄照片之后动画效果
废话不多说,先看上效果,由于动画录制的时候帧率限制,只能将动画放慢了进行录制,更容易看到效果 这是点击开始之后代码 -(IBAction)btnStartClick:(id)sender { CABa ...
- Photoshop将普通照片快速制作二次元漫画风格效果
今天为大家分享Photoshop将普通照片快速制作二次元漫画风格效果,教程很不错,对于喜欢漫画的朋友可以参考本文,希望能对大家有所帮助! 一提到日本动画电影,大家第一印象肯定是宫崎骏,但是日本除了宫崎 ...
- 3d照片环效果(修改版--添加了x轴y轴双向转动和修复模糊度的bug)
今天用用前两天总结的css3新效果写了一个3d照片环的效果,其中还有些bug大家可以看一看,一起改进. <!DOCTYPE html> <html lang="en&quo ...
- Stage3d 由浅到深理解AGAL的管线vertex shader和fragment shader || 简易教程 学习心得 AGAL 非常非常好的入门文章
Everyday Stage3D (一) Everyday Stage3D (二) Triangle Everyday Stage3D (三) AGAL的基本概念 Everyday Stage3D ( ...
- 一定要记住这20种PS技术!!!会让你的照片美的不行!!!
一种简单的数码照片后期润饰 1 打开图片,执行色像/饱和度(-40)降低饱和度. 2 新建一图层,将图层模式改为柔光,用画笔工具将需要润饰的部分画几下,这里可以利用色板方便的提取颜色 3 图片色彩过渡 ...
- photoshop快速把新照片制作成老照片教学
原图 步骤1 在photoshop中找开需要处理的图片,Ctrl+J复制图片,得到图片1. 步骤2 单击图层面板底部的创建新的填充或调整图层图标,添加色调/饱和度调整图层.调整它的饱合度和明度. 步骤 ...
随机推荐
- 修改WampServer的默认端口
WampServer默认的安装端口是80,容易和已安装的ISS等其他服务冲突,导致WampServer无法启动. 无法启动的现象如下: 1.apache服务无法启动.问题所在:80端口冲突. 2.在浏 ...
- 关于ANDROID模拟器的一些事
转载请注明本文出自大苞米的博客(http://blog.csdn.net/a396901990),谢谢支持! 继上一篇Android Studio VS Eclipse的文章后接着来分享AnDevCo ...
- C#调用 Oracle 存储过程样例代码
-- 建表 CREATE TABLE sale_report ( sale_date DATE NOT NULL , sale_item VARCHAR(2) NOT NULL , ...
- C#托管堆对象实例包含什么
每个托管堆上的对象实例除了包含本身的值外,还包括:○ Type Object Ponter: 指向Type对象实例.如果是同类型的对象实例,就指向同一个Type对象实例.○ Sync Block In ...
- ProGuard使用简介
我们做java开发的一般都会遇到如何保护我们开发的代码问题.java语言由于是基于jvm上面,所以反编译class 文件很很容易.假如我们做了一个web程序,并把这个web程序发布给客户.实际上,客户 ...
- plsql调用无参/有参存储过程
--有参调用方式:declare STERMINAL ); SPROCESS NUMBER; begin sj_transfera_digi_getmapping(,,'DYH010006783031 ...
- Android图片加载框架最全解析(四),玩转Glide的回调与监听
大家好,今天我们继续学习Glide. 在上一篇文章当中,我带着大家一起深入探究了Glide的缓存机制,我们不光掌握了Glide缓存的使用方法,还通过源码分析对缓存的工作原理进行了了解.虽说上篇文章和本 ...
- 【UOJ Round #8】
A 一道不错的题,虽然大家都觉得是水题,然而蒟蒻我想出来的好慢……Orz alpq 发现其实就是一个网格图,每一个大块都是同一颜色……横纵坐标互不干扰…… //UOJ Round #8 A #incl ...
- 【BZOJ】【3671】【NOI2014】随机数生成器
贪心 嗯……其实生成这个矩阵就是一个$O(n^2)$的模拟 = = 然后?字典序最小?贪心呗= =能选1就选1,然后能选2就选2…… 我们发现,对于矩阵(1,1)~(n,m),假设1的位置是(x,y) ...
- convert-a-number-to-hexadecimal
https://leetcode.com/problems/convert-a-number-to-hexadecimal/ // https://discuss.leetcode.com/topic ...