Project

General

Profile

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

library / src / main / java / org / distorted / library / effect / MatrixEffectScale.java @ 6bb59aad

1
///////////////////////////////////////////////////////////////////////////////////////////////////
2
// Copyright 2017 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.effect;
21

    
22
import org.distorted.library.type.Data3D;
23
import org.distorted.library.type.Dynamic3D;
24
import org.distorted.library.type.Static3D;
25

    
26
///////////////////////////////////////////////////////////////////////////////////////////////////
27

    
28
public class MatrixEffectScale extends MatrixEffect
29
  {
30
  private static final String NAME = "SCALE";
31
  private static final float[] UNITIES = new float[] {1.0f,1.0f,1.0f};
32
  private static final int DIMENSION = 3;
33
  private static final boolean SUPPORTS_CENTER = false;
34
  private static final boolean SUPPORTS_REGION = false;
35

    
36
///////////////////////////////////////////////////////////////////////////////////////////////////
37
/**
38
 * Scales the Object by (possibly changing in time) 3D scale factors.
39
 *
40
 * @param scale 3-dimensional Data which at any given time returns a Static3D
41
 *              representing the current x- , y- and z- scale factors.
42
 */
43
  public MatrixEffectScale(Data3D scale)
44
    {
45
    super(SCALE,UNITIES,DIMENSION,SUPPORTS_CENTER,SUPPORTS_REGION,NAME);
46

    
47
    if( scale instanceof Static3D)
48
      {
49
      mStatic0 = (Static3D)scale;
50
      }
51
    else if ( scale instanceof Dynamic3D)
52
      {
53
      mDynamic0 = (Dynamic3D)scale;
54
      }
55
    }
56

    
57
///////////////////////////////////////////////////////////////////////////////////////////////////
58
/**
59
 * Scales the Object by (possibly changing in time) 3D scale factors.
60
 *
61
 * @param scale Common x,y, and z scale factor.
62
 */
63
  public MatrixEffectScale(float scale)
64
    {
65
    super(SCALE,UNITIES,DIMENSION,SUPPORTS_CENTER,SUPPORTS_REGION,NAME);
66

    
67
    mStatic0 = new Static3D(scale,scale,scale);
68
    }
69

    
70
///////////////////////////////////////////////////////////////////////////////////////////////////
71

    
72
  public boolean compute(float[] uniforms, int index, long currentDuration, long step )
73
    {
74
    if( mDynamic0!=null )
75
      {
76
      return mDynamic0.interpolateMain(uniforms,index,currentDuration,step);
77
      }
78
    else
79
      {
80
      uniforms[index  ] = ((Static3D)mStatic0).getX();
81
      uniforms[index+1] = ((Static3D)mStatic0).getY();
82
      uniforms[index+2] = ((Static3D)mStatic0).getZ();
83

    
84
      return false;
85
      }
86
    }
87
  }
(12-12/23)