Project

General

Profile

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

library / src / main / java / org / distorted / library / effect / MatrixEffectScale.java @ 1dec66e0

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.helpers.MatrixHelper;
24
import org.distorted.library.type.Data3D;
25
import org.distorted.library.type.Static3D;
26

    
27
///////////////////////////////////////////////////////////////////////////////////////////////////
28
/**
29
 * Scale the Mesh by 3D scale factors.
30
 */
31
public class MatrixEffectScale extends MatrixEffect
32
  {
33
  private final Data3D mScale;
34

    
35
///////////////////////////////////////////////////////////////////////////////////////////////////
36
/**
37
 * Only for use by the library itself.
38
 *
39
 * @y.exclude
40
 */
41
  public boolean compute(float[] uniforms, int index, long currentDuration, long step )
42
    {
43
    return mScale.get(uniforms,index,currentDuration,step);
44
    }
45

    
46
///////////////////////////////////////////////////////////////////////////////////////////////////
47
/**
48
 * Only for use by the library itself.
49
 * <p>
50
 * Here and in Shear we have the whole reason why there are two separate 'P' and 'V' (Point and
51
 * Vector) matrices - Scale and Shear have to manipulate Points and Normal Vectors differently.
52
 *
53
 * Points get multiplied by (sx,sy,sz) - and vectors by (1/sx,1/sy,1/sz) (think about it!) - or
54
 * better by sx*sy*sz*(1/sx,1/sy,1/sz) to avoid dividing my zero (vectors are normalized after)
55
 *
56
 * @y.exclude
57
 */
58
  public void apply(float[] matrixP, float[] matrixV, float[] uniforms, int index)
59
    {
60
    float sx = uniforms[NUM_FLOAT_UNIFORMS*index  ];
61
    float sy = uniforms[NUM_FLOAT_UNIFORMS*index+1];
62
    float sz = uniforms[NUM_FLOAT_UNIFORMS*index+2];
63

    
64
    MatrixHelper.scale(matrixP, sx, sy, sz);
65
    MatrixHelper.scale(matrixV, sy*sz, sx*sz, sx*sy);
66
    }
67

    
68
///////////////////////////////////////////////////////////////////////////////////////////////////
69
// PUBLIC API
70
///////////////////////////////////////////////////////////////////////////////////////////////////
71
/**
72
 * Scale the Mesh by 3D scale factors.
73
 *
74
 * @param scale current x- , y- and z- scale factors.
75
 */
76
  public MatrixEffectScale(Data3D scale)
77
    {
78
    super(EffectName.SCALE);
79
    mScale = scale;
80
    }
81

    
82
///////////////////////////////////////////////////////////////////////////////////////////////////
83
/**
84
 * Scale the Mesh by 3D scale factors.
85
 *
86
 * @param scale Common x,y, and z scale factor.
87
 */
88
  public MatrixEffectScale(float scale)
89
    {
90
    super(EffectName.SCALE);
91
    mScale = new Static3D(scale,scale,scale);
92
    }
93
  }
(15-15/34)