Project

General

Profile

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

library / src / main / java / org / distorted / library / effect / FragmentEffect.java @ cbcf2374

1
///////////////////////////////////////////////////////////////////////////////////////////////////
2
// Copyright 2017 Leszek Koltunski  leszek@koltunski.pl                                          //
3
//                                                                                               //
4
// This file is part of Distorted.                                                               //
5
//                                                                                               //
6
// This library is free software; you can redistribute it and/or                                 //
7
// modify it under the terms of the GNU Lesser General Public                                    //
8
// License as published by the Free Software Foundation; either                                  //
9
// version 2.1 of the License, or (at your option) any later version.                            //
10
//                                                                                               //
11
// This library 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 GNU                             //
14
// Lesser General Public License for more details.                                               //
15
//                                                                                               //
16
// You should have received a copy of the GNU Lesser General Public                              //
17
// License along with this library; if not, write to the Free Software                           //
18
// Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA                //
19
///////////////////////////////////////////////////////////////////////////////////////////////////
20

    
21
package org.distorted.library.effect;
22

    
23
import org.distorted.library.effectqueue.EffectQueue;
24
import org.distorted.library.type.Static3D;
25

    
26
///////////////////////////////////////////////////////////////////////////////////////////////////
27
/**
28
 * Abstract class that represents an Effect that works by injecting certain code into the main Fragment shader.
29
 */
30
public abstract class FragmentEffect extends Effect
31
  {
32
  /**
33
   * 12: 4-per effect interpolated values, 3 dimensional Center (+padding), 3 dimensional Region (+padding).
34
   */
35
  public static final int NUM_FLOAT_UNIFORMS = 12;
36
  /**
37
   * 4: the name, unused, unused, unused
38
   */
39
  public static final int NUM_INT_UNIFORMS = 4;
40

    
41
  static final int CENTER_OFFSET = 5;
42
  static final int REGION_OFFSET = 8;
43
  private static String mGLSL = "";
44
  private static int mNumEnabled = 0;
45

    
46
  final static Static3D MAX_REGION = new Static3D(1000000,1000000,1000000);
47

    
48
///////////////////////////////////////////////////////////////////////////////////////////////////
49

    
50
  FragmentEffect(EffectName name)
51
    {
52
    super(name);
53
    }
54

    
55
///////////////////////////////////////////////////////////////////////////////////////////////////
56
// prepare code to be injected into the 'main_fragment_shader' main() function.
57

    
58
  static void addEffect(EffectName not_smooth, EffectName yes_smooth, String code)
59
    {
60
    int effect1 = not_smooth.ordinal();
61
    int effect2 = yes_smooth.ordinal();
62

    
63
    if( mEnabled[effect1] ) return;
64

    
65
    mEnabled[effect1] = true;
66
    mNumEnabled ++;
67

    
68
    mGLSL +=
69

    
70
         "if( fProperties[i].x =="+effect1+")\n"
71
        +  "{\n"
72
        +  "degree = sign(degree); \n"
73
        +   code +"\n"
74
        +  "}\n"
75
        +"else\n"
76
        +"if( fProperties[i].x =="+effect2+")\n"
77
        +  "{\n"
78
        +   code +"\n"
79
        +  "}\n"
80
        +"else\n";
81
    }
82

    
83
///////////////////////////////////////////////////////////////////////////////////////////////////
84
/**
85
 * Only for use by the library itself.
86
 *
87
 * @y.exclude
88
 */
89
  public static String getGLSL()
90
    {
91
    return mGLSL + "{}";
92
    }
93

    
94
///////////////////////////////////////////////////////////////////////////////////////////////////
95

    
96
  static void destroyStatics()
97
    {
98
    mNumEnabled = 0;
99
    mGLSL = "";
100
    }
101

    
102
///////////////////////////////////////////////////////////////////////////////////////////////////
103
/**
104
 * Only for use by the library itself.
105
 *
106
 * @y.exclude
107
 */
108
  public void addQueue(EffectQueue queue)
109
    {
110
    // NO OP
111
    }
112

    
113
///////////////////////////////////////////////////////////////////////////////////////////////////
114
/**
115
 * Only for use by the library itself.
116
 *
117
 * @y.exclude
118
 */
119
  public void remQueue(EffectQueue queue)
120
    {
121
    // NO OP
122
    }
123

    
124
///////////////////////////////////////////////////////////////////////////////////////////////////
125
// PUBLIC API
126
///////////////////////////////////////////////////////////////////////////////////////////////////
127
/**
128
 * Return the number of Fragment effects enabled.
129
 */
130
  public static int getNumEnabled()
131
    {
132
    return mNumEnabled;
133
    }
134
  }
(5-5/35)