1 - ブロックの表示

by samegame
二次元配列でブロックを表示。
* 
* 問題点:ブロックの幅がきっちりしすぎてくっついているように見える
♥0 | Line 51 | Modified 2009-11-17 09:04:29 | MIT License
play

ActionScript3 source code

/**
 * Copyright samegame ( http://wonderfl.net/user/samegame )
 * MIT License ( http://www.opensource.org/licenses/mit-license.php )
 * Downloaded from: http://wonderfl.net/c/70iw
 */

/**
 * 二次元配列でブロックを表示。
 * 
 * 問題点:ブロックの幅がきっちりしすぎてくっついているように見える
 */
package
{
	import flash.display.Sprite;
	
	[SWF(backgroundColor = "0x0")]
	public class Main extends Sprite
	{
		public function Main()
		{
			var panel:Panel = new Panel();
			addChild(panel);
		}
	}
}

import flash.display.Sprite;

class Panel extends Sprite // ブロックはパネルに貼る
{
	public static const WIDTH:int = 10; 	// ブロックの数 - 横
	public static const HEIGHT:int = 10; 	// ブロックの数 - 縦
	
	private var blocks:Array;
	
	public function Panel()
	{
		createBlocks();
	}
	
	private function createBlocks():void
	{
		blocks = new Array(WIDTH);
		
		for (var y:int = 0; y < HEIGHT; y++)
		{
			blocks[y] = new Array(HEIGHT);
			
			for (var x:int = 0; x < WIDTH; x++)
			{
				var block:Block = new Block();
				block.x = x * Block.WIDTH;
				block.y = y * Block.HEIGHT;
				addChild(block);
				
				blocks[y][x] = block;
			}
		}
	}
}

class Block extends Sprite
{
	public static const WIDTH:int = 30; // ブロックの横幅
	public static const HEIGHT:int = 30; // ブロックの縦幅
	
	public function Block()
	{	
		graphics.beginFill(0xED1A3D);
		graphics.drawRect(0, 0, WIDTH, HEIGHT);
		graphics.endFill();
	}
}

Forked