我有一个CircleMorph
,我想扩展它的直径,可能用它创建一个小动画。
b := CircleMorph new.
b color: Color transparent.
b borderWidth: 2.
b extent:100 @ 100.
b openInWorld.
如果我使用循环或step
方法执行此操作会不会很好?如果您推荐step
方法,那我该怎么做?
答案 0 :(得分:2)
您可以创建名为CircleMorph
的{{1}}的子类。
然后实施GrowingCircleMorph
:
step
现在如果你在世界上打开一个新的GrowingCircleMorph实例,它将开始成长为201 @ 201。
要更改速度,请执行step
self extent: (self extent) + 1.
(self extent) > (200@200) ifTrue: [ self stopStepping ]
并在步骤之间返回所需的时间(以毫秒为单位)。
更新:如果您希望中心保持不变,请更改圆圈变形的范围,而不是范围:
stepTime
答案 1 :(得分:0)
如果您想要玩这些东西,请将其设为通用:
HOCanvasMorph>>drawOn: aCanvas
super drawOn: aCanvas.
drawBlock ifNotNil: [
aCanvas
translateBy: self bounds origin
clippingTo: self bounds
during: [:canvas | drawBlock value: canvas]]
HOCanvasMorph>>drawBlock: aBlock
drawBlock := aBlock.
self changed.
HOCanvasMorph class>>example
|m|
m := HOCanvasMorph new openInWorld.
"to draw:"
m drawBlock: [:c |
c line: 10@10 to: 100@100 color: Color red
]
HOCanvasMorph class>>napperons
"Some mathematical fun"
| m |
m := HOCanvasMorph new openInWorld. "to draw:"
m
drawBlock: [ :aCanvas |
| n r t xa xc xb yc ya yb longueur nombreDeDroites |
longueur := 150.
nombreDeDroites := 30. "super drawOn: aCanvas."
xc := 200.
yc := 200.
n := 15.
r := 100.
0 to: n - 2 do: [ :i |
t := 2 * Float pi * i / n.
i + 1 to: n - 1 do: [ :j |
| tj |
tj := 2 * Float pi * j / n.
xa := xc + (r * t cos).
ya := yc + (r * t sin).
xb := xc + (r * tj cos).
yb := yc + (r * tj sin).
(aCanvas asBalloonCanvas) line: xa @ ya to: xb @ yb color: Color green ] ] ]
由于块可以使用任何更改的内容,请将这些更改放入步骤方法中。