前段有牛人写了很多SWING的应用效果,觉得SWING实在是不可小视。嘿嘿,没事写着玩,不要跟牛人相比,看了你才知道真的可以用代码制造出来绚烂的效果。也许我们中的每一个都可以。
看了那个《飞屋环游记》的文章后,想再完善里边的云彩,如果可以用代码制造出来随机生成、色彩斑斓的祥云,代替呆板的静态底图,那这也是为牛人的补充啊。
不管咋样,最后做出来的效果也还差强人意:
这个祥云的动画效果主要关键点是云彩形状的控制,云彩位置的动画(制造动画的效果)和颜色的随机分配和透明度设置问题。分开来好好解决这三个问题,这个最终效果就出来了。随机分配都是用了别人产品的,不过一下子就好简单了。
云彩形状的控制:
Area shape = null;
for (int i = 0; i < 10; i++) {
int w = 100 + TWaverUtil.getRandomInt(200);
int h = 50 + TWaverUtil.getRandomInt(100);
int offsetSeed = 100;
int xOffset = TWaverUtil.getRandomInt(offsetSeed) - offsetSeed;
int yOffset = TWaverUtil.getRandomInt(offsetSeed / 4) - offsetSeed / 4;
Area circle = new Area(new Ellipse2D.Double(centerX + xOffset, centerY + yOffset, w, h));
if (shape == null) {
shape = circle;
} else {
shape.add(circle);
}
}
//transform.
Rectangle bounds = shape.getBounds();
double xScale = width / bounds.getWidth();
double yScale = height / bounds.getHeight();
AffineTransform at = AffineTransform.getScaleInstance(xScale, yScale);
return at.createTransformedShape(shape);
颜色的随机分配问题:
TWaverUtil.getRandomAlphaColor(),
透明度设置:
int a1 = mPointColor.getAlpha();
int a2 = mBackgroundColor.getAlpha();
return ( ( (a1 & a2) == 0xff) ? OPAQUE : TRANSLUCENT);
附带上比较全的代码,牛人手下留情啊