dat.GUI 创建多个同名按钮
dat.GUI create multiple buttons with same name
我尝试使用 dat.GUI 创建多个同名 "ShowCoord" 的按钮,这可能吗?我目前拥有的是:
for (i = 0; i < overlay.numElements; i ++)
{
var length = overlay.elementNumVertices[i];
var subObj = {
'name' : overlay.elementNames[i],
'index' : i,
'numVertices': overlay.elementNumVertices[i],
"ShowCoord" : function(){
console.log("i is " + subObj['index']);
var verts = overlay.elementVertices[i];
for(var j = 0; j < subObj['numVertices']; j ++)
{
console.log("The coordinates are " + verts[3*j] + ", "+ verts[3*j+1] +", "+verts[3*j+2]);
}
}
};
subObjArray.push(subObj);
}
for(i = 0; i < subObjArray.length; i ++)
{
var currObj = subObjArray[i];
var subGui = gui.addFolder(currObj['name']);
subGui.add(currObj, 'numVertices');
subGui.add(currObj, "ShowCoord");
}
我现在显示了正确的 currObj['name'] 和 currObj['numVertices']。但是所有 "ShowCoord" 按钮只包含最后一个 subObj 的信息(所以 console.log("i is " + subObj['index']) 即使我点击每次都会打印出 148不同的按钮)。我怎样才能让它发挥作用?非常感谢!
尝试将 subGui
移到 for loop
之外并修改您的代码,以免重新分配 subGui
变量。
var subGui = new dat.GUI();
for(i = 0; i < subObjArray.length; i ++)
{
var currObj = subObjArray[i];
subGui.addFolder(currObj['name']);// <--- work on this line
subGui.add(currObj, 'numVertices');
subGui.add(currObj, "ShowCoord");
}
否则总是用for loop
的最后一个迭代元素重新定义
注意:这只是一个提示,我无法从您的代码中得出更多结论。
我尝试使用 dat.GUI 创建多个同名 "ShowCoord" 的按钮,这可能吗?我目前拥有的是:
for (i = 0; i < overlay.numElements; i ++)
{
var length = overlay.elementNumVertices[i];
var subObj = {
'name' : overlay.elementNames[i],
'index' : i,
'numVertices': overlay.elementNumVertices[i],
"ShowCoord" : function(){
console.log("i is " + subObj['index']);
var verts = overlay.elementVertices[i];
for(var j = 0; j < subObj['numVertices']; j ++)
{
console.log("The coordinates are " + verts[3*j] + ", "+ verts[3*j+1] +", "+verts[3*j+2]);
}
}
};
subObjArray.push(subObj);
}
for(i = 0; i < subObjArray.length; i ++)
{
var currObj = subObjArray[i];
var subGui = gui.addFolder(currObj['name']);
subGui.add(currObj, 'numVertices');
subGui.add(currObj, "ShowCoord");
}
我现在显示了正确的 currObj['name'] 和 currObj['numVertices']。但是所有 "ShowCoord" 按钮只包含最后一个 subObj 的信息(所以 console.log("i is " + subObj['index']) 即使我点击每次都会打印出 148不同的按钮)。我怎样才能让它发挥作用?非常感谢!
尝试将 subGui
移到 for loop
之外并修改您的代码,以免重新分配 subGui
变量。
var subGui = new dat.GUI();
for(i = 0; i < subObjArray.length; i ++)
{
var currObj = subObjArray[i];
subGui.addFolder(currObj['name']);// <--- work on this line
subGui.add(currObj, 'numVertices');
subGui.add(currObj, "ShowCoord");
}
否则总是用for loop
注意:这只是一个提示,我无法从您的代码中得出更多结论。