Loren Brichter
d2b202d30a
Use verlet-style integration for spring animations. Rather than keeping track of "value" and velocity over time, keep track of value and previous-value, and derive velocity from the delta every tick. This has a few benefits, including greater stability (position and velocity can't drift) and simplifying signature of tick_spring (no need to pass velocity back up). Pulling "settled" flag out of the return signature as well means return value is just "next value", simplifying code mapping over objects and arrays, and eliminating duplicated code across get_initial_velocity, get_threshold and tick_spring. Refactored "threshold" calcs, extremely inexpensive to do inline in tick_spring rather than create a parallel structure. Also fixes a rare pathological case where springs will never settle (reading through the code, could happen if velocity was non-zero during a set() where target==current, threshold will be calculated to be zero and settled will always be set to false, leading to infinite animations). Functional changes: In my experience dealing with spring animations, there are a handful of edge-cases where it is nice to have library support. 99% of the time, the only times you'd want to fudge 'stiffness' and 'damping' is during a live interaction (e.g. dragging something around). By providing an idiomatic mechanism hopefully the code around dealing with that could be simpler. I propose an additional "options" parameter to 'set()' and 'update()'. If passed {hard:true} the set will be considered a "hard" set, where you want the value to be set to the target value immediately. This could be extremely useful when implementing dragging for instance. If passed {soft:true} or {soft:<duration>}, the set will be considered a "soft" set, where momentum will be preserved for some duration before settling. This could be useful when implementing "throwing", e.g. after a drag, on mouseup, 'soft set' to some position and the user's previous momentum will be honored before settling down. Technically momentum preservation happens to a degree now, but aggressive stiffness and/or damping values make it nearly unapparent. This handles the case where you may want more aggressive or heavily underdamped springs but without the apparent velocity discontinuity that happens on throw. (As a real example, in FaceTime, note behavior when tossing around the picture-in-picture, or the iPhone X gestural behavior when tossing apps back to the home screen). Internally this is implemented by temporarily setting mass to infinity and ramping back to normal over some duration. "Hard sets" are also special-cased to trigger a same-frame set and fulfilment, leading to more responsive dragging. Best case is a one frame improvement in drag latency (noticed in Safari). This also handles the "old way" method of munging 'stiffness' and 'damping' to 1, so the improvement applies to existing code. |
6 years ago | |
---|---|---|
.github | update references to svelte.technology - fixes #2450 | 6 years ago |
site | Document svelte/animate - flip. | 6 years ago |
src | Subtle tweaks to spring animations | 6 years ago |
test | fix subscribe implementation, add test for unsubscribing observables | 6 years ago |
.editorconfig | Fix prefixed animation name replacement | 7 years ago |
.eslintignore | implement Store | 7 years ago |
.eslintrc.json | change pkg.main to appease webpack | 6 years ago |
.flowconfig | add editorconfig and flowconfig files | 8 years ago |
.gitattributes | add .gitattributes for stopgap HTML syntax highlighting on .svelte files | 6 years ago |
.gitignore | Merge pull request #2247 from sveltejs/gh-2241 | 6 years ago |
.prettierrc | upgrade prettier; use .prettierrc | 7 years ago |
.travis.yml | Implement reactive assignments (#1839) | 6 years ago |
CHANGELOG.md | -> v3.1.0 | 6 years ago |
LICENSE | update license | 6 years ago |
README.md | better look | 6 years ago |
animate.mjs | add crossfade and flip functions (#2241) | 6 years ago |
appveyor.yml | Implement reactive assignments (#1839) | 6 years ago |
banner.png | ditto | 6 years ago |
easing.mjs | svelte/motion | 6 years ago |
index.mjs | rename to tick, remove callback interface | 6 years ago |
mocha.coverage.opts | Reinstate code coverage | 7 years ago |
mocha.opts | fire intro.start and outro.start events (#702) | 8 years ago |
package-lock.json | bump beta version | 6 years ago |
package.json | -> v3.1.0 | 6 years ago |
register.js | error on invalid compiler options — closes #2094 | 6 years ago |
rollup.config.js | add crossfade and flip functions (#2241) | 6 years ago |
store.mjs | add initial_value argument to derived store | 6 years ago |
transition.mjs | fix another crossfade bug | 6 years ago |
tsconfig.json | baby steps towards #1316 | 7 years ago |
README.md
What is Svelte?
Svelte is a new way to build web applications. It's a compiler that takes your declarative components and converts them into efficient JavaScript that surgically updates the DOM.
Learn more at the Svelte website, or stop by the Discord chatroom.
Development
Pull requests are encouraged and always welcome. Pick an issue and help us out!
To install and work on Svelte locally:
git clone git@github.com:sveltejs/svelte.git
cd svelte
npm install
To build the compiler, and all the other modules included in the package:
npm run build
To watch for changes and continually rebuild the package (this is useful if you're using npm link to test out changes in a project locally):
npm run dev
The compiler is written in TypeScript, but don't let that put you off — it's basically just JavaScript with type annotations. You'll pick it up in no time. If you're using an editor other than VSCode you may need to install a plugin in order to get syntax highlighting and code hints etc.
Running Tests
npm run test
To filter tests, use -g
(aka --grep
). For example, to only run tests involving transitions:
npm run test -- -g transition
svelte.dev
The source code for https://svelte.dev, including all the documentation, lives in the site directory. The site is built with Sapper. To develop locally:
cd site
npm install && npm run update
npm run dev