我正在尝试创建一个程序,它将使用数组传播节点,我在数组中输入节点,首先程序运行正常,但是当我想在greed []数组中对数据进行排序时;与greed.sort();数据没有订购,请帮帮我们。还有一个,如果这些信息是movieclip或graphic,我如何在输出面板中看到标签?像这样:
<pre><code>
//first program
trace("data"); //data --> can display label "data".
//second program
var dot:Dot = new Dot(); //graphic from library
trace(dot); //[object Dot] --> Cant show label "dot" ??
所以,我的问题是: 1.如何从对象数据中排序数组中的数据? 2.如果数据是图形或动画片段,如何在输出面板中显示标签数据?
这是我的完整代码:
var A:Node = new Node();
var B:Node = new Node();
var C:Node = new Node();
var D:Node = new Node();
var E:Node = new Node();
var F:Node = new Node();
var G:Node = new Node();
var node:Array = [];
var goal:Array = [E,G];
var finalCheck:Array = [];
A.x = 55; B.x = 165; C.x = 275; D.x = 55; E.x = 385; F.x = 165; G.x = 385;
A.y = 165; B.y = 55; C.y = 165; D.y = 275; E.y = 55; F.y = 275; G.y = 275;
node.push(A,B, A,C, A,D,
B,E, B,C, C,B, C,E, C,G, C,F, D,F,
C,E, C,G, C,F, B,A, B,E, F,G, F,D, F,C, F,G,
F,G, F,D, D,A, C,A, C,B, C,E, C,G,
D,A, B,A, B,E);
for (var d:int = 0; d<node.length; d++){
addChild(node[d]);
}
trace(node.length);
function sortIndex(){
var greedArr = [];
for (var i:int = 0; i<node.length; i++)
{
if ((i%2 == 0 && node[i] != goal[1] && node[(i+1)] == goal[0]) ||
(i%2 == 0 && node[i] != goal[0] && node[(i+1)] == goal[1]) ||
(i%2 != 0 && node[i] != goal[1] && node[(i+1)] == goal[0]) ||
(i%2 != 0 && node[i] != goal[0] && node[(i+1)] == goal[1]))
greedArr.push(node[(i)]);
}
greedArr.sort();
trace("greedArr : "+greedArr+" // "+greedArr.length); //B,B,B,C,C,C,C,C,C,F,F,F
var checker:Array = [];
var Z:int;
for (var k:int = 0; k<greedArr.length/3; k++){
Z = k*3;
checker.push(greedArr[Z]);
}
trace("checker : "+checker+" // "+checker.length); //B,C,C,F
for (var M:int = 0; M<checker.length; M++){
if (checker[M] != checker[M-1] && checker[M] != checker[M+1]){
finalCheck.push(checker[M]);
}
if (checker[M] == checker[M-1] && checker[M] != checker[M+1]){
finalCheck.unshift(checker[M]);
}
if (checker[M] != checker[M-1] && checker[M] == checker[M+1]){
finalCheck.unshift(checker[M]);
}
}
trace("finalCheck : "+finalCheck+" // "+finalCheck.length); //C,C,B,F
for (var e:int = 0; e<finalCheck.length; e++){
trace((finalCheck[e]).x)
}
}
sortIndex();
答案 0 :(得分:0)
你的代码很难读。似乎属于某种类型的游戏。为什么你过分复杂?如果您确实需要Node系统,我建议您使用流行的框架。它的社区支持并优化了比特。