forked from jupyter-widgets/pythreejs
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathArrowHelper.js
86 lines (65 loc) · 2.81 KB
/
ArrowHelper.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
var ArrowHelperAutogen = require('./ArrowHelper.autogen').ArrowHelperModel;
var THREE = require('three');
var ArrowHelperModel = ArrowHelperAutogen.extend({
constructThreeObject: function() {
var headLength = this.get('headLength');
var headWidth = this.get('headWidth');
if (headLength === null) {
headLength = undefined;
}
if (headWidth === null) {
headWidth = undefined;
}
var result = new THREE.ArrowHelper(
this.convertVectorModelToThree(this.get('dir'), 'dir'),
this.convertVectorModelToThree(this.get('origin'), 'origin'),
this.convertFloatModelToThree(this.get('length'), 'length'),
this.convertColorModelToThree(this.get('color'), 'color'),
this.convertFloatModelToThree(headLength, 'headLength'),
this.convertFloatModelToThree(headWidth, 'headWidth')
);
return Promise.resolve(result);
},
createPropertiesArrays: function() {
ArrowHelperAutogen.prototype.createPropertiesArrays.call(this);
// Prevent from syncing these to object
delete this.property_converters['origin'];
// Map with setDirection
delete this.property_converters['dir'];
// Map with setColor
delete this.property_converters['color'];
// Map these to setLength instead
delete this.property_converters['length'];
delete this.property_converters['headLength'];
delete this.property_converters['headWidth'];
this.property_mappers['mapArrowHelper'] = 'mapArrowHelper';
},
mapArrowHelperModelToThree: function() {
var headLength = this.get('headLength');
var headWidth = this.get('headWidth');
if (headLength === null) {
headLength = undefined;
}
if (headWidth === null) {
headWidth = undefined;
}
this.obj.setDirection(this.convertVectorModelToThree(this.get('dir'), 'dir'));
this.obj.setColor(this.convertColorModelToThree(this.get('color'), 'color'));
this.obj.position.copy(this.convertVectorModelToThree(this.get('origin'), 'origin'));
this.obj.setLength(
this.convertFloatModelToThree(this.get('length'), 'length'),
this.convertFloatModelToThree(headLength, 'headLength'),
this.convertFloatModelToThree(headWidth, 'headWidth')
);
},
mapArrowHelperThreeToModel: function() {
this.set({
headLength: this.convertFloatThreeToModel(this.obj.cone.scale.y, 'headLength'),
headWidth: this.convertFloatThreeToModel(this.obj.cone.scale.x, 'headWidth'),
origin: this.convertVectorThreeToModel(this.obj.position, 'origin'),
});
}
});
module.exports = {
ArrowHelperModel: ArrowHelperModel,
};