mirror of
https://github.com/xibyte/jsketcher
synced 2025-12-08 09:24:18 +01:00
fix modifying operation API
This commit is contained in:
parent
e30f53262a
commit
9aaebb7166
7 changed files with 276 additions and 58 deletions
|
|
@ -2,6 +2,27 @@
|
||||||
TCAD.UI = function(app) {
|
TCAD.UI = function(app) {
|
||||||
this.app = app;
|
this.app = app;
|
||||||
this.viewer = app.viewer;
|
this.viewer = app.viewer;
|
||||||
|
|
||||||
|
var box = new TCAD.toolkit.Box();
|
||||||
|
var propFolder = new TCAD.toolkit.Folder("Solid's Properties");
|
||||||
|
var cameraFolder = new TCAD.toolkit.Folder("Camera");
|
||||||
|
var objectsFolder = new TCAD.toolkit.Folder("Objects");
|
||||||
|
var modificationsFolder = new TCAD.toolkit.Folder("Modifications");
|
||||||
|
TCAD.toolkit.add(box, propFolder);
|
||||||
|
TCAD.toolkit.add(propFolder, new TCAD.toolkit.Button("Extrude"));
|
||||||
|
TCAD.toolkit.add(propFolder, new TCAD.toolkit.Button("Cut"));
|
||||||
|
TCAD.toolkit.add(propFolder, new TCAD.toolkit.Button("Edit"));
|
||||||
|
TCAD.toolkit.add(propFolder, new TCAD.toolkit.Button("Refresh Sketches"));
|
||||||
|
TCAD.toolkit.add(propFolder, new TCAD.toolkit.Text("Message"));
|
||||||
|
TCAD.toolkit.add(box, cameraFolder);
|
||||||
|
TCAD.toolkit.add(cameraFolder, new TCAD.toolkit.Number("x"));
|
||||||
|
TCAD.toolkit.add(cameraFolder, new TCAD.toolkit.Number("y"));
|
||||||
|
TCAD.toolkit.add(cameraFolder, new TCAD.toolkit.Number("z"));
|
||||||
|
TCAD.toolkit.add(box, objectsFolder);
|
||||||
|
TCAD.toolkit.add(box, modificationsFolder);
|
||||||
|
this.modificationsTreeComp = new TCAD.toolkit.Tree();
|
||||||
|
TCAD.toolkit.add(cameraFolder, this.modificationsTreeComp);
|
||||||
|
|
||||||
this.dat = new dat.GUI();
|
this.dat = new dat.GUI();
|
||||||
var ui = this;
|
var ui = this;
|
||||||
var gui = this.dat;
|
var gui = this.dat;
|
||||||
|
|
|
||||||
|
|
@ -156,10 +156,15 @@ TCAD.App.prototype.extrude = function() {
|
||||||
}
|
}
|
||||||
var polyFace = this.viewer.selectionMgr.selection[0];
|
var polyFace = this.viewer.selectionMgr.selection[0];
|
||||||
var height = prompt("Height", "50");
|
var height = prompt("Height", "50");
|
||||||
|
if (!height) return;
|
||||||
|
|
||||||
var app = this;
|
var app = this;
|
||||||
this.craft.modify(polyFace.solid, function() {
|
var solids = [polyFace.solid];
|
||||||
return TCAD.craft.extrude(app, polyFace, polyFace.solid.polyFaces, height);
|
this.craft.modify({
|
||||||
|
type: 'PAD',
|
||||||
|
solids : solids,
|
||||||
|
face : polyFace,
|
||||||
|
height : height
|
||||||
});
|
});
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
@ -170,12 +175,16 @@ TCAD.App.prototype.cut = function() {
|
||||||
}
|
}
|
||||||
var polyFace = this.viewer.selectionMgr.selection[0];
|
var polyFace = this.viewer.selectionMgr.selection[0];
|
||||||
var depth = prompt("Depth", "50");
|
var depth = prompt("Depth", "50");
|
||||||
|
if (!depth) return;
|
||||||
|
|
||||||
var app = this;
|
var app = this;
|
||||||
this.craft.modify(polyFace.solid, function() {
|
var solids = [polyFace.solid];
|
||||||
return TCAD.craft.cut(app, polyFace, polyFace.solid.polyFaces, depth);
|
this.craft.modify({
|
||||||
|
type: 'CUT',
|
||||||
|
solids : solids,
|
||||||
|
face : polyFace,
|
||||||
|
depth : depth
|
||||||
});
|
});
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
TCAD.App.prototype.refreshSketches = function() {
|
TCAD.App.prototype.refreshSketches = function() {
|
||||||
|
|
|
||||||
|
|
@ -107,6 +107,12 @@ TCAD.utils.fixCCW = function(path, normal) {
|
||||||
return path;
|
return path;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
TCAD.utils.addAll = function(arr, arrToAdd) {
|
||||||
|
for (var i = 0; i < arrToAdd.length; i++) {
|
||||||
|
arr.push(arrToAdd[i]);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
TCAD.TOLERANCE = 1E-6;
|
TCAD.TOLERANCE = 1E-6;
|
||||||
|
|
||||||
TCAD.utils.areEqual = function(v1, v2, tolerance) {
|
TCAD.utils.areEqual = function(v1, v2, tolerance) {
|
||||||
|
|
@ -320,7 +326,7 @@ TCAD.geom.extrude = function(source, target) {
|
||||||
return poly;
|
return poly;
|
||||||
};
|
};
|
||||||
|
|
||||||
TCAD.geom.FACE_COUNTER = 0;
|
TCAD.geom.SOLID_COUNTER = 0;
|
||||||
|
|
||||||
/** @constructor */
|
/** @constructor */
|
||||||
TCAD.Solid = function(polygons, material) {
|
TCAD.Solid = function(polygons, material) {
|
||||||
|
|
@ -329,6 +335,9 @@ TCAD.Solid = function(polygons, material) {
|
||||||
|
|
||||||
this.meshObject = new THREE.Mesh(this, material);
|
this.meshObject = new THREE.Mesh(this, material);
|
||||||
|
|
||||||
|
this.id = TCAD.geom.SOLID_COUNTER ++;
|
||||||
|
this.faceCounter = 0;
|
||||||
|
|
||||||
this.polyFaces = [];
|
this.polyFaces = [];
|
||||||
var scope = this;
|
var scope = this;
|
||||||
function pushVertices(vertices) {
|
function pushVertices(vertices) {
|
||||||
|
|
@ -423,7 +432,7 @@ TCAD.SketchFace = function(solid, poly) {
|
||||||
var proto = poly.__face;
|
var proto = poly.__face;
|
||||||
poly.__face = this;
|
poly.__face = this;
|
||||||
if (proto === undefined) {
|
if (proto === undefined) {
|
||||||
this.id = TCAD.geom.FACE_COUNTER++;
|
this.id = solid.id + ":" + (solid.faceCounter++);
|
||||||
this.sketchGeom = null;
|
this.sketchGeom = null;
|
||||||
} else {
|
} else {
|
||||||
this.id = proto.id;
|
this.id = proto.id;
|
||||||
|
|
|
||||||
62
web/app/ui/toolkit.js
Normal file
62
web/app/ui/toolkit.js
Normal file
|
|
@ -0,0 +1,62 @@
|
||||||
|
TCAD.toolkit = {};
|
||||||
|
|
||||||
|
TCAD.toolkit.add = function(parent, child) {
|
||||||
|
parent.content.append(child.root);
|
||||||
|
};
|
||||||
|
|
||||||
|
TCAD.toolkit.Box = function() {
|
||||||
|
this.root = this.content = $('<div class="tc-box" />');
|
||||||
|
this.root.addClass('tc-box');
|
||||||
|
this.root.appendTo('body');
|
||||||
|
};
|
||||||
|
|
||||||
|
TCAD.toolkit.Folder = function(title) {
|
||||||
|
this.root = $('<div/>', {class: 'tc-folder'});
|
||||||
|
this.content = $('<div/>', {class: 'tc-scroll'});
|
||||||
|
this.root.append($('<div/>', {text: title, class: 'tc-row tc-title'}));
|
||||||
|
this.root.append(this.content);
|
||||||
|
};
|
||||||
|
|
||||||
|
TCAD.toolkit.Button = function(title) {
|
||||||
|
this.root = $('<div/>',
|
||||||
|
{class: 'tc-row tc-ctrl tc-ctrl-btn', text: title});
|
||||||
|
};
|
||||||
|
|
||||||
|
TCAD.toolkit.propLayout = function(root, name, valueEl) {
|
||||||
|
root.append($('<span/>', {class: 'tc-prop-name', text: name}))
|
||||||
|
.append($('<div/>', {class: 'tc-prop-value'})
|
||||||
|
.append(valueEl));
|
||||||
|
};
|
||||||
|
|
||||||
|
TCAD.toolkit.Number = function(name) {
|
||||||
|
this.root = $('<div/>', {class: 'tc-row tc-ctrl tc-ctrl-number'});
|
||||||
|
TCAD.toolkit.propLayout(this.root, name, $('<input type="text"/>'))
|
||||||
|
};
|
||||||
|
|
||||||
|
TCAD.toolkit.Text = function(name) {
|
||||||
|
this.root = $('<div/>', {class: 'tc-row tc-ctrl tc-ctrl-text'});
|
||||||
|
TCAD.toolkit.propLayout(this.root, name, $('<input type="text" />'))
|
||||||
|
};
|
||||||
|
|
||||||
|
TCAD.toolkit.Tree = function() {
|
||||||
|
this.root = $('<div/>', {class: 'tc-tree'});
|
||||||
|
};
|
||||||
|
|
||||||
|
TCAD.toolkit.Tree.prototype.set = function(data) {
|
||||||
|
this.root.empty();
|
||||||
|
this._fill(this.root, data.children);
|
||||||
|
};
|
||||||
|
|
||||||
|
TCAD.toolkit.Tree.prototype._fill = function(parent, data) {
|
||||||
|
parent.append($('<div/>', {text : data.name}));
|
||||||
|
if (data.children !== undefined && data.children.length !== 0) {
|
||||||
|
var ul = $('<ul>');
|
||||||
|
parent.append(ul);
|
||||||
|
for (var i = 0; i < data.children.length; i++) {
|
||||||
|
var li = $('<li/>');
|
||||||
|
ul.append(li);
|
||||||
|
var child = data.children[i];
|
||||||
|
this._fill(li, child);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
@ -72,38 +72,6 @@ TCAD.workbench.serializeSolid = function(solid) {
|
||||||
return data;
|
return data;
|
||||||
};
|
};
|
||||||
|
|
||||||
TCAD.workbench.applyHistory = function(history) {
|
|
||||||
|
|
||||||
for (var hi = 0; hi < history.length; ++hi) {
|
|
||||||
var mod = history[hi];
|
|
||||||
switch (mod.operation) {
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
TCAD.workbench.Cut = function() {
|
|
||||||
|
|
||||||
this.depth = null;
|
|
||||||
|
|
||||||
this.load = function(data) {
|
|
||||||
this.depth = data.depth;
|
|
||||||
};
|
|
||||||
|
|
||||||
this.save = function() {
|
|
||||||
return {
|
|
||||||
depth : this.depth
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
this.apply = function(app, face, faces) {
|
|
||||||
TCAD.craft.cut(app, face, faces, this.depth);
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
TCAD.workbench.Cut.prototype.TYPE = 'CUT';
|
|
||||||
|
|
||||||
|
|
||||||
TCAD.craft = {};
|
TCAD.craft = {};
|
||||||
|
|
||||||
TCAD.craft.getSketchedPolygons3D = function(app, face) {
|
TCAD.craft.getSketchedPolygons3D = function(app, face) {
|
||||||
|
|
@ -142,16 +110,18 @@ TCAD.craft.getSketchedPolygons3D = function(app, face) {
|
||||||
return sketchedPolygons;
|
return sketchedPolygons;
|
||||||
};
|
};
|
||||||
|
|
||||||
TCAD.craft.extrude = function(app, face, faces, height) {
|
TCAD.craft.extrude = function(app, request) {
|
||||||
|
var face = request.face;
|
||||||
var sketchedPolygons = TCAD.craft.getSketchedPolygons3D(app, face);
|
var sketchedPolygons = TCAD.craft.getSketchedPolygons3D(app, face);
|
||||||
if (sketchedPolygons == null) return null;
|
if (sketchedPolygons == null) return null;
|
||||||
|
|
||||||
var newSolidFaces = [];
|
var faces = TCAD.craft.collectFaces(request.solids);
|
||||||
|
|
||||||
var normal = face.polygon.normal;
|
var normal = face.polygon.normal;
|
||||||
|
|
||||||
var toMeldWith = [];
|
var toMeldWith = [];
|
||||||
for (var i = 0; i < sketchedPolygons.length; i++) {
|
for (var i = 0; i < sketchedPolygons.length; i++) {
|
||||||
var extruded = TCAD.geom.extrude(sketchedPolygons[i], normal.multiply(height));
|
var extruded = TCAD.geom.extrude(sketchedPolygons[i], normal.multiply(request.height));
|
||||||
toMeldWith = toMeldWith.concat(TCAD.craft._makeFromPolygons(extruded));
|
toMeldWith = toMeldWith.concat(TCAD.craft._makeFromPolygons(extruded));
|
||||||
}
|
}
|
||||||
var work = TCAD.craft._makeFromPolygons(faces.map(function(f){ return f.polygon }));
|
var work = TCAD.craft._makeFromPolygons(faces.map(function(f){ return f.polygon }));
|
||||||
|
|
@ -218,7 +188,7 @@ TCAD.craft._mergeCSGPolygons = function (__cgsPolygons, allPoints) {
|
||||||
vertices: cp.vertices.map(function (cv) {
|
vertices: cp.vertices.map(function (cv) {
|
||||||
return vec(cv.pos)
|
return vec(cv.pos)
|
||||||
}),
|
}),
|
||||||
csgInfo : cp.shared.__tcad,
|
shared : cp.shared.__tcad,
|
||||||
normal: vec(cp.plane.normal),
|
normal: vec(cp.plane.normal),
|
||||||
w: cp.plane.w
|
w: cp.plane.w
|
||||||
};
|
};
|
||||||
|
|
@ -450,7 +420,7 @@ TCAD.craft._mergeCSGPolygons = function (__cgsPolygons, allPoints) {
|
||||||
vertices : path,
|
vertices : path,
|
||||||
normal : csgData.normal,
|
normal : csgData.normal,
|
||||||
w : csgData.w,
|
w : csgData.w,
|
||||||
csgInfo : csgData.csgInfo
|
shared : csgData.shared
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
@ -526,7 +496,10 @@ TCAD.craft._makeFromPolygons = function(polygons) {
|
||||||
}
|
}
|
||||||
var pid = poly.id;
|
var pid = poly.id;
|
||||||
var shared = new CSG.Polygon.Shared([pid, pid, pid, pid]);
|
var shared = new CSG.Polygon.Shared([pid, pid, pid, pid]);
|
||||||
shared.__tcad = poly.csgInfo;
|
shared.__tcad = {
|
||||||
|
csgInfo : poly.csgInfo,
|
||||||
|
face : poly.__face
|
||||||
|
};
|
||||||
var refs = poly.triangulate();
|
var refs = poly.triangulate();
|
||||||
for ( var i = 0; i < refs.length; ++ i ) {
|
for ( var i = 0; i < refs.length; ++ i ) {
|
||||||
var a = refs[i][0] + off;
|
var a = refs[i][0] + off;
|
||||||
|
|
@ -628,7 +601,7 @@ TCAD.craft.reconstruct = function (cut) {
|
||||||
return {
|
return {
|
||||||
vertices : path.vertices.map(function(v) {return tr.apply(v);}),
|
vertices : path.vertices.map(function(v) {return tr.apply(v);}),
|
||||||
normal : path.normal,
|
normal : path.normal,
|
||||||
csgInfo : path.csgInfo
|
shared : path.shared
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
@ -715,7 +688,10 @@ TCAD.craft.reconstruct = function (cut) {
|
||||||
var p = new TCAD.Polygon(path.vertices, path.holes.map(function (path) {
|
var p = new TCAD.Polygon(path.vertices, path.holes.map(function (path) {
|
||||||
return path.vertices
|
return path.vertices
|
||||||
}), path.normal);
|
}), path.normal);
|
||||||
p.csgInfo = path.csgInfo;
|
if (path.shared !== undefined) {
|
||||||
|
p.csgInfo = path.shared.csgInfo;
|
||||||
|
p.__face = path.shared.face;
|
||||||
|
}
|
||||||
return p;
|
return p;
|
||||||
})
|
})
|
||||||
);
|
);
|
||||||
|
|
@ -724,17 +700,25 @@ TCAD.craft.reconstruct = function (cut) {
|
||||||
return result;
|
return result;
|
||||||
};
|
};
|
||||||
|
|
||||||
TCAD.craft.cut = function(app, face, faces, depth) {
|
TCAD.craft.collectFaces = function(solids) {
|
||||||
|
var faces = [];
|
||||||
|
for (var i = 0; i < solids.length; i++) {
|
||||||
|
TCAD.utils.addAll(faces, solids[i].polyFaces);
|
||||||
|
}
|
||||||
|
return faces;
|
||||||
|
};
|
||||||
|
|
||||||
|
TCAD.craft.cut = function(app, request) {
|
||||||
|
var face = request.face;
|
||||||
var sketchedPolygons = TCAD.craft.getSketchedPolygons3D(app, face);
|
var sketchedPolygons = TCAD.craft.getSketchedPolygons3D(app, face);
|
||||||
if (sketchedPolygons == null) return null;
|
if (sketchedPolygons == null) return null;
|
||||||
|
|
||||||
var newSolidFaces = [];
|
var faces = TCAD.craft.collectFaces(request.solids);
|
||||||
var normal = face.polygon.normal;
|
var normal = face.polygon.normal;
|
||||||
|
|
||||||
var cutter = [];
|
var cutter = [];
|
||||||
for (var i = 0; i < sketchedPolygons.length; i++) {
|
for (var i = 0; i < sketchedPolygons.length; i++) {
|
||||||
var extruded = TCAD.geom.extrude(sketchedPolygons[i], normal.multiply( - depth));
|
var extruded = TCAD.geom.extrude(sketchedPolygons[i], normal.multiply( - request.depth));
|
||||||
cutter = cutter.concat(TCAD.craft._makeFromPolygons(extruded));
|
cutter = cutter.concat(TCAD.craft._makeFromPolygons(extruded));
|
||||||
}
|
}
|
||||||
var work = TCAD.craft._makeFromPolygons(faces.map(function(f){ return f.polygon }));
|
var work = TCAD.craft._makeFromPolygons(faces.map(function(f){ return f.polygon }));
|
||||||
|
|
@ -754,15 +738,45 @@ TCAD.Craft = function(app) {
|
||||||
TCAD.Craft.prototype.current = function() {
|
TCAD.Craft.prototype.current = function() {
|
||||||
return this.history[this.history.length - 1];
|
return this.history[this.history.length - 1];
|
||||||
};
|
};
|
||||||
|
|
||||||
TCAD.Craft.prototype.modify = function(solid, modification) {
|
|
||||||
var faces = modification();
|
|
||||||
if (faces == null) return;
|
|
||||||
this.app.viewer.scene.remove( solid.meshObject );
|
|
||||||
this.app.viewer.scene.add(TCAD.utils.createSolidMesh(faces));
|
|
||||||
|
|
||||||
|
TCAD.craft.detach = function(request) {
|
||||||
|
var detachedConfig = {};
|
||||||
|
for (var prop in request) {
|
||||||
|
if (request.hasOwnProperty(prop)) {
|
||||||
|
var value = request[prop];
|
||||||
|
if (typeof(value) === 'object' && value.id !== undefined) {
|
||||||
|
detachedConfig[prop] = value.id;
|
||||||
|
} else {
|
||||||
|
detachedConfig[prop] = value;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return detachedConfig
|
||||||
|
};
|
||||||
|
|
||||||
|
TCAD.Craft.prototype.modify = function(request) {
|
||||||
|
|
||||||
|
var op = TCAD.craft.OPS[request.type];
|
||||||
|
if (!op) return;
|
||||||
|
|
||||||
|
var detachedRequest = TCAD.craft.detach(request);
|
||||||
|
var newFaces = op(this.app, request);
|
||||||
|
|
||||||
|
if (newFaces == null) return;
|
||||||
|
for (var i = 0; i < request.solids.length; i++) {
|
||||||
|
var solid = request.solids[i];
|
||||||
|
this.app.viewer.scene.remove( solid.meshObject );
|
||||||
|
}
|
||||||
|
this.app.viewer.scene.add(TCAD.utils.createSolidMesh(newFaces));
|
||||||
|
this.history.push(detachedRequest);
|
||||||
|
this.app.bus.notify('operation');
|
||||||
//REMOVE IT
|
//REMOVE IT
|
||||||
this.app._refreshSketches();
|
this.app._refreshSketches();
|
||||||
|
|
||||||
this.app.viewer.render();
|
this.app.viewer.render();
|
||||||
};
|
};
|
||||||
|
|
||||||
|
TCAD.craft.OPS = {
|
||||||
|
CUT : TCAD.craft.cut,
|
||||||
|
PAD : TCAD.craft.extrude
|
||||||
|
};
|
||||||
|
|
|
||||||
99
web/css/toolkit.css
Normal file
99
web/css/toolkit.css
Normal file
|
|
@ -0,0 +1,99 @@
|
||||||
|
|
||||||
|
.tc-box {
|
||||||
|
position: absolute;
|
||||||
|
margin-left: 0; margin-top: 0;
|
||||||
|
top: 0; left: 0;
|
||||||
|
width : 250px; height: 300px;
|
||||||
|
background-color: #000;
|
||||||
|
}
|
||||||
|
|
||||||
|
.tc-row {
|
||||||
|
height: 27px;
|
||||||
|
line-height: 27px;
|
||||||
|
overflow: hidden;
|
||||||
|
padding: 0 4px 0 5px;
|
||||||
|
border-bottom: 1px solid #2c2c2c;
|
||||||
|
}
|
||||||
|
|
||||||
|
.tc-title {
|
||||||
|
padding-left: 16px;
|
||||||
|
background: black url() 6px 10px no-repeat;
|
||||||
|
cursor: pointer;
|
||||||
|
}
|
||||||
|
|
||||||
|
.tc-folder {
|
||||||
|
color: #eee;
|
||||||
|
font: 11px 'Lucida Grande', sans-serif;
|
||||||
|
background-color: #1a1a1a;
|
||||||
|
}
|
||||||
|
|
||||||
|
.tc-ctrl {
|
||||||
|
border-left: 3px solid #e61d5f;
|
||||||
|
}
|
||||||
|
|
||||||
|
.tc-ctrl-btn {
|
||||||
|
border-left: 3px solid #e61d5f;
|
||||||
|
cursor: pointer;
|
||||||
|
}
|
||||||
|
|
||||||
|
.tc-ctrl-btn:hover {
|
||||||
|
background-color: #000;
|
||||||
|
}
|
||||||
|
|
||||||
|
.tc-prop-name {
|
||||||
|
cursor: default;
|
||||||
|
float: left;
|
||||||
|
clear: left;
|
||||||
|
width: 40%;
|
||||||
|
overflow: hidden;
|
||||||
|
text-overflow: ellipsis;
|
||||||
|
}
|
||||||
|
|
||||||
|
.tc-prop-value {
|
||||||
|
float: left;
|
||||||
|
width: 60%;
|
||||||
|
}
|
||||||
|
|
||||||
|
.tc-ctrl input[type=text] {
|
||||||
|
color: #2fa1d6;
|
||||||
|
background: #303030;
|
||||||
|
outline: none;
|
||||||
|
border: 0;
|
||||||
|
margin-top: 4px;
|
||||||
|
padding: 3px;
|
||||||
|
width: 100%;
|
||||||
|
float: right;
|
||||||
|
}
|
||||||
|
|
||||||
|
.tc-ctrl-text input[type=text] {
|
||||||
|
color:#1ed36f;
|
||||||
|
}
|
||||||
|
|
||||||
|
.tc-ctrl input[type=text]:focus {
|
||||||
|
color: #eee;
|
||||||
|
}
|
||||||
|
|
||||||
|
.tc-scroll {
|
||||||
|
overflow-y: auto;
|
||||||
|
overflow-x: hidden;
|
||||||
|
}
|
||||||
|
|
||||||
|
.tc-scroll::-webkit-scrollbar {
|
||||||
|
width: 2px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.tc-scroll::-webkit-scrollbar-track {
|
||||||
|
background:#eee;
|
||||||
|
border: thin solid lightgray;
|
||||||
|
box-shadow: 0px 0px 3px #dfdfdf inset;
|
||||||
|
border-radius:10px;
|
||||||
|
}
|
||||||
|
.tc-scroll::-webkit-scrollbar-thumb {
|
||||||
|
background:#999;
|
||||||
|
border: thin solid gray;
|
||||||
|
border-radius:10px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.tc-scroll::-webkit-scrollbar-thumb:hover {
|
||||||
|
background:#7d7d7d;
|
||||||
|
}
|
||||||
|
|
@ -8,7 +8,10 @@
|
||||||
overflow: hidden;
|
overflow: hidden;
|
||||||
}
|
}
|
||||||
</style>
|
</style>
|
||||||
|
<link rel="stylesheet" href="css/toolkit.css">
|
||||||
|
|
||||||
|
|
||||||
|
<script src="lib/jquery-2.1.0.min.js"></script>
|
||||||
<script src="lib/three/three.js"></script>
|
<script src="lib/three/three.js"></script>
|
||||||
<script src="lib/three/TrackballControls.js"></script>
|
<script src="lib/three/TrackballControls.js"></script>
|
||||||
<script src="lib/three/OrbitControls.js"></script>
|
<script src="lib/three/OrbitControls.js"></script>
|
||||||
|
|
@ -24,6 +27,7 @@
|
||||||
<script src="app/workbench.js"></script>
|
<script src="app/workbench.js"></script>
|
||||||
<script src="app/math/graph.js"></script>
|
<script src="app/math/graph.js"></script>
|
||||||
<script src="app/3d/hashmap.js"></script>
|
<script src="app/3d/hashmap.js"></script>
|
||||||
|
<script src="app/ui/toolkit.js"></script>
|
||||||
|
|
||||||
<script>window.onload = function() {
|
<script>window.onload = function() {
|
||||||
window._TCAD_APP = new TCAD.App();
|
window._TCAD_APP = new TCAD.App();
|
||||||
|
|
@ -32,4 +36,4 @@
|
||||||
<body>
|
<body>
|
||||||
|
|
||||||
</body>
|
</body>
|
||||||
</html>
|
</html>
|
||||||
|
|
|
||||||
Loading…
Reference in a new issue