From 8dac5d8a3f2d860a3638f875dd256e3231a46645 Mon Sep 17 00:00:00 2001 From: Michael Date: Thu, 8 Jul 2021 15:40:57 +0200 Subject: [PATCH] add missing symbols (moved symbols there) --- stitchcode/symbols.js | 338 ++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 338 insertions(+) create mode 100644 stitchcode/symbols.js diff --git a/stitchcode/symbols.js b/stitchcode/symbols.js new file mode 100644 index 00000000..dad34569 --- /dev/null +++ b/stitchcode/symbols.js @@ -0,0 +1,338 @@ +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; +}; +*/