简体   繁体   中英

animation in squeak smalltalk

I have a simple morph in squeak smalltalk. I want to move it from x1,y1 to x2,y2 (animation) with 5 seconds (or 10 seconds)

is there a build in way to create animation in squeak smalltalk ?

Yes, there is a built in way:

Make a subclass of Morph and implement the two methods

  • stepTime (time between steps in milliseconds) and
  • step (is sent to the morph in regular intervals of time)

A minimal example:

Morph subclass: #MovingMorph
    instanceVariableNames: ''
    classVariableNames: ''
    category: 'MovingMorph'

MovingMorph>>stepTime

stepTime
    ^ 100

MovingMorph>>step

step
    self position: self position + (1@1)

Now open a MovingMorph in the World ( MovingMorph new openInWorld ) and control the animation with startStepping and stopStepping .

While it is possible to show animations using Morphic stepping, the Animations Project takes a bit further, and provides a simple interface to use short animations:

AnimPropertyAnimation new
   duration: 500;
   target: myMorph;
   property: #position; "There should be a message called #position:."
   startValue: 10@10;
   endValue: 100@100;
   start.

Things like fade-in or fade-out or similar are even simpler:

myMorph fadeOut.

The technical post webpages of this site follow the CC BY-SA 4.0 protocol. If you need to reprint, please indicate the site URL or the original address.Any question please contact:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM