Developer Documentation
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Modules Pages
vec4dWrapper.cc
1 /*===========================================================================*\
2 * *
3 * OpenFlipper *
4  * Copyright (c) 2001-2015, RWTH-Aachen University *
5  * Department of Computer Graphics and Multimedia *
6  * All rights reserved. *
7  * www.openflipper.org *
8  * *
9  *---------------------------------------------------------------------------*
10  * This file is part of OpenFlipper. *
11  *---------------------------------------------------------------------------*
12  * *
13  * Redistribution and use in source and binary forms, with or without *
14  * modification, are permitted provided that the following conditions *
15  * are met: *
16  * *
17  * 1. Redistributions of source code must retain the above copyright notice, *
18  * this list of conditions and the following disclaimer. *
19  * *
20  * 2. Redistributions in binary form must reproduce the above copyright *
21  * notice, this list of conditions and the following disclaimer in the *
22  * documentation and/or other materials provided with the distribution. *
23  * *
24  * 3. Neither the name of the copyright holder nor the names of its *
25  * contributors may be used to endorse or promote products derived from *
26  * this software without specific prior written permission. *
27  * *
28  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS *
29  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED *
30  * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A *
31  * PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER *
32  * OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, *
33  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, *
34  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR *
35  * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF *
36  * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING *
37  * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS *
38  * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. *
39 * *
40 \*===========================================================================*/
41 
42 /*===========================================================================*\
43 * *
44 * $Revision: 10745 $ *
45 * $LastChangedBy: moebius $ *
46 * $Date: 2011-01-26 10:23:50 +0100 (Mi, 26. Jan 2011) $ *
47 * *
48 \*===========================================================================*/
49 
50 
51 
52 //=============================================================================
53 //
54 // Wrapper for Vector ( Vec4d ) - IMPLEMENTATION
55 //
56 //=============================================================================
57 
58 
59 //== INCLUDES =================================================================
60 
61 #include "vec4dWrapper.hh"
62 
63 //== IMPLEMENTATION ==========================================================
64 
65 //=== Vector4 ( = Vec4d) =======================================================
66 
67 QScriptValue toScriptValueVector4(QScriptEngine *engine, const Vector4 &s)
68 {
69  QScriptValue obj = engine->newObject();
70  obj.setProperty("x", QScriptValue(engine, s[0]));
71  obj.setProperty("y", QScriptValue(engine, s[1]));
72  obj.setProperty("z", QScriptValue(engine, s[2]));
73  obj.setProperty("w", QScriptValue(engine, s[3]));
74  return obj;
75 }
76 
77 void fromScriptValueVector4(const QScriptValue &obj, Vector4 &s)
78 {
79  if (obj.isObject()) {
80  s[0] = obj.property("x").toNumber();
81  s[1] = obj.property("y").toNumber();
82  s[2] = obj.property("z").toNumber();
83  s[3] = obj.property("w").toNumber();
84  return;
85  }
86 
87  QString _from = obj.toString();
88  if (_from.startsWith ("Vector4 ("))
89  _from.remove (0, 8);
90  else if (_from.startsWith ("Vector4 : ( "))
91  _from.remove (0, 11);
92  if (_from.endsWith (")"))
93  _from.remove (_from.length () - 1, 1);
94 
95  QStringList sl = _from.split (',');
96 
97  float v[4];
98  bool ok = true;
99 
100  if (sl.length () == 4) {
101  for (int i = 0; i < 4 && ok; i++)
102  v[i] = sl[i].toFloat (&ok);
103 
104  if (ok)
105  for (int i = 0; i < 4; i++)
106  s[i] = v[i];
107  else {
108  for (int i = 0; i < 4; i++)
109  s[i] = 0;
110  std::cerr << "String to Vec4D conversion failed!" << std::endl;
111  }
112  }
113 }
114 
115 QScriptValue createVector4(QScriptContext *context, QScriptEngine *engine)
116 {
117  Vector4 s;
118 
119  QScriptValue callee = context->callee();
120 
121  // If arguments are given, use them for initialization otherwise
122  // initialize with 0
123  if (context->argumentCount() == 4) {
124  s[0] = context->argument(0).toNumber();
125  s[1] = context->argument(1).toNumber();
126  s[2] = context->argument(2).toNumber();
127  s[3] = context->argument(3).toNumber();
128  } else {
129  s[0] = 0.0;
130  s[1] = 0.0;
131  s[2] = 0.0;
132  s[3] = 0.0;
133  }
134 
135  return engine->toScriptValue(s);
136 }
137 
138 QScriptValue Vector4ToString(QScriptContext *context, QScriptEngine *engine)
139 {
140  QString result = "Vector4 : ( " +
141  context->thisObject().property("x").toString() + "," +
142  context->thisObject().property("y").toString() + "," +
143  context->thisObject().property("z").toString() + ","+
144  context->thisObject().property("w").toString() + " )";
145  return QScriptValue(engine, result);
146 }
147 
148 //=============================================================================
149