UNPKG

agentscript

Version:

AgentScript Model in Model/View architecture

61 lines (52 loc) 1.6 kB
<html> <head> <title>Avalanche</title> <link rel="icon" type="image/x-icon" href="../favicon.ico" /> </head> <body> <script type="module"> import * as util from '../src/utils.js' import TwoDraw from '../src/TwoDraw.js' import Animator from '../src/Animator.js' import Color from '../src/Color.js' import ColorMap from '../src/ColorMap.js' import AvalancheModel from '../models/AvalancheModel.js' const pi = Math.PI /** * * View * * */ const snowColor = ColorMap.gradientColorMap(20, ['rgb(98,52,18)', 'white']) const drawOptions = { patchesColor: p => { const aspect2 = (p.aspect + 2 * pi) % (2 * pi) const k = (pi - Math.abs(aspect2 - pi)) / pi const snow = snowColor.scaleColor(p.snowDepth, 0, 6) const col = Color.typedColor(k * snow[0], k * snow[1], k * snow[2]) return col }, } const model = new AvalancheModel() await model.startup() model.setup() const view = new TwoDraw( model, { div: 'modelDiv', }, drawOptions ) const anim = new Animator( () => { model.step() view.draw() }, 500, // run 500 steps 30 // 30 fps ) util.toWindow({ util, model, view, anim, ColorMap, Color }) </script> <div id="modelDiv"></div> </body> </html>