~holger-seelig/cobweb.js/trunk

« back to all changes in this revision

Viewing changes to src/cobweb/Browser/Interpolation/CatmullRomSplineInterpolatorTemplate.js

  • Committer: Holger Seelig
  • Date: 2017-08-22 04:53:24 UTC
  • Revision ID: holger.seelig@yahoo.de-20170822045324-4of4xxgt79669gbt
Switched to npm.

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
/* -*- Mode: JavaScript; coding: utf-8; tab-width: 3; indent-tabs-mode: tab; c-basic-offset: 3 -*-
 
2
 *******************************************************************************
 
3
 *
 
4
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
 
5
 *
 
6
 * Copyright create3000, Scheffelstraße 31a, Leipzig, Germany 2011.
 
7
 *
 
8
 * All rights reserved. Holger Seelig <holger.seelig@yahoo.de>.
 
9
 *
 
10
 * The copyright notice above does not evidence any actual of intended
 
11
 * publication of such source code, and is an unpublished work by create3000.
 
12
 * This material contains CONFIDENTIAL INFORMATION that is the property of
 
13
 * create3000.
 
14
 *
 
15
 * No permission is granted to copy, distribute, or create derivative works from
 
16
 * the contents of this software, in whole or in part, without the prior written
 
17
 * permission of create3000.
 
18
 *
 
19
 * NON-MILITARY USE ONLY
 
20
 *
 
21
 * All create3000 software are effectively free software with a non-military use
 
22
 * restriction. It is free. Well commented source is provided. You may reuse the
 
23
 * source in any way you please with the exception anything that uses it must be
 
24
 * marked to indicate is contains 'non-military use only' components.
 
25
 *
 
26
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
 
27
 *
 
28
 * Copyright 2015, 2016 Holger Seelig <holger.seelig@yahoo.de>.
 
29
 *
 
30
 * This file is part of the Cobweb Project.
 
31
 *
 
32
 * Cobweb is free software: you can redistribute it and/or modify it under the
 
33
 * terms of the GNU General Public License version 3 only, as published by the
 
34
 * Free Software Foundation.
 
35
 *
 
36
 * Cobweb is distributed in the hope that it will be useful, but WITHOUT ANY
 
37
 * WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
 
38
 * A PARTICULAR PURPOSE. See the GNU General Public License version 3 for more
 
39
 * details (a copy is included in the LICENSE file that accompanied this code).
 
40
 *
 
41
 * You should have received a copy of the GNU General Public License version 3
 
42
 * along with Cobweb.  If not, see <http://www.gnu.org/licenses/gpl.html> for a
 
43
 * copy of the GPLv3 License.
 
44
 *
 
45
 * For Silvio, Joy and Adi.
 
46
 *
 
47
 ******************************************************************************/
 
48
 
 
49
 
 
50
define ([
 
51
        "jquery",
 
52
        "cobweb/Browser/Interpolation/CatmullRomSplineInterpolator"
 
53
],
 
54
function ($,
 
55
          CatmullRomSplineInterpolator)
 
56
{
 
57
"use strict";
 
58
 
 
59
        return function (Type)
 
60
        {
 
61
                var
 
62
                        c0 = new Type (0, 0, 0, 0),
 
63
                        c1 = new Type (0, 0, 0, 0),
 
64
                        c2 = new Type (0, 0, 0, 0),
 
65
                        c3 = new Type (0, 0, 0, 0);
 
66
        
 
67
                function CatmullRomSplineInterpolatorInstance ()
 
68
                {
 
69
                        this .T0 = [ ];
 
70
                        this .T1 = [ ];
 
71
                }
 
72
        
 
73
                CatmullRomSplineInterpolatorInstance .prototype = $.extend (Object .create (CatmullRomSplineInterpolator .prototype),
 
74
                {
 
75
                        constructor: CatmullRomSplineInterpolatorInstance,
 
76
                        create: function ()
 
77
                        {
 
78
                                return new Type (0, 0, 0, 0);
 
79
                        },
 
80
                        copy: function (value)
 
81
                        {
 
82
                                return value .copy ();
 
83
                        },
 
84
                        subtract: function (lhs, rhs)
 
85
                        {
 
86
                                return Type .subtract (lhs, rhs);
 
87
                        },
 
88
                        multiply: function (lhs, rhs)
 
89
                        {
 
90
                                return Type .multiply (lhs, rhs);
 
91
                        },
 
92
                        divide: function (lhs, rhs)
 
93
                        {
 
94
                                return Type .divide (lhs, rhs);
 
95
                        },
 
96
                        abs: function (value)
 
97
                        {
 
98
                                return value .abs ();
 
99
                        },
 
100
                        dot: function (SH, C0, C1, C2, C3)
 
101
                        {
 
102
                                c0 .assign (C0) .multiply (SH [0]);
 
103
                                c1 .assign (C1) .multiply (SH [1]);
 
104
                                c2 .assign (C2) .multiply (SH [2]);
 
105
                                c3 .assign (C3) .multiply (SH [3]);
 
106
        
 
107
                                return c0 .add (c1) .add (c2) .add (c3);
 
108
                        },
 
109
                });
 
110
        
 
111
                return CatmullRomSplineInterpolatorInstance;
 
112
        };
 
113
});
 
114
 
 
115