| OLD | NEW |
| (Empty) |
| 1 #!mojo mojo:sky_viewer | |
| 2 <sky> | |
| 3 <import src="/sky/framework/debug/shake-to-reload.sky" /> | |
| 4 <style> | |
| 5 dot { | |
| 6 position: absolute; | |
| 7 height: 10px; | |
| 8 width: 10px; | |
| 9 background-color: #00FF00; | |
| 10 border-radius: 5px; | |
| 11 opacity: .75; | |
| 12 } | |
| 13 </style> | |
| 14 <log>Ready!</log> | |
| 15 <script> | |
| 16 import "dart:sky"; | |
| 17 | |
| 18 // Material design colors. :p | |
| 19 List<String> colors = [ | |
| 20 "#009688", | |
| 21 "#FFC107", | |
| 22 "#9C27B0", | |
| 23 "#03A9F4", | |
| 24 "#673AB7", | |
| 25 "#CDDC39", | |
| 26 ]; | |
| 27 | |
| 28 Element whichDot(event) { | |
| 29 return document.querySelector('dot[id="${event.pointer}"]'); | |
| 30 } | |
| 31 | |
| 32 void moreDots(event) { | |
| 33 Element dot = document.createElement('dot'); | |
| 34 dot.setAttribute('id', "${event.pointer}"); | |
| 35 dot.style['background-color'] = colors[event.pointer.remainder(colors.length)]
; | |
| 36 document.querySelector('sky').appendChild(dot); | |
| 37 runToTheCenter(event); | |
| 38 } | |
| 39 | |
| 40 void goAway(event) { | |
| 41 whichDot(event).remove(); | |
| 42 } | |
| 43 | |
| 44 void stopDots(event) { | |
| 45 for (Element e in document.querySelectorAll('dot')) | |
| 46 e.remove(); | |
| 47 } | |
| 48 | |
| 49 void runToTheCenter(event) { | |
| 50 double radius = (5 + (95 * event.pressure)); | |
| 51 Element dot = whichDot(event); | |
| 52 dot.style["transform"] = "translate(${event.x-radius}px,${event.y-radius}px)"; | |
| 53 dot.style["width"] = "${2 * radius}px"; | |
| 54 dot.style["height"] = "${2 * radius}px"; | |
| 55 dot.style["border-radius"] = "${radius}px"; | |
| 56 } | |
| 57 | |
| 58 void main() { | |
| 59 document.addEventListener("pointerdown", moreDots); | |
| 60 document.addEventListener("pointermove", runToTheCenter); | |
| 61 document.addEventListener("pointerup", goAway); | |
| 62 document.addEventListener("pointercancel", stopDots); | |
| 63 } | |
| 64 </script> | |
| 65 </sky> | |
| OLD | NEW |