Project

General

Profile

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

library / src / main / java / org / distorted / library / effect / MatrixEffectShear.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 MatrixEffectShear extends MatrixEffect
29
  {
30
  private static final String NAME = "SHEAR";
31
  private static final float[] UNITIES = new float[] {0.0f,0.0f,0.0f};
32
  private static final int DIMENSION = 3;
33
  private static final boolean SUPPORTS_CENTER = true;
34
  private static final boolean SUPPORTS_REGION = false;
35

    
36
///////////////////////////////////////////////////////////////////////////////////////////////////
37
/**
38
 * Shears the Object.
39
 *
40
 * @param shear   The 3-tuple of shear factors. The first controls level
41
 *                of shearing in the X-axis, second - Y-axis and the third -
42
 *                Z-axis. Each is the tangens of the shear angle, i.e 0 -
43
 *                no shear, 1 - shear by 45 degrees (tan(45deg)=1) etc.
44
 * @param center  Center of shearing, i.e. the point which stays unmoved.
45
 */
46
  public MatrixEffectShear(Data3D shear, Data3D center)
47
    {
48
    super(SHEAR,UNITIES,DIMENSION,SUPPORTS_CENTER,SUPPORTS_REGION,NAME);
49

    
50
    if( shear instanceof Static3D)
51
      {
52
      mStatic0 = (Static3D)shear;
53
      }
54
    else if ( shear instanceof Dynamic3D)
55
      {
56
      mDynamic0 = (Dynamic3D)shear;
57
      }
58

    
59
    if( center instanceof Static3D)
60
      {
61
      mStaticCenter = (Static3D)center;
62
      }
63
    else if( center instanceof Dynamic3D )
64
      {
65
      mDynamicCenter = (Dynamic3D)center;
66
      }
67
    }
68

    
69
///////////////////////////////////////////////////////////////////////////////////////////////////
70

    
71
  public boolean compute(float[] uniforms, int index, long currentDuration, long step )
72
    {
73
    if( mDynamicCenter!=null )
74
      {
75
      mDynamicCenter.interpolateMain(uniforms,index+4,currentDuration,step);
76
      }
77
    else
78
      {
79
      uniforms[index+4] = mStaticCenter.getX();
80
      uniforms[index+5] = mStaticCenter.getY();
81
      uniforms[index+6] = mStaticCenter.getZ();
82
      }
83

    
84
    if( mDynamic0!=null )
85
      {
86
      return mDynamic0.interpolateMain(uniforms,index,currentDuration,step);
87
      }
88
    else
89
      {
90
      uniforms[index  ] = ((Static3D)mStatic0).getX();
91
      uniforms[index+1] = ((Static3D)mStatic0).getY();
92
      uniforms[index+2] = ((Static3D)mStatic0).getZ();
93

    
94
      return false;
95
      }
96
    }
97
  }
(13-13/23)