Project

General

Profile

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

library / src / main / java / org / distorted / library / main / DistortedTexture.java @ 246d021c

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.main;
21

    
22
import android.graphics.Bitmap;
23
import android.graphics.Canvas;
24
import android.graphics.Matrix;
25
import android.graphics.Paint;
26
import android.opengl.GLES30;
27
import android.opengl.GLUtils;
28

    
29
///////////////////////////////////////////////////////////////////////////////////////////////////
30
/**
31
 * Class which represents a OpenGL Texture object.
32
 * <p>
33
 * Create a Texture of arbitrary size and feed some pixels to it via the setTexture() method.
34
 */
35
public class DistortedTexture extends InternalSurface
36
  {
37
  private Bitmap mBmp;
38

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

    
49
  private static Bitmap flipBitmap(Bitmap src)
50
    {
51
    Matrix matrix = new Matrix();
52
    matrix.preScale(1.0f,-1.0f);
53

    
54
    return Bitmap.createBitmap(src,0,0,src.getWidth(),src.getHeight(), matrix,true);
55
    }
56

    
57
///////////////////////////////////////////////////////////////////////////////////////////////////
58
// must be called from a thread holding OpenGL Context
59

    
60
  void create()
61
    {
62
    if( mBmp!=null )
63
      {
64
      if( mColorCreated==NOT_CREATED_YET )
65
        {
66
        mColorCreated = CREATED;
67
        GLES30.glGenTextures(1, mColorH, 0);
68
        }
69

    
70
      GLES30.glBindTexture(GLES30.GL_TEXTURE_2D, mColorH[0]);
71
      GLES30.glTexParameteri ( GLES30.GL_TEXTURE_2D, GLES30.GL_TEXTURE_MIN_FILTER, GLES30.GL_LINEAR );
72
      GLES30.glTexParameteri ( GLES30.GL_TEXTURE_2D, GLES30.GL_TEXTURE_MAG_FILTER, GLES30.GL_LINEAR );
73
      GLES30.glTexParameteri ( GLES30.GL_TEXTURE_2D, GLES30.GL_TEXTURE_WRAP_S, GLES30.GL_CLAMP_TO_EDGE );
74
      GLES30.glTexParameteri ( GLES30.GL_TEXTURE_2D, GLES30.GL_TEXTURE_WRAP_T, GLES30.GL_CLAMP_TO_EDGE );
75
      GLUtils.texImage2D(GLES30.GL_TEXTURE_2D, 0, flipBitmap(mBmp), 0);
76
      GLES30.glBindTexture(GLES30.GL_TEXTURE_2D, 0);
77

    
78
      mBmp = null;
79
      }
80
    }
81

    
82
///////////////////////////////////////////////////////////////////////////////////////////////////
83
// must be called from a thread holding OpenGL Context
84

    
85
  void delete()
86
    {
87
    if( mColorH[0]>0 )
88
      {
89
      GLES30.glDeleteTextures(1, mColorH, 0);
90
      mColorH[0] = 0;
91
      mColorCreated = NOT_CREATED_YET;
92
      }
93
    }
94

    
95
///////////////////////////////////////////////////////////////////////////////////////////////////
96
// called from onDestroy(); mark OpenGL assets as 'not created'
97

    
98
  void recreate()
99
    {
100
    if( mColorCreated!=DONT_CREATE )
101
      {
102
      mColorCreated = NOT_CREATED_YET;
103
      mColorH[0] = 0;
104
      }
105
    }
106

    
107
///////////////////////////////////////////////////////////////////////////////////////////////////
108
// create SYSTEM or TREE textures (those are just like normal Textures, just hold information
109
// that they were autocreated only for the Library's internal purposes (SYSTEM) or for using
110
// inside a Tree of DistortedNodes (TREE)
111
// SYSTEM surfaces do not get removed in onDestroy().
112

    
113
  public DistortedTexture(int type)
114
    {
115
    super(NOT_CREATED_YET,1,1,type);
116
    mBmp= null;
117
    }
118

    
119
///////////////////////////////////////////////////////////////////////////////////////////////////
120
// PUBLIC API
121
///////////////////////////////////////////////////////////////////////////////////////////////////
122
/**
123
 * Create an empty texture.
124
 */
125
  public DistortedTexture()
126
    {
127
    this(TYPE_USER);
128
    }
129

    
130
///////////////////////////////////////////////////////////////////////////////////////////////////
131
/**
132
 * Sets the underlying android.graphics.Bitmap object.
133
 * <p>
134
 * You can only recycle() the passed Bitmap once the OpenGL context gets created (i.e. after call
135
 * to GLSurfaceView.onSurfaceCreated) because only after this point can the Library upload it to the GPU!
136
 *
137
 * @param bmp The android.graphics.Bitmap object to apply effects to and display.
138
 */
139
  public void setTexture(Bitmap bmp)
140
    {
141
    mBmp= bmp;
142
    markForCreation();
143
    }
144

    
145
///////////////////////////////////////////////////////////////////////////////////////////////////
146
/**
147
 * Paints the Texture with solid color.
148
 *
149
 * @param argb The color to paint the Texture with.
150
 */
151
  public void setColorARGB(int argb)
152
    {
153
    Paint paint = new Paint();
154
    paint.setColor(argb);
155
    paint.setStyle(Paint.Style.FILL);
156

    
157
    mBmp = Bitmap.createBitmap(1,1, Bitmap.Config.ARGB_8888);
158
    Canvas canvas = new Canvas(mBmp);
159
    canvas.drawRect(0,0,1,1,paint);
160

    
161
    markForCreation();
162
    }
163
  }
(6-6/14)