Project

General

Profile

Download (6.17 KB) Statistics
| Branch: | Revision:

library / src / main / java / org / distorted / library / DistortedTexture.java @ 2e49718d

1
///////////////////////////////////////////////////////////////////////////////////////////////////
2
// Copyright 2016 Leszek Koltunski                                                               //
3
//                                                                                               //
4
// This file is part of Distorted.                                                               //
5
//                                                                                               //
6
// Distorted is free software: you can redistribute it and/or modify                             //
7
// it under the terms of the GNU General Public License as published by                          //
8
// the Free Software Foundation, either version 2 of the License, or                             //
9
// (at your option) any later version.                                                           //
10
//                                                                                               //
11
// Distorted is distributed in the hope that it will be useful,                                  //
12
// but WITHOUT ANY WARRANTY; without even the implied warranty of                                //
13
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the                                 //
14
// GNU General Public License for more details.                                                  //
15
//                                                                                               //
16
// You should have received a copy of the GNU General Public License                             //
17
// along with Distorted.  If not, see <http://www.gnu.org/licenses/>.                            //
18
///////////////////////////////////////////////////////////////////////////////////////////////////
19

    
20
package org.distorted.library;
21

    
22
import android.graphics.Bitmap;
23
import android.graphics.Matrix;
24
import android.opengl.GLES30;
25
import android.opengl.GLUtils;
26

    
27
///////////////////////////////////////////////////////////////////////////////////////////////////
28
/**
29
 * Class which represents a OpenGL Texture object.
30
 * <p>
31
 * Create a Texture of arbitrary size and feed some pixels to it via the setTexture() method.
32
 * <p>
33
 * Keep all objects created in a static LinkedList. The point: we need to be able to mark
34
 * Textures for deletion, and delete all marked objects later at a convenient time (that's
35
 * because we can only delete from a thread that holds the OpenGL context so here we provide a
36
 * framework where one is able to mark for deletion at any time and actual deletion takes place
37
 * on the next render).
38
 */
39
public class DistortedTexture extends DistortedRenderable
40
  {
41
  private Bitmap mBmp= null;
42

    
43
///////////////////////////////////////////////////////////////////////////////////////////////////
44
// We have to flip vertically every single Bitmap that we get fed with.
45
//
46
// Reason: textures read from files are the only objects in OpenGL which have their origins at the
47
// upper-left corner. Everywhere else the origin is in the lower-left corner. Thus we have to flip.
48
// The alternative solution, namely inverting the y-coordinate of the TexCoord does not really work-
49
// i.e. it works only in case of rendering directly to the screen, but if we render to an FBO and
50
// then take the FBO and render to screen, (DistortedTree does so!) things get inverted as textures
51
// created from FBO have their origins in the lower-left... Mindfuck!
52

    
53
  private static Bitmap flipBitmap(Bitmap src)
54
    {
55
    Matrix matrix = new Matrix();
56
    matrix.preScale(1.0f,-1.0f);
57

    
58
    return Bitmap.createBitmap(src,0,0,src.getWidth(),src.getHeight(), matrix,true);
59
    }
60

    
61
///////////////////////////////////////////////////////////////////////////////////////////////////
62
// must be called from a thread holding OpenGL Context
63

    
64
  void create()
65
    {
66
    if( mBmp!=null && mColorH !=null )
67
      {
68
      if( mColorH[0]==NOT_CREATED_YET )
69
        {
70
        GLES30.glGenTextures(1, mColorH, 0);
71
        GLES30.glBindTexture(GLES30.GL_TEXTURE_2D, mColorH[0]);
72
        GLES30.glTexParameteri ( GLES30.GL_TEXTURE_2D, GLES30.GL_TEXTURE_MIN_FILTER, GLES30.GL_LINEAR );
73
        GLES30.glTexParameteri ( GLES30.GL_TEXTURE_2D, GLES30.GL_TEXTURE_MAG_FILTER, GLES30.GL_LINEAR );
74
        GLES30.glTexParameteri ( GLES30.GL_TEXTURE_2D, GLES30.GL_TEXTURE_WRAP_S, GLES30.GL_CLAMP_TO_EDGE );
75
        GLES30.glTexParameteri ( GLES30.GL_TEXTURE_2D, GLES30.GL_TEXTURE_WRAP_T, GLES30.GL_CLAMP_TO_EDGE );
76
        GLUtils.texImage2D(GLES30.GL_TEXTURE_2D, 0, flipBitmap(mBmp), 0);
77
        }
78
      else
79
        {
80
        GLES30.glBindTexture(GLES30.GL_TEXTURE_2D, mColorH[0]);
81
        GLUtils.texSubImage2D(GLES30.GL_TEXTURE_2D, 0,0,0,flipBitmap(mBmp));
82
        }
83

    
84
      mBmp = null;
85
      }
86
    }
87

    
88
///////////////////////////////////////////////////////////////////////////////////////////////////
89
// must be called from a thread holding OpenGL Context
90

    
91
  void delete()
92
    {
93
    if( mColorH !=null && mColorH[0]>=0 )
94
      {
95
      GLES30.glDeleteTextures(1, mColorH, 0);
96
      mColorH[0] = NOT_CREATED_YET;
97
      }
98
    }
99

    
100
///////////////////////////////////////////////////////////////////////////////////////////////////
101

    
102
  static void getUniforms(int mProgramH)
103
    {
104
    int textureH= GLES30.glGetUniformLocation( mProgramH, "u_Texture");
105

    
106
    GLES30.glActiveTexture(GLES30.GL_TEXTURE0);
107
    GLES30.glUniform1i(textureH, 0);
108
    }
109

    
110
///////////////////////////////////////////////////////////////////////////////////////////////////
111
// PUBLIC API
112
///////////////////////////////////////////////////////////////////////////////////////////////////
113
/**
114
 * Create empty texture of given dimensions.
115
 */
116
  public DistortedTexture(int width, int height)
117
    {
118
    super(width,height,NOT_CREATED_YET);
119
    mBmp= null;
120
    }
121

    
122
///////////////////////////////////////////////////////////////////////////////////////////////////
123
/**
124
 * Sets the underlying android.graphics.Bitmap object.
125
 * <p>
126
 * You can only recycle() the passed Bitmap once the OpenGL context gets created (i.e. after call
127
 * to GLSurfaceView.onSurfaceCreated) because only after this point can the Library upload it to the GPU!
128
 *
129
 * @param bmp The android.graphics.Bitmap object to apply effects to and display.
130
 */
131
  public void setTexture(Bitmap bmp)
132
    {
133
    mBmp= bmp;
134
    }
135
  }
(5-5/17)