Error: Getting control 0's position in a ...when doing used

I am getting this error:

“Getting control 0’s position in a group with only 0 controls when doing used”

I am trying to have a GUILayout area with some buttons that appear and disappear, and have everything resized accordingly. Here is the code snippet.

GUILayout.BeginArea (Rect (actionButtonsEdge, buttonGuiTop, buttonSide, buttonSide));

for (action = 0; action < lighterActions.length; action++) {

if (GUILayout.Button(lighterActions[action], buttonStyle, GUILayout.ExpandWidth(true), GUILayout.ExpandHeight(true))) {}

}
					
GUILayout.EndArea ();

I also get

“GUILayout: Mismatched BeginArea.”

and

“InvalidOperationException: Operation is not valid due to the current state of the object”.

:?: :? :?:

There must be more to it than that. :slight_smile: Because that bit looks OK, I think.

–Eric

I don’t get any errors when I use my original method:

var buttonHeight = buttonSide / lighterActions.length;

for (action = 0; action < lighterActions.length; action++) {

var buttonTop = buttonGuiTop + (action * buttonHeight);

if (GUI.Button(Rect (actionButtonsEdge, buttonTop, buttonSide, buttonHeight), lighterActions[action], buttonStyle)) {}

}

However, that doesn’t seem to allow me to use the Margin settings of the GUI Style, which I want to employ in order to get a bit of spacing between the buttons.

This is the only change being made, and it makes the difference of the script generating errors or not. The buttons actually show up using the first code example, and even still function correctly (with a lot more code not shown here), but I get that error, and I think it adds a bit of weirdness down the road.

That looks like a bug + I’d love it if you would file me a repro case using the bugreporter so I can take a look.

Thanks,
Nicholas

Ok, I’ve found the culprit. It’s the “if (objects[object] == “1”) {}” statement in this code:

private var objects = new Array();
private var object : int;
private var actions = new Array();

function Start () {
	objects = ["1", "2", "3"];
	actions = ["one", "two", "three"];
}

function OnGUI () {
	var utObjects = objects.ToBuiltin(String);  // so you can modify the objects list and make the GUI grid work
	object = GUI.SelectionGrid (Rect (0, 0, 300, 300), object, utObjects, 1);
	
	if (objects[object] == "1") {
		GUILayout.BeginArea (Rect (300,0,300,300));
		for (action = 0; action < actions.length; action++) {
			if (GUILayout.Button(actions[action], GUILayout.ExpandWidth(true), GUILayout.ExpandHeight(true))) {
			}
		}
		GUILayout.EndArea ();
	}
}

Just click on 2 or 3 and then select 1 again, and you will get the errors. Now, the code works fine if I use the non-GUI Layout method found here:

private var objects = new Array();
private var object : int;
private var actions = new Array();

function Start () {
	objects = ["1", "2", "3"];
	actions = ["one", "two", "three"];
}

function OnGUI () {
	var utObjects = objects.ToBuiltin(String);  // so you can modify the objects list and make the GUI grid work
	object = GUI.SelectionGrid (Rect (0, 0, 300, 300), object, utObjects, 1);
	
	if (objects[object] == "1") {
		var buttonHeight = 300 / actions.length;
		for (action = 0; action < actions.length; action++) {
			var buttonTop = action * buttonHeight;
			if (GUI.Button(Rect (300, buttonTop, 300, buttonHeight), actions[action]) ) {
			}
		}
	}
}

But once again, I am trying to incorporate the Margin setting for the buttons, and I am hoping that the Layout method will allow that, because my current, otherwise functional method, does not. Please let me know if a bug report is still in order, or if there is a way to fix this.

I have also encountered this message, and I believe it is a bug.
I have uploaded a BugReport with a very small script and project that demonstrates it.
Case 19168

P.S. The bug was both in 2.0.0 and 2.0.2, which I just upgraded to.

…and 2.0.1, which I was using!

Yeah, I have been getting the same error messages too for 2.0.1 and 2.0.2. Here is my code:

// Chat Log
else if(logMode == LogMode.Chat)
{
	GUILayout.BeginArea(new Rect(Screen.width-190, 10, 180, 130));
		chatScroll = GUILayout.BeginScrollView(chatScroll);
			GUILayout.Label(chatText.ToString(),"leftalign",GUILayout.Width(179 - GUI.skin.verticalScrollbar.fixedWidth));
		GUILayout.EndScrollView();
	GUILayout.EndArea();
}

Any idea Nicholas if this will be looked into? I believe I can avoid it if I use GUI insead of GUILayout, but GUILayout as some auto resizing features for the text in scrollviews that I find indispensable in a lot of cases. I guess it is related to toggling a GUILayout on and off. When its toggled on each time, the three errors are generated.

Please file a bug that shows this in the simplest possible case, then I’ll take a look.

I did that exact thing a while ago. I’ll dig it up again if necessary.

…nevermind, I didn’t back up these files when I got my new computer, because I figured UT had it covered. I guess if there was any trouble with the files I sent, you could send them back to me, so I can help out more, but I remember thinking everything was pretty clear.

Ahh that one - I fixed that and closed it. If you have filed bugs with us, you get a URL in your reply mail which you can use to look at the status.