spring-draggable-bound-main.js

total 0
used 0
limit 0
/* title: Spring Forces Distributed With Time tags: springs categories: springs files: ../point_src/core/head.js ../point_src/pointpen.js ../point_src/pointdraw.js ../point_src/math.js ../point_src/extras.js ../point_src/point-content.js ../point_src/pointlistpen.js ../point_src/pointlist.js ../point_src/events.js ../point_src/point.js ../point_src/distances.js ../point_src/dragging.js ../point_src/stage.js ../point_src/automouse.js ../point_src/functions/springs.js ../point_src/functions/clamp.js ../point_src/setunset.js ../point_src/stroke.js */ class MainStage extends Stage { // canvas = document.getElementById('playspace'); canvas = 'playspace' mounted(){ this.points = new PointList( new Point({ x: 150, y: 230 , radius: 10 , vx: .1, vy: 0 , mass: 10 }) , new Point({ x: 350, y: 200 , vx: 2, vy: 0 , radius: 12 , mass: 12 }) , new Point({ x: 250, y: 270 , vx: .4, vy: -1 , radius: 8 , mass: 8 }) ) this.dragging.addPoints(...this.points) this.dragging.onWheel = this.onWheel.bind(this) this.dragging.onDragStart = this.onDragStart.bind(this) this.dragging.onDragEnd = this.onDragEnd.bind(this) this.restLength = 100; this.springConstant = .6; this.dampingFactor = 0.99; // Adjust this value between 0 and 1 } onDragStart(ev, p) { this.dragPoint = p } onDragEnd(ev, p) { this.dragPoint = undefined } onWheel(ev, p) { p.mass = p.radius } draw(ctx){ this.clear(ctx) let mouse = Point.mouse.position let ps = this.points; let sv = this.dragPoint != undefined? [this.dragPoint]: []; const lockedPoints = new Set(sv)//ps[0]]); // Lock pointA in place const restLength = this.restLength const springConstant = this.springConstant const dampingFactor = this.dampingFactor const deltaTime = .1 const f = applySpringForceDistributedWithTime // const f = applySpringForceDistributed // const f = applySpringForce //applySpringForceDistributed f(ps[0], ps[1], restLength, springConstant, dampingFactor, lockedPoints, deltaTime); f(ps[1], ps[2], restLength, springConstant, dampingFactor, lockedPoints, deltaTime); f(ps[2], ps[0], restLength, springConstant, dampingFactor, lockedPoints, deltaTime); // this.points.last().rotation += 2 this.points.pen.indicators(ctx) } } stage = MainStage.go(/*{ loop: true }*/)
Run
Meta Data
title Spring Forces Distributed With Time
imports ()
files ('../point_src/core/head.js', '../point_src/pointpen.js', '../point_src/pointdraw.js', '../point_src/math.js', '../point_src/extras.js', '../point_src/point-content.js', '../point_src/pointlistpen.js', '../point_src/pointlist.js', '../point_src/events.js', '../point_src/point.js', '../point_src/distances.js', '../point_src/dragging.js', '../point_src/stage.js', '../point_src/automouse.js', '../point_src/functions/springs.js', '../point_src/functions/clamp.js', '../point_src/setunset.js', '../point_src/stroke.js')
unused_keys ()
unknown_keys ('categories', 'tags')
categories ['springs']
tags ['springs']
filepath_exists True
path spring-draggable-bound-main.js
filepath spring-draggable-bound-main.js
clean_files ('../point_src/core/head.js', '../point_src/pointpen.js', '../point_src/pointdraw.js', '../point_src/math.js', '../point_src/extras.js', '../point_src/compass.js', '../point_src/center.js', '../point_src/point-content.js', '../point_src/pointlistpen.js', '../point_src/pointlistdraw.js', '../point_src/pointlistgradient.js', '../point_src/pointlistshape.js', '../point_src/pointlistgenerator.js', '../point_src/unpack.js', '../point_src/pointlist.js', '../point_src/events.js', '../point_src/relative-xy.js', '../point_src/pointcast.js', '../point_src/point.js', '../point_src/distances.js', '../point_src/protractor.js', '../point_src/text/beta.js', '../point_src/dragging.js', '../point_src/stage-resize.js', '../point_src/functions/resolve.js', '../point_src/stage.js', '../point_src/automouse.js', '../point_src/functions/springs.js', '../point_src/functions/clamp.js', '../point_src/setunset.js', '../point_src/stroke.js')
markdown {'html': '', 'content': 'title: Spring Forces Distributed With Time\ntags: springs\ncategories: springs\nfiles:\n ../point_src/core/head.js\n ../point_src/pointpen.js\n ../point_src/pointdraw.js\n ../point_src/math.js\n ../point_src/extras.js\n ../point_src/point-content.js\n ../point_src/pointlistpen.js\n ../point_src/pointlist.js\n ../point_src/events.js\n ../point_src/point.js\n ../point_src/distances.js\n ../point_src/dragging.js\n ../point_src/stage.js\n ../point_src/automouse.js\n ../point_src/functions/springs.js\n ../point_src/functions/clamp.js\n ../point_src/setunset.js\n ../point_src/stroke.js'}