我試圖創建一種樹形圖,使得如果你點擊其中一個圓圈,它的子圓圈向外散佈一定程度的隨機性從原始圓圈連接線。我有這個工作,但現在我想要做的是確保沒有任何一個圓圈彼此碰撞,沒有任何一條線縱橫交錯。你可以看到正在發生的事情的截圖。我的代碼如下。如何更改此代碼以檢查碰撞並避免碰撞?我已經閱讀了flash的hitTestObject命令,但它只適用於上下文中的一個對象。我想測試一個對象與任何顯示對象的聯繫。與舞臺上的多個對象碰撞測試
import com.greensock.TweenMax;
var sw = stage.stageWidth;
var sh = stage.stageHeight;
var cr = 3; //circle radius
var moveRange = 25;
var circleColor = 0xcccccc;
var numCircles = 4;
var lineCanvas:Sprite = new Sprite();
addChild(lineCanvas);
var lineColor = 0xe9e9e9;
var lineWeight = 1;
function init(){
firstCircle();
}
function firstCircle(){
var xPos = randomRange(cr, sw-cr);
var yPos = randomRange(cr, sh-cr);
var newCircle:Shape = new Shape();
newCircle.graphics.beginFill(circleColor);
newCircle.graphics.drawCircle(0,0,cr);
newCircle.graphics.endFill();
var circleClip:MovieClip = new MovieClip();
circleClip.childCircles = 2;
circleClip.x = xPos;
circleClip.y = yPos;
circleClip.addChild(newCircle);
addChild(circleClip);
circleClip.addEventListener(MouseEvent.CLICK,clickCircle);
}
function clickCircle(e:MouseEvent):void {
var thisCircle = e.target;
for (var i=0; i<thisCircle.childCircles;i++){
drawCircle(thisCircle);
}
}
function drawCircle(parentCircle){
var xPos = parentCircle.x;
var yPos = parentCircle.y
//var xPos = randomRange(cr, sw-cr);
//var yPos = randomRange(cr, sh-cr);
var newCircle:Shape = new Shape();
newCircle.graphics.beginFill(circleColor);
newCircle.graphics.drawCircle(0,0,cr);
newCircle.graphics.endFill();
var circleClip:MovieClip = new MovieClip();
circleClip.childCircles = 2;
circleClip.x = xPos;
circleClip.y = yPos;
circleClip.addChild(newCircle);
addChild(circleClip);
circleClip.addEventListener(MouseEvent.CLICK,clickCircle);
moveCircle(circleClip,xPos,yPos);
}
function drawLine(childCircle,parentX,parentY){
lineCanvas.graphics.lineStyle(lineWeight,lineColor);
lineCanvas.graphics.moveTo(parentX,parentY);
lineCanvas.graphics.lineTo(childCircle.x,childCircle.y);
//想檢查線或圓是否在這裏聯繫任何東西。如果是這樣,我想殺死圈子(因此也停止繪製線)。
}
function moveCircle(childCircle,parentX,parentY){
var curX = childCircle.x;
var curY = childCircle.y;
var moveX = randomRange(curX-moveRange,curX+moveRange);
var moveY = randomRange(curY-moveRange-cr,curY+moveRange+cr);
TweenMax.to(childCircle,.5, { x: moveX, y: moveY, onUpdate:drawLine, onUpdateParams:[childCircle,parentX,parentY]});
}
function randomRange(minNum:Number, maxNum:Number):Number {
return (Math.floor(Math.random() * (maxNum - minNum + 1)) + minNum);
}
init();