source: ThirdParty/mpqc_open/src/lib/util/render/transform.cc@ 7516f6

Action_Thermostats Adding_MD_integration_tests Adding_StructOpt_integration_tests AutomationFragmentation_failures Candidate_v1.6.1 ChemicalSpaceEvaluator Enhanced_StructuralOptimization Enhanced_StructuralOptimization_continued Exclude_Hydrogens_annealWithBondGraph Fix_Verbose_Codepatterns ForceAnnealing_with_BondGraph ForceAnnealing_with_BondGraph_continued ForceAnnealing_with_BondGraph_continued_betteresults ForceAnnealing_with_BondGraph_contraction-expansion Gui_displays_atomic_force_velocity JobMarket_RobustOnKillsSegFaults JobMarket_StableWorkerPool PythonUI_with_named_parameters Recreated_GuiChecks StoppableMakroAction TremoloParser_IncreasedPrecision
Last change on this file since 7516f6 was 860145, checked in by Frederik Heber <heber@…>, 8 years ago

Merge commit '0b990dfaa8c6007a996d030163a25f7f5fc8a7e7' as 'ThirdParty/mpqc_open'

  • Property mode set to 100644
File size: 2.8 KB
Line 
1//
2// transform.cc
3//
4// Copyright (C) 1996 Limit Point Systems, Inc.
5//
6// Author: Curtis Janssen <cljanss@limitpt.com>
7// Maintainer: LPS
8//
9// This file is part of the SC Toolkit.
10//
11// The SC Toolkit is free software; you can redistribute it and/or modify
12// it under the terms of the GNU Library General Public License as published by
13// the Free Software Foundation; either version 2, or (at your option)
14// any later version.
15//
16// The SC Toolkit is distributed in the hope that it will be useful,
17// but WITHOUT ANY WARRANTY; without even the implied warranty of
18// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
19// GNU Library General Public License for more details.
20//
21// You should have received a copy of the GNU Library General Public License
22// along with the SC Toolkit; see the file COPYING.LIB. If not, write to
23// the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA.
24//
25// The U.S. Government is granted a limited license as per AL 91-7.
26//
27
28#include <stdlib.h>
29#include <util/render/transform.h>
30
31using namespace std;
32using namespace sc;
33
34static ClassDesc Transform_cd(
35 typeid(Transform),"Transform",1,"public DescribedClass",
36 0, create<Transform>, 0);
37
38Transform::Transform(const Ref<KeyVal>& keyval)
39{
40 transform_ = identity3D();
41 if (keyval->exists("translate")) {
42 if (keyval->count("translate") != 3) {
43 ExEnv::errn() << "Transform: error in translation" << endl;
44 abort();
45 }
46 translate(keyval->doublevalue("translate",0),
47 keyval->doublevalue("translate",1),
48 keyval->doublevalue("translate",2));
49 }
50 if (keyval->exists("rotate")) {
51 if (keyval->count("rotate:axis") != 3
52 || !keyval->exists("rotate:angle")) {
53 ExEnv::errn() << "Transform: error in rotation" << endl;
54 abort();
55 }
56 vec3 axis(keyval->doublevalue("rotate:axis",0),
57 keyval->doublevalue("rotate:axis",1),
58 keyval->doublevalue("rotate:axis",2));
59 rotate(axis, keyval->doublevalue("rotate:angle"));
60 }
61 if (keyval->exists("scale")) {
62 double scalefactor = keyval->doublevalue("scale");
63 scale(scalefactor);
64 }
65}
66
67Transform::~Transform()
68{
69}
70
71void
72Transform::translate(double x, double y, double z)
73{
74 vec3 r(x,y,z);
75 translate(r);
76}
77
78void
79Transform::translate(const vec3& r)
80{
81 transform_ = translation3D(r) * transform_;
82}
83
84void
85Transform::rotate(const vec3& axis, double angle)
86{
87 transform_ = rotation3D(axis, angle) * transform_;
88}
89
90void
91Transform::scale(double scalefactor)
92{
93 transform_ = scaling3D(vec3(scalefactor,scalefactor,scalefactor))
94 * transform_;
95 }
96
97void
98Transform::print(ostream& os) const
99{
100 os << "Transform" << endl;
101}
102
103/////////////////////////////////////////////////////////////////////////////
104
105// Local Variables:
106// mode: c++
107// c-file-style: "CLJ"
108// End:
Note: See TracBrowser for help on using the repository browser.