Project

General

Profile

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

library / src / main / java / org / distorted / library / effectqueue / EffectQueueMatrix.java @ c90aca24

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

    
22
import android.opengl.GLES31;
23
import android.opengl.Matrix;
24

    
25
import org.distorted.library.effect.EffectType;
26
import org.distorted.library.effect.MatrixEffect;
27
import org.distorted.library.message.EffectMessageSender;
28

    
29
///////////////////////////////////////////////////////////////////////////////////////////////////
30

    
31
class EffectQueueMatrix extends EffectQueue
32
  {   
33
  private static final int NUM_UNIFORMS = MatrixEffect.NUM_UNIFORMS;
34
  private static final int INDEX = EffectType.MATRIX.ordinal();
35

    
36
  private static float[] mMVPMatrix = new float[16];
37
  private static float[] mViewMatrix= new float[16];
38

    
39
  private static int[] mObjDH      = new int[MAIN_VARIANTS];
40
  private static int[] mMVPMatrixH = new int[MAIN_VARIANTS];
41
  private static int[] mMVMatrixH  = new int[MAIN_VARIANTS];
42

    
43
  private static float[] mTmpMatrix = new float[16];
44
  private static float[] mTmpResult = new float[4];
45
  private static float[] mTmpPoint  = new float[4];
46
  private static float mMinX,mMaxX,mMinY,mMaxY;
47

    
48
///////////////////////////////////////////////////////////////////////////////////////////////////
49
   
50
  EffectQueueMatrix()
51
    { 
52
    super(NUM_UNIFORMS,INDEX );
53
    }
54

    
55
///////////////////////////////////////////////////////////////////////////////////////////////////
56

    
57
  static void uniforms(int mProgramH, int variant)
58
    {
59
    mObjDH[variant]     = GLES31.glGetUniformLocation(mProgramH, "u_objD");
60
    mMVPMatrixH[variant]= GLES31.glGetUniformLocation(mProgramH, "u_MVPMatrix");
61
    mMVMatrixH[variant] = GLES31.glGetUniformLocation(mProgramH, "u_MVMatrix");
62
    }
63

    
64
///////////////////////////////////////////////////////////////////////////////////////////////////
65

    
66
  private void magnifyDir()
67
    {
68
    Matrix.multiplyMV(mTmpResult,0,mTmpMatrix,0,mTmpPoint,0);
69
    float nx = mTmpResult[0]/mTmpResult[3];
70
    float ny = mTmpResult[1]/mTmpResult[3];
71

    
72
    if( nx<mMinX ) mMinX = nx;
73
    if( nx>mMaxX ) mMaxX = nx;
74
    if( ny<mMinY ) mMinY = ny;
75
    if( ny>mMaxY ) mMaxY = ny;
76
    }
77

    
78
///////////////////////////////////////////////////////////////////////////////////////////////////
79
// return a float which describes how much larger an object must be so that it appears to be (about)
80
// 'marginInPixels' pixels larger in each direction. Used in Postprocessing.
81

    
82
  float magnify(float[] projection, int width, int height, float mipmap, float halfX, float halfY, float halfZ, float marginInPixels)
83
    {
84
    mMinX = Integer.MAX_VALUE;
85
    mMaxX = Integer.MIN_VALUE;
86
    mMinY = Integer.MAX_VALUE;
87
    mMaxY = Integer.MIN_VALUE;
88

    
89
    mTmpPoint[3] = 1.0f;
90

    
91
    Matrix.multiplyMM(mTmpMatrix, 0, projection, 0, mViewMatrix, 0);
92

    
93
    mTmpPoint[0] = +halfX; mTmpPoint[1] = +halfY; mTmpPoint[2] = +halfZ; magnifyDir();
94
    mTmpPoint[0] = +halfX; mTmpPoint[1] = +halfY; mTmpPoint[2] = -halfZ; magnifyDir();
95
    mTmpPoint[0] = +halfX; mTmpPoint[1] = -halfY; mTmpPoint[2] = +halfZ; magnifyDir();
96
    mTmpPoint[0] = +halfX; mTmpPoint[1] = -halfY; mTmpPoint[2] = -halfZ; magnifyDir();
97
    mTmpPoint[0] = -halfX; mTmpPoint[1] = +halfY; mTmpPoint[2] = +halfZ; magnifyDir();
98
    mTmpPoint[0] = -halfX; mTmpPoint[1] = +halfY; mTmpPoint[2] = -halfZ; magnifyDir();
99
    mTmpPoint[0] = -halfX; mTmpPoint[1] = -halfY; mTmpPoint[2] = +halfZ; magnifyDir();
100
    mTmpPoint[0] = -halfX; mTmpPoint[1] = -halfY; mTmpPoint[2] = -halfZ; magnifyDir();
101

    
102
    float xLenInPixels = width *(mMaxX-mMinX)/2;
103
    float yLenInPixels = height*(mMaxY-mMinY)/2;
104

    
105
    // already margin / avg(xLen,yLen) is the size of the halo.
106
    // Here we need a bit more because we are marking not only the halo, but a little bit around
107
    // it as well so that the (blur for example) will be smooth on the edges. Thus the 2.0f.
108
    // ( 4.0 because there is an extra 2.0 from the avg(xLen,yLen) )
109
    //
110
    // mMipmap ( 1.0, 0.5, 0.25, 0.125 ) - we need to make the size of the halo independent
111
    // of postprocessing effect quality.
112

    
113
    return mipmap*4.0f*marginInPixels/( xLenInPixels+yLenInPixels );
114
    }
115

    
116
///////////////////////////////////////////////////////////////////////////////////////////////////
117

    
118
  void compute(long currTime)
119
    {
120
    if( currTime==mTime ) return;
121
    if( mTime==0 ) mTime = currTime;
122
    long step = (currTime-mTime);
123

    
124
    for(int i=0; i<mNumEffects; i++)
125
      {
126
      mCurrentDuration[i] += step;
127

    
128
      if( mEffects[i].compute(mUniforms, NUM_UNIFORMS*i, mCurrentDuration[i], step) )
129
        {
130
        EffectMessageSender.newMessage(mEffects[i]);
131
        }
132
      }
133
     
134
    mTime = currTime;  
135
    }  
136

    
137
///////////////////////////////////////////////////////////////////////////////////////////////////
138

    
139
  float[] getMVP()
140
    {
141
    return mMVPMatrix;
142
    }
143

    
144
///////////////////////////////////////////////////////////////////////////////////////////////////
145

    
146
  void send(int width, int height, float distance, float mipmap, float[] projection, float halfX, float halfY, float halfZ, int variant)
147
    {
148
    Matrix.setIdentityM(mViewMatrix, 0);
149
    Matrix.translateM(mViewMatrix, 0, -width*0.5f, -height*0.5f, -distance);
150
    if( mipmap!=1 ) Matrix.scaleM(mViewMatrix, 0, mipmap, mipmap, mipmap);
151

    
152
    for(int i=mNumEffects-1; i>=0; i--) ((MatrixEffect)mEffects[i]).apply(mViewMatrix,mUniforms,i);
153

    
154
    Matrix.translateM(mViewMatrix, 0, halfX,halfY,halfZ);
155
    Matrix.multiplyMM(mMVPMatrix, 0, projection, 0, mViewMatrix, 0);
156

    
157
    GLES31.glUniform3f( mObjDH[variant] , halfX, halfY, halfZ);
158
    GLES31.glUniformMatrix4fv(mMVMatrixH[variant] , 1, false, mViewMatrix, 0);
159
    GLES31.glUniformMatrix4fv(mMVPMatrixH[variant], 1, false, mMVPMatrix , 0);
160
    }
161
  }
(3-3/5)