SymbolMorph.prototype.names.push('largeStage'); SymbolMorph.prototype.names.push('zoomToFit'); /* SymbolMorph.prototype.originalSymbolCanvasColored = SymbolMorph.prototype.symbolCanvasColored; SymbolMorph.prototype.symbolCanvasColored = function (aColor) { if (this.name == 'largeStage') { return this.drawSymbolLargeStage(newCanvas(new Point(this.symbolWidth(), this.size)), aColor); } else if (this.name == 'zoomToFit') { return this.drawSymbolZoomToFit(newCanvas(new Point(this.symbolWidth(), this.size)), aColor); } else if (this.name == 'turtle') { return this.drawSymbolTurtle(newCanvas(new Point(this.symbolWidth(), this.size)), aColor); } else { return this.originalSymbolCanvasColored(aColor) } } */ SymbolMorph.prototype.originalSymbolWidth = SymbolMorph.prototype.symbolWidth; SymbolMorph.prototype.symbolWidth = function () { switch (this.name) { // case 'gears': // case 'file': // return this.originalSymbolWidth() * 0.8; case 'turtle': return this.originalSymbolWidth() * 0.8; default: return this.originalSymbolWidth(); } }; SymbolMorph.prototype.origRenderShape = SymbolMorph.prototype.renderShape; SymbolMorph.prototype.renderShape = function (ctx, aColor) { switch (this.name) { case 'zoomToFit': this.renderSymbolZoomToFit(ctx, aColor); break; default: this.origRenderShape(ctx, aColor); } } SymbolMorph.prototype.renderSymbolZoomToFit = function(ctx, color) { var c = this.symbolWidth() / 2, h = this.size, w = this.symbolWidth() / 5; ctx.fillStyle = color.toString(); ctx.beginPath(); ctx.moveTo(0, 0); ctx.lineTo(w, 0); ctx.stroke(); ctx.moveTo(0, 0); ctx.lineTo(0, w); ctx.stroke(); ctx.moveTo(0, h); ctx.lineTo(0, h - w); ctx.stroke(); ctx.moveTo(0, h); ctx.lineTo(w, h); ctx.stroke(); ctx.moveTo(h, 0); ctx.lineTo(h - w, 0); ctx.stroke(); ctx.moveTo(h, 0); ctx.lineTo(h, w); ctx.stroke(); ctx.moveTo(h, h); ctx.lineTo(h - w, h); ctx.stroke(); ctx.moveTo(h, h); ctx.lineTo(h, h - w); ctx.stroke(); } SymbolMorph.prototype.renderSymbolTurtle = function (ctx, color) { // this.renderTexture('stitchcode/assets/turtles16.png', ctx); // draw a circle // draw a solid circle var w = this.symbolWidth(); var r = w / 2.5; ctx.fillStyle = color.toString(); ctx.beginPath(); ctx.scale(1, 0.7); ctx.arc(w / 2 - 1, w / (2 * 0.7), r, radians(0), radians(360), true); ctx.fill(); ctx.beginPath(); ctx.arc(w / 2 - 1 + r, w / (2 * 0.7), r/2, radians(0), radians(360), true); ctx.fill(); ctx.beginPath(); ctx.scale(1,1); ctx.arc(w / 2 - 1 - r/1.5, w / 2 - r/2, r/2.5, radians(0), radians(360), true); ctx.fill(); ctx.beginPath(); ctx.arc(w / 2 - 1 + r/1.5, w / 2 - r/2, r/2.5, radians(0), radians(360), true); ctx.fill(); ctx.beginPath(); ctx.arc(w / 2 - 1 - r/1.5, w / 2 + (r*1.5), r/2.5, radians(0), radians(360), true); ctx.fill(); ctx.beginPath(); ctx.arc(w / 2 - 1 + r/1.5, w / 2.0 + r*1.5, r/2.5, radians(0), radians(360), true); ctx.fill(); } SymbolMorph.prototype.renderSymbolTurtle2 = function (ctx, color) { this.texture = " Cve5B880WQVo6Ee0TIBauRzLuY/tmJaKeJsWp3DTChV/l6VNCk/+Pppgtmeb0RwdP/XMEudtw34iQ+oaiuVUPY978xwWvsz5nuuiwWea6OhT/S9a3Hj3FTJMQyUC6lYdqtpaKdvtFFkLcqQDPr/nVaYM4hu2D+MS2+YCWPbsHbV3kpRV55qp3vRV/8ClLvUdYCW1iM77XgPJRtjgIzVrOpJONvOwQtYz3uEUq955HZ/qh4coQiakt2WPVlJ9zrJ/D6dvDNnoc5ZTwk5fH4yPbNfGAn7oZ4oD412YBEOfb/ItxHH2QtIpgPN5DlOdMGVVBCSPcwvqYHyet1nGaRvu/N/Y0zpo8jpqMdG/xfPcN3mFuC9vgAAAAGYktHRAAAAAAAAPlDu38AAAAJcEhZcwAACxMAAAsTAQCanBgAAAAHdElNRQfiCwUTJB+11iBwAAACOklEQVQ4y42SzWsTQRjG3/nIajay+dytmVC20gSWJLLoghdDrb15CpZCIeQqePHa/6AiiDeh4lmxRMhBEcTSYg7iydqLwlIMdCPJoVuhmYHSzW7Xi4ht7aYPPKd5+M287zMIImSaJsIYLwZBIKXT6VedTmcEY0R1Xb8iy/I1VVW/DIfDna2trb+HjuOg4XB4A2P8gDHmAcDqWKCiKNdt237R7XZ/lUqlhZmZmc+u6yJZlkEIgTjnMBqNKMb4znmAmFL6JpvNrnuex3q93qrjOEuc87dCiC4h5AchpAkAcHR0RObm5mCs6vU6FIvFWULIAQCEZ5kx9t00zZxpmtEjHx4e6pzzJ0EQXIgKDgYDI5VK3atUKo/K5fIlTdNCz/PEysrK8WA+n38X9bJ/nc/n+9PT0x8TiUQvk8nYlmVZp25OJBLeeYEnrWnaw1OlxOPx9wghOI+mpqYGhmGsK4rSS6VSdqFQaJ3MEMuyPvm+f4tzfhkAziRjjEHX9eVms3mfUvpcUZRnExMTP23bPh5sNBpQrVZvU0oPACBECP13PFVVv9Vqtdz8/Hx0y67rxoQQS77vX8zlcg5j7KkQ4ibnvOT7PsIYZ/f29jRZlr9KkuS22+3oj727u1vv9/uzyWRyUCgUFg3DeJxMJu/G4/EqIeTq/v7+SwAASZKCjY2NsXumjLFNIURDUZRNSZJ2Wq0W/BkT0ul0GIYhxGIxX1XVD9vb22OBkfVOTk4iQsgCQogWi8XXa2tr/jjgb0Kz62O06rjhAAAAAElFTkSuQmCC"; this.render = function (ctx) { if (this.cachedTexture) { this.renderCachedTexture(ctx); } else if (this.texture) { this.renderTexture(this.texture, ctx); } this.changed(); }; this.renderCachedTexture = function (ctx) { ctx.drawImage( this.cachedTexture, 0, 16 ); this.changed(); }; this.render() this.fixLayout() }; /* SymbolMorph.prototype.drawSymbolFullScreen = function (canvas, color) { // answer a canvas showing two arrows pointing diagonally outwards var ctx = canvas.getContext('2d'), h = canvas.height, c = canvas.width / 2, off = canvas.width / 10, w = canvas.width / 2; ctx.strokeStyle = color.toString(); ctx.lineWidth = 1.5; ctx.moveTo(c - off, c + off); ctx.lineTo(0, h); ctx.stroke(); ctx.moveTo(c + off, c - off); ctx.lineTo(h, 0); ctx.stroke(); ctx.moveTo(0, h); ctx.lineTo(0, h - w); ctx.stroke(); ctx.moveTo(0, h); ctx.lineTo(w, h); ctx.stroke(); ctx.moveTo(h, 0); ctx.lineTo(h - w, 0); ctx.stroke(); ctx.moveTo(h, 0); ctx.lineTo(h, w); ctx.stroke(); return canvas; }; SymbolMorph.prototype.drawSymbolZoomToFit = function (canvas, color) { // answer a canvas showing two arrows pointing diagonally outwards var ctx = canvas.getContext('2d'), h = canvas.height, c = canvas.width / 2, off = canvas.width / 10, w = canvas.width / 4; ctx.strokeStyle = color.toString(); ctx.lineWidth = 1.5; ctx.moveTo(0, 0); ctx.lineTo(w, 0); ctx.stroke(); ctx.moveTo(0, 0); ctx.lineTo(0, w); ctx.stroke(); ctx.moveTo(0, h); ctx.lineTo(0, h - w); ctx.stroke(); ctx.moveTo(0, h); ctx.lineTo(w, h); ctx.stroke(); ctx.moveTo(h, 0); ctx.lineTo(h - w, 0); ctx.stroke(); ctx.moveTo(h, 0); ctx.lineTo(h, w); ctx.stroke(); ctx.moveTo(h, h); ctx.lineTo(h - w, h); ctx.stroke(); ctx.moveTo(h, h); ctx.lineTo(h, h - w); ctx.stroke(); return canvas; }; SymbolMorph.prototype.drawSymbolFile= function (canvas, color) { // answer a canvas showing a page symbol var ctx = canvas.getContext('2d'), w = Math.min(canvas.width, canvas.height) / 2; //ctx.fillStyle = color.toString(); ctx.beginPath(); ctx.moveTo(0, 0); ctx.lineTo(w, 0); ctx.lineTo(w, w); ctx.lineTo(canvas.width, w); ctx.lineTo(canvas.width, canvas.height); ctx.lineTo(0, canvas.height); ctx.stroke(); //ctx.fill(); //ctx.fillStyle = color.darker(25).toString(); ctx.beginPath(); ctx.moveTo(w, 0); ctx.lineTo(canvas.width, w); ctx.lineTo(w, w); ctx.lineTo(w, 0); ctx.stroke(); //ctx.fill(); return canvas; }; SymbolMorph.prototype.drawSymbolNormalScreen = function (canvas, color) { // answer a canvas showing two arrows pointing diagonally outwards var ctx = canvas.getContext('2d'), h = canvas.height, c = canvas.width / 2, off = canvas.width / 10, w = canvas.width / 2; ctx.strokeStyle = color.toString(); ctx.lineWidth = 1.5; ctx.moveTo(c - off, c + off); ctx.lineTo(0, h); ctx.stroke(); ctx.moveTo(c + off, c - off); ctx.lineTo(h, 0); ctx.stroke(); ctx.moveTo(0, h); ctx.lineTo(0, h - w); ctx.stroke(); ctx.moveTo(0, h); ctx.lineTo(w, h); ctx.stroke(); ctx.moveTo(h, 0); ctx.lineTo(h - w, 0); ctx.stroke(); ctx.moveTo(h, 0); ctx.lineTo(h, w); ctx.stroke(); return canvas; }; SymbolMorph.prototype.drawSymbolLargeStage = function (canvas, color) { var ctx = canvas.getContext('2d'), w = canvas.width, h = canvas.height, w2 = w * 1 / 3, h2 = h * 2 / 3; ctx.strokeStyle = color.toString(); ctx.lineWidth = 2; ctx.rect(0, 0, w, h); ctx.stroke(); ctx.rect(w2, 0, w, h2); ctx.stroke(); return canvas; }; SymbolMorph.prototype.drawSymbolNormalStage = function (canvas, color) { var ctx = canvas.getContext('2d'), w = canvas.width, h = canvas.height, w2 = w / 2, h2 = h / 2; ctx.strokeStyle = color.toString(); ctx.lineWidth = 2; ctx.rect(0, 0, w, h); ctx.stroke(); ctx.rect(w2, 0, w2, h2); ctx.stroke(); return canvas; }; SymbolMorph.prototype.drawSymbolSmallStage = function (canvas, color) { var ctx = canvas.getContext('2d'), w = canvas.width, h = canvas.height, w2 = w * 2 / 3, h2 = h * 1 / 3; ctx.strokeStyle = color.toString(); ctx.lineWidth = 2; ctx.rect(0, 0, w, h); ctx.stroke(); ctx.rect(w2, 0, w2, h2); ctx.stroke(); return canvas; }; */