我的图层上有一个EditBox。
var ebox = new cc.EditBox(cc.p(200, 30));
ebox.setPosition(size.width / 2 - 50, size.height / 2);
ebox.setPlaceHolder("Password");
ebox.setInputFlag(cc.EDITBOX_INPUT_FLAG_PASSWORD);
ebox.setDelegate(this);
ebox.setFontColor({"r": 0, "g": 0, "b": 0});
ebox.setFontSize(20);
ebox.initWithBackgroundColor(cc.size(200, 30), {"r": 0, "g": 255, "b": 0});
ebox.init();
this.addChild(ebox, 1); //this - is a main layer
然后我必须在主图层上显示某种叠加
this.getParent().addChild(overlayLayer, 100);
overlayLayer - 填充颜色的图层
事情是编辑框始终位于叠加层之上。为什么没有zOrder使用EditBox ??
答案 0 :(得分:0)
我的代码遇到了同样的问题。我的解决方案是一种解决方法。您可以使用精灵作为背景。然后就行了。
var ebox = cc.EditBox.create(cc.size(170, 50), cc.Scale9Sprite.create("res/extensions/green_edit.png"), cc.Scale9Sprite.create("res/extensions/orange_edit.png"));
ebox.setPlaceHolder("Password");
ebox.setInputFlag(cc.EDITBOX_INPUT_FLAG_PASSWORD);
ebox.setPosition(cc.p(size.width/2,size.height/2));
ebox.setFontColor({"r": 0, "g": 0, "b": 0});
ebox.setDelegate(this);
this.addChild(ebox,1);