android openglse实现滤镜九宫格

opengl的渲染之前讲过很多,包括FBO等常用的技术(可参考我的博客:fbo),今天解决之前的一个小疑问:手机系统相机中,九宫格的滤镜选择是如何实现的,今天闲暇就实现起来看看,同时开放出来之前私有的相机项目:LammyOpenglCamera
原理:先利用fbo,将相机数据绘制到一个纹理当中,然后将纹理设置到不同的filter,利用 glViewport来确定绘制窗口位置,然后利用不同的filter绘制在一个glsurfaceview不同的位置。

确定滤镜的位置

过滤格子位置不包含间隔

如图,假如每个格子代表一个滤镜的显示,不包含过滤之间的间隔,为何这样标记主要是因为 glViewport的参数坐标是 左下角为圆心的
为了符合应用的审美习惯,从左上角开始显示filter,因此,在结算第二个参数y的时候,用2-当前的y的竖直参数,计算位置如下:然后将位置以point来存储在filtersStartPoints中

private void getFiltersStartPoints( int width, int height){
      int offsetW = width /24;
      int offsetH = height/24;
      int size = filters.size();
      for(int i = 0; i < size; i ++){
          int index = i/9;
          int offX = offsetW + index * width + (i % 3) * width/3;
          int offY = offsetH + (2-(i % 9)/3) * height/3;
          filtersStartPoints.add(new Point(offX,offY));
      }
  }

offsetW是距离glsurfaceView左边的距离,offsetW是距离底边的距离。每个filter的宽高是总的控件宽高的1/4。

绘制filter

确定了每个filter的位置后,只需要利用glViewport来控制绘制的位置,然后将每个filter的texture设置为camera数据离频渲染的texture,然后就可以将所有filter的滤镜效果绘制出来:

 private ArrayList<LyFilter> filters = new ArrayList<>();
  public void drawFilters(int textureId, int width, int height){

        if(filtersStartPoints.size() < filters.size()){
            getFiltersStartPoints( width,  height);
        }

        GLES20.glClearColor(0.0f, 0.0f, 0.0f, 0.0f);
        GLES20.glClear(GLES20.GL_COLOR_BUFFER_BIT | GLES20.GL_DEPTH_BUFFER_BIT);

        int size = filters.size();
        for(int i = 0; i < size; i ++){
            LyFilter filter = filters.get(i);
            filter.setTextureId(textureId);
            GLES20.glViewport(filtersStartPoints.get(i).x, filtersStartPoints.get(i).y ,
                                            width/4, height/4);
            filter.drawNoClear();
        }
        GLES20.glViewport(0,0,width,height);

这样就可以将多个filter绘制到一个glsurfaceview上,当然在ontouch中实现滑动翻页,因此,可以最多绘制2页就够了,在滑动的时候,我们只需要平移窗口即可。
效果如下:

device-2019-06-13-155722.png

也希望各位老铁下载,如有收获还请多多给予鼓励,谢谢,github地址:LammyOpenglCamera

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,547评论 6 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,399评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,428评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,599评论 1 274
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,612评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,577评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,941评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,603评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,852评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,605评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,693评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,375评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,955评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,936评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,172评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,970评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,414评论 2 342