How to restrict a textfield to numbers only

I am learning and teaching myself scripting with unity, but ran into a brick wall when trying to figure out how to force a player to only enter numbers into a gui textfield.

Google and the forums here had some ideas, but all were long and confusing for something that I felt should be fairly simple. I finally figured it out, so thought I would share here in case any others starting out run into the same wall I did.

function stringIsInt(testString:String) {

	try {
		testString = "" + parseInt(testString);
		}
	catch(err) {
		testString = "0";
		}
	return testString;
}

What this does is take the string (text entered by the user in the textfield) and try to convert it to an integer, and then overwrite the string with that number.
If it is not able to do this, then it will overwrite the string with the number β€œ0”.

With that function in place all you need to do for your textfield is this,

	myNumberTextField = GUI.TextField(Rect (10,10,25,100),myNumberTextField);
	myNumberTextField = stringIsInt(myNumberTextField);

This places the textfield on your screen and puts the user input into the string myNumberTextField.
Then it enters that string into the function you just wrote and overwrites it with the results, which in turn update the text in the field.

So, if the user enters the following text, this is what will be displayed. (in the same box they are typing in, so if they type something not allowed it is changed instantly)

β€œ00” = β€œ0”
β€œ01” = β€œ1”
β€œ1” = β€œ1”
β€œasdf” = β€œ0”
β€œ12df” = β€œ0”
β€œdf12” = β€œ0”

This worked perfectly for what I was needing, but then I thought, β€œwhat if I wanted a different default number than β€œ0”? or what if I wanted to limit the range of numbers allowed?”

So I refined it and added some more options,

function stringIsInt(testString:String) {

	try {
		testString = "" + parseInt(testString);
		}
	catch(err) {
		testString = "0";
		}
	return testString;
}

function stringIsInt(testString:String,defaultNum:int,minNumber:int,maxNumber:int) {


	if (defaultNum < minNumber || defaultNum > maxNumber) {
		defaultNum = 0;
		minNumber = 0;
		maxNumber = 0;
		}
	try {
		testString = "" + parseInt(testString);
		}
	catch(err) {
		testString = defaultNum.ToString();
		}
		
	if (!(minNumber <= parseInt(testString)  parseInt(testString) <= maxNumber)) {
		testString = defaultNum.ToString();
		}
		
	return testString;
}

Now you can use this function as I originally intended with the default number it resets to as β€œ0” and no limit to the range, or you can define the default and range.
The second option here is a little more complex, but still fairly simple.

First it checks if the default number entered falls within the range specified it sets the default, min and max all to 0.
Then it does the same check as before to see if it can be converted to an integer.
This time though, if it can not be set to an integer, it sets it to the specified default number instead of β€œ0” like we did earlier.
Then it checks to see if the number falls within the range specified, and if not sets it to default.

I am just learning, so if any experts have comments on how to do this better I am open to suggestions. I had a hard time googling this though so wanted to get it out here for discussion or reference.

have fun :slight_smile:

narfi

–Eric

1 Like

Thanks eric, I had seen that and other similar things, but most recomendations of regix were followed with warnings that it was a bad way of doing things.
I have since talked to someone and they told me that regix used to require extra libraries or resources, but now is a cleaner method than it used to be so is probably acceptable now.

What are your thoughts, pros and cons of the method i chose vs using regix?

Read (and use :wink: ) my answer to that question. Honestly it’s the most effective method since it doesn’t involve string manipulations and so on; read Molix’s comment on my answer. Nothing has changed regarding regex.

–Eric