mirror of
https://github.com/overte-org/overte.git
synced 2025-04-26 05:36:40 +02:00
159 lines
4.9 KiB
JavaScript
159 lines
4.9 KiB
JavaScript
//
|
|
// overlaysExample.js
|
|
// hifi
|
|
//
|
|
// Created by Brad Hefta-Gaub on 2/14/14.
|
|
// Copyright (c) 2014 HighFidelity, Inc. All rights reserved.
|
|
//
|
|
// This is an example script that demonstrates use of the Overlays class
|
|
//
|
|
//
|
|
|
|
var swatchColors = new Array();
|
|
swatchColors[0] = { red: 255, green: 0, blue: 0};
|
|
swatchColors[1] = { red: 0, green: 255, blue: 0};
|
|
swatchColors[2] = { red: 0, green: 0, blue: 255};
|
|
swatchColors[3] = { red: 255, green: 255, blue: 0};
|
|
swatchColors[4] = { red: 255, green: 0, blue: 255};
|
|
swatchColors[5] = { red: 0, green: 255, blue: 255};
|
|
swatchColors[6] = { red: 128, green: 128, blue: 128};
|
|
swatchColors[7] = { red: 128, green: 0, blue: 0};
|
|
swatchColors[8] = { red: 0, green: 240, blue: 240};
|
|
|
|
var swatches = new Array();
|
|
var numberOfSwatches = 9;
|
|
var swatchesX = 100;
|
|
var swatchesY = 200;
|
|
var selectedSwatch = 0;
|
|
for (s = 0; s < numberOfSwatches; s++) {
|
|
var imageFromX = 12 + (s * 27);
|
|
var imageFromY = 0;
|
|
if (s == selectedSwatch) {
|
|
imageFromY = 55;
|
|
}
|
|
|
|
swatches[s] = Overlays.addOverlay({
|
|
x: 100 + (30 * s),
|
|
y: 200,
|
|
width: 31,
|
|
height: 54,
|
|
subImage: { x: imageFromX, y: imageFromY, width: 30, height: 54 },
|
|
imageURL: "http://highfidelity-public.s3-us-west-1.amazonaws.com/images/testing-swatches.svg",
|
|
backgroundColor: swatchColors[s],
|
|
alpha: 1
|
|
});
|
|
}
|
|
|
|
var toolA = Overlays.addOverlay({
|
|
x: 100,
|
|
y: 100,
|
|
width: 62,
|
|
height: 40,
|
|
subImage: { x: 0, y: 0, width: 62, height: 40 },
|
|
imageURL: "https://s3-us-west-1.amazonaws.com/highfidelity-public/images/hifi-interface-tools.svg",
|
|
backgroundColor: { red: 255, green: 255, blue: 255},
|
|
alpha: 0.7,
|
|
visible: false
|
|
});
|
|
|
|
var slider = Overlays.addOverlay({
|
|
// alternate form of expressing bounds
|
|
bounds: { x: 100, y: 300, width: 158, height: 35},
|
|
imageURL: "https://s3-us-west-1.amazonaws.com/highfidelity-public/images/slider.png",
|
|
backgroundColor: { red: 255, green: 255, blue: 255},
|
|
alpha: 1
|
|
});
|
|
|
|
var minThumbX = 130;
|
|
var maxThumbX = minThumbX + 65;
|
|
var thumbX = (minThumbX + maxThumbX) / 2;
|
|
var thumb = Overlays.addOverlay({
|
|
x: thumbX,
|
|
y: 309,
|
|
width: 18,
|
|
height: 17,
|
|
imageURL: "https://s3-us-west-1.amazonaws.com/highfidelity-public/images/thumb.png",
|
|
backgroundColor: { red: 255, green: 255, blue: 255},
|
|
alpha: 1
|
|
});
|
|
|
|
|
|
// 270x 109
|
|
// 109... 109/2 = 54,1,54
|
|
// 270... 39 to 66 = 28 x 9 swatches with
|
|
// unselected:
|
|
// 38,0,28,54
|
|
// selected:
|
|
// 38,55,28,54
|
|
//http://highfidelity-public.s3-us-west-1.amazonaws.com/images/swatches.svg
|
|
|
|
// 123456789*123456789*123456789*
|
|
// 0123456789*123456789*123456789*
|
|
|
|
function scriptEnding() {
|
|
Overlays.deleteOverlay(toolA);
|
|
for (s = 0; s < numberOfSwatches; s++) {
|
|
Overlays.deleteOverlay(swatches[s]);
|
|
}
|
|
Overlays.deleteOverlay(thumb);
|
|
Overlays.deleteOverlay(slider);
|
|
}
|
|
Script.scriptEnding.connect(scriptEnding);
|
|
|
|
|
|
var toolAVisible = false;
|
|
var count = 0;
|
|
function update() {
|
|
count++;
|
|
if (count % 60 == 0) {
|
|
if (toolAVisible) {
|
|
toolAVisible = false;
|
|
} else {
|
|
toolAVisible = true;
|
|
}
|
|
Overlays.editOverlay(toolA, { visible: toolAVisible } );
|
|
}
|
|
}
|
|
Script.willSendVisualDataCallback.connect(update);
|
|
|
|
|
|
var movingSlider = false;
|
|
var thumbClickOffsetX = 0;
|
|
function mouseMoveEvent(event) {
|
|
if (movingSlider) {
|
|
newThumbX = event.x - thumbClickOffsetX;
|
|
if (newThumbX < minThumbX) {
|
|
newThumbX = minThumbX;
|
|
}
|
|
if (newThumbX > maxThumbX) {
|
|
newThumbX = maxThumbX;
|
|
}
|
|
Overlays.editOverlay(thumb, { x: newThumbX } );
|
|
}
|
|
}
|
|
function mousePressEvent(event) {
|
|
var clickedOverlay = Overlays.getOverlayAtPoint({x: event.x, y: event.y});
|
|
if (clickedOverlay == thumb) {
|
|
movingSlider = true;
|
|
thumbClickOffsetX = event.x - thumbX;
|
|
} else {
|
|
for (s = 0; s < numberOfSwatches; s++) {
|
|
if (clickedOverlay == swatches[s]) {
|
|
Overlays.editOverlay(swatches[selectedSwatch], { subImage: { y: 0 } } );
|
|
Overlays.editOverlay(swatches[s], { subImage: { y: 55 } } );
|
|
selectedSwatch = s;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
function mouseReleaseEvent(event) {
|
|
if (movingSlider) {
|
|
movingSlider = false;
|
|
}
|
|
}
|
|
|
|
Controller.mouseMoveEvent.connect(mouseMoveEvent);
|
|
Controller.mousePressEvent.connect(mousePressEvent);
|
|
Controller.mouseReleaseEvent.connect(mouseReleaseEvent);
|
|
|