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
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
|
function Miles(element, params) {
// private attributes
var self = this;
// private instanceId
if (!Miles.instances)
Miles.instances = 0;
// public attributes
this.instanceId = Miles.instances++;
this.element = element;
this.connected = false;
this.imageIteration = 0;
// private attributes
var scxmlURL = "localhost:8080"
var reflectorIp = "localhost"
var email = "me@somehost.de";
var problemName = "some really hard problem";
// override with parameters if given
this.params = params;
if (params && params.scxmlURL) scxmlURL = params.scxmlURL;
if (params && params.reflectorIp) reflectorIp = params.reflectorIp;
if (params && params.email) email = params.email;
if (params && params.problemName) problemName = params.problemName;
// called when dojo loaded all requirements below
this.connect = function() {
self.xhr.post({
// The URL to request
url: "http://" + scxmlURL + "/miles/connect",
// handleAs:"text",
contentType: 'application/json',
postData: dojo.toJson({
reflectorIp: reflectorIp,
email: email,
problemName: problemName
}),
headers:{
"X-Requested-With": null,
},
error: function(err) {
console.log(err);
},
load: function(result) {
// we expect nothing in return
self.connected = true;
// trigger continuously loading the image
refreshImage();
}
});
}
// fetch a base64 encoded image and set it as the src attribute
var refreshImage = function() {
self.xhr.get({
// The URL to request
url: "http://" + scxmlURL + "/miles/image",
headers:{
"X-Requested-With":null
},
error: function(err) {
console.log(err);
if (self.connected) {
self.messageElem.innerHTML = self.imageIteration++;
refreshImage();
}
},
load: function(result) {
self.pictureElem.src = "data:image/jpeg;base64," + result;
if (self.connected) {
self.messageElem.innerHTML = self.imageIteration++;
refreshImage();
}
}
});
};
require(["dojo/dom-construct",
"dojo/_base/xhr",
"dojo/dom",
"dijit/form/DropDownButton",
"dijit/TooltipDialog",
"dojo/ready"],
function(domConst,
xhr,
dom,
DropDownButton,
TooltipDialog,
ready) {
ready(function() {
self.xhr = xhr;
// if we were passed an id, resolve to dom node
if (typeof(element) === 'string') {
element = dom.byId(element);
}
// dynamically assemble the DOM we need
element.appendChild(domConst.toDom('\
<table>\
<tr>\
<td valign="top">\
<div style="position: relative; padding: 0px">\
<img class="picture" src="test1.jpeg"></img>\
<div style="position: absolute; left: 10px; top: 10px">\
<table></tr>\
<td class="control" style="vertical-align: middle"></td>\
</tr></table>\
</div>\
</div>\
</td>\
</tr>\
<tr>\
<td valign="top">\
<div class="messages" style="position: relative; padding: 0px">\
</td>\
</tr>\
</table>\
'));
// from the above DOM, fetch some nodes to put dojo widgets in
self.pictureElem = dojo.query("img.picture", element)[0];
self.controlElem = dojo.query("td.control", element)[0];
self.messageElem = dojo.query("div.messages", element)[0];
// the control dropdown button
self.controlDropDownContent = domConst.toDom('<div />');
self.controlToolTip = new TooltipDialog({ content:self.controlDropDownContent, style:"max-height:320px"});
self.controlDropDown = new DropDownButton({ label: "Connect", dropDown: self.controlToolTip });
self.controlElem.appendChild(self.controlDropDown.domNode);
// many more control widgets to be instantiated here
// connect and start to fetch images from the server
self.connect();
})
});
}
|