Security News
The Risks of Misguided Research in Supply Chain Security
Snyk's use of malicious npm packages for research raises ethical concerns, highlighting risks in public deployment, data exfiltration, and unauthorized testing.
github.com/tanema/gween
Gween (go-between) is a small library to perform tweening in Go. It has a minimal interface, and it comes with several easing functions.
package gween
import (
"github.com/tanema/gween/ease"
"github.com/tanema/gween/gween"
)
// increase the value from 0 to 5 in 10 seconds
var tweenLinear = gween.New(0, 5, 10, ease.Linear)
current, isFinished := tweenLinear.Update(dt)
// make some text fall from the top of the screen, bouncing on y=300, in 4 seconds
var tweenLabel = gween.new(0, 300, 4, ease.OutBounce)
label.Y, _ = tweenLabel.Update(dt)
// fade background from white to black and foregrond from black to red in 2 seconds
currentBGColor = [4]float32{255, 255, 255, 255}
currentColor = [4]float32{0, 0, 0, 0}
var tweenBackground = gween.new(255, 0, 2, ease.Linear)
var tweenRed = gween.new(255, 0, 2, ease.Linear)
currentBG, _ := tweenBackground.Update(dt)
currentBGColor = [4]float32{currentBG, currentBG, currentBG, currentBG}
currentColor[0], _ = tweenRed.Update(dt)
// sequence increasing linearly from 0 to 4 over 10 seconds,
// then decreasing outElastic 4 to 0 over 2 seconds
var sequence = gween.NewSequence(
gween.New(0, 4, 10, ease.Linear),
gween.New(4, 0, 2, ease.OutElastic),
)
// set to infinitely loop
sequence.SetLoop(-1)
val, tweenCompleted, seqenceCompleted = sequence.Update(dt)
t := gween.New(begin, end, duration, easingFunction)
Creates a new tween.
begin
is the start valueend
is the ending valueduration
means how much the change will take until it's finished. It must be a positive number.easingFunction
can be either a function or a function name (see the easing section below).This function only creates and returns the tween. It must be captured in a variable
and updated via t.Update(dt)
in order for the changes to take place.
currentValue, isFinished := t.Update(dt)
Gradually changes the currentValue
toward the end
value as time passes.
t
is a tween returned by gween.New
dt
is the difference in time. It will be added to the internal time counter of
the tween. The current value at the current value will be returned using selected
easing function.currentValue
is the current eased value for the current time.isFinised
is true
if the tween has reached its limit (its internal clock is >= duration
). It is false otherwise.When the tween is complete, the currentValue
will be equal to the end
value.
The way they change over time will depend on the chosen easing function.
If dt
is positive, the easing will be applied until the internal clock equals
duration
, at which point the easing will stop. If it is negative,
the easing will play "backwards", until it reaches the initial value.
currentValue, isFinished := t.Set(clock)
Moves a tween's internal clock to a particular moment.
t
is a tween returned by gween.New
clock
is a positive number or 0. It's the new value of the tween's internal clock.currentValue
is the value of the tween at the time set.isFinished
works like in t.Update
; it's true
if the tween has reached its
end, and false
otherwise.s := gween.NewSeqence(tweens ...*Tween)
Sequences can be used to execute tweens in sequence. They also provide looping and "yoyo" functionality.
tweens
the tweens to be executed in sequential orderThis function only creates and returns the sequence. It must be captured in a variable
and updated via s.Update(dt)
in order for the changes to take place.
currentValue, tweenCompleted, seqeuenceCompleted := s.Update(dt)
Gradually changes the currentValue
from the begin
value to the end
value
of each tween in the sequence as time passes. If a dt
is too large for the current
tween, the "overflow" amount will automatically be carried into the next tween until the
entire dt
is exhausted by the tweens in the sequence, or the sequence completes.
s
is a sequence returned by gween.NewSequence
dt
is the difference in time. It will be added to the internal time counter of
the current tween and "overflow" to the next until completed exhausted.currentValue
is the current eased value for the current time.tweenCompleted
is true
if any tween within the sequence has completed during this update.sequenceCompleted
is true
if the entire sequence and all loops have completed.
false
s.SetLoop(l)
Defaults to 1
Configures the sequence to "loop" l
times. When l
is -1
, sequence will
loop infinitely.
When used with s.SetYoyo(true)
, a single "loop" starts and ends at the
begin
ning of the first tween; making its way out to the end
of the final
tween and back again.
s.SetYoyo(bool)
Defaults to false
Configures the sequence on whether to "yoyo" between the begin
ning of the
first tween and the end
of the last tween.
yoyo
is false
:
currentValue
will be
equal to the end
value of the final tween.yoyo
is true
:
currentValue
will be
equal to the begin
value of the first tween.s.Reset()
Resets all tweens in the sequence and sets the "current" tween back to the first. Also,
sets the remaining loop count back to the initial value last set using the
.SetLoop()
function (or 1
if using the default).
s.SetReverse(bool)
Defaults to false
Configures the sequence to run in "reverse" or not.
yoyo
is false
:
reverse
is false
, the sequence will run forward and will loop back to
the beginning if availablereverse
is true
, the sequence will run backward and will loop back to
the end if availableyoyo
is true
:
s.Add(tweens ...*Tween)
Adds the tweens
provided, in order, at the end of the existing tween list
s.Remove(index)
Removes the tween at the desired index
. If you call .Remove()
on an index
out of bounds, nothing happens.
Easing functions are functions that express how slow/fast the interpolation happens in tween.
Gween comes with 45 default easing functions already built-in (adapted from Enrique García Cota's easing library).
The easing functions can be found in the ease
package.
They can be divided into several families:
linear
is the simplest easing function, straight from one value to the other.quad
, cubic
, quart
, quint
, expo
, sine
and circle
are all "smooth" curves that will make transitions look natural.back
family starts by moving the interpolation slightly "backwards" before moving it forward.bounce
family simulates the motion of an object bouncing.elastic
family simulates inertia in the easing, like an elastic gum.Each family (except linear
) has 4 variants:
In
starts slow, and accelerates at the endOut
starts fast, and decelerates at the endInOut
starts and ends slow, but it's fast in the middleOutIn
starts and ends fast, but it's slow in the middlefamily | in | out | inOut | outIn |
---|---|---|---|---|
Linear | Linear | Linear | Linear | Linear |
Quad | InQuad | OutQuad | InOutQuad | OutInQuad |
Cubic | InCubic | OutCubic | InOutCubic | OutInCubic |
Quart | InQuart | OutQuart | InOutQuart | OutInQuart |
Quint | InQuint | OutQuint | InOutQuint | OutInQuint |
Expo | InExpo | OutExpo | InOutExpo | OutInExpo |
Sine | InSine | OutSine | InOutSine | OutInSine |
Circ | InCirc | OutCirc | InOutCirc | OutInCirc |
Back | InBack | OutBack | InOutBack | OutInBack |
Bounce | InBounce | OutBounce | InOutBounce | OutInBounce |
Elastic | InElastic | OutElastic | InOutElastic | OutInElastic |
You are not limited to gween's easing functions; if you pass a function parameter in the easing, it will be used.
The passed function will need to suite the TweenFunc interface: func(t, b, c, d float32) float32
t
(time): starts in 0 and usually moves towards durationb
(begin): initial value of the of the property being eased.c
(change): ending value of the property - starting value of the propertyd
(duration): total duration of the tweenAnd must return the new value after the interpolation occurs.
Here's an example using a custom easing.
labelTween := tween.new(0, 300, 4, func(t, b, c, d) float32 {
return c*t/d + b // linear ease
})
The easing functions have been translated from Enrique García Cota's project in
https://github.com/kikito/tween.lua
See the LICENSE file for details.
FAQs
Unknown package
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Snyk's use of malicious npm packages for research raises ethical concerns, highlighting risks in public deployment, data exfiltration, and unauthorized testing.
Research
Security News
Socket researchers found several malicious npm packages typosquatting Chalk and Chokidar, targeting Node.js developers with kill switches and data theft.
Security News
pnpm 10 blocks lifecycle scripts by default to improve security, addressing supply chain attack risks but sparking debate over compatibility and workflow changes.