Cycle 2 – DroidCo. Interface Development

For cycle two, I finished the development of the OSC interface for DroidCo. The interface consisted of a set of buttons that sent keywords to Isadora which would then be used to generate the virtual code for each team’s droid to run.

The interface (available in both an iPhone/iPod version and iPad version) consisted of two pages. The first contained the END command to complete code blocks, IF and WHILE to create conditional blocks, action keywords to trigger turn actions, and a delete button to remove lines of code. The second page contained all the conditionals that would be used with the IF and WHILE blocks.

To process these OSC inputs, I created a String builder javascript program. This program takes the next OSC input and adds it to a code string (the string the compiler from cycle 1 uses to create the virtual code) and a display string that shows the user their code (with proper indentation). Below is the code for this program.

function main(){
	var codeString = arguments[0];
	var displayString = arguments[1];
	var next = arguments[2];
	var ends = arguments[3];
	var i;
	switch(next){
		case "END ":
			codeString = codeString.concat(next);
			ends = ends - 1;
			for (i = 0; i < ends; i++){
				displayString = displayString.concat("\t");
			}
			displayString = displayString.concat(next);
			displayString = displayString.concat("\n");
			break;
		case "IF":
			codeString = codeString.concat(next);
			for (i = 0; i < ends; i++){
				displayString = displayString.concat("\t");
			}
			displayString = displayString.concat(next);
			ends = ends + 1;
			break;
		case "WHILE":
			codeString = codeString.concat(next);
			for (i = 0; i < ends; i++){
				displayString = displayString.concat("\t");
			}
			displayString = displayString.concat(next);
			ends = ends + 1;
			break;
		case "move ":
			codeString = codeString.concat(next);
			for (i = 0; i < ends; i++){
				displayString = displayString.concat("\t");
			}
			displayString = displayString.concat(next);
			displayString = displayString.concat("\n");
			break;
		case "turn-left ":
			codeString = codeString.concat(next);
			for (i = 0; i < ends; i++){
				displayString = displayString.concat("\t");
			}
			displayString = displayString.concat(next);
			displayString = displayString.concat("\n");
			break;
		case "turn-right ":
			codeString = codeString.concat(next);
			for (i = 0; i < ends; i++){
				displayString = displayString.concat("\t");
			}
			displayString = displayString.concat(next);
			displayString = displayString.concat("\n");
			break;
		case "skip ":
			codeString = codeString.concat(next);
			for (i = 0; i < ends; i++){
				displayString = displayString.concat("\t");
			}
			displayString = displayString.concat(next);
			displayString = displayString.concat("\n");
			break;
		case "hack ":
			codeString = codeString.concat(next);
			for (i = 0; i < ends; i++){
				displayString = displayString.concat("\t");
			}
			displayString = displayString.concat(next);
			displayString = displayString.concat("\n");
			break;
		case "back":
			if(codeString != "BEGIN "){
				if(codeString.substring(codeString.length - 4) == "END "){
					ends = ends + 1;
				}
				codeString = codeString.substring(0, codeString.lastIndexOf(" "));
				codeString = codeString.substring(0, codeString.lastIndexOf(" ")+1);
				displayString = displayString.substring(0, displayString.lastIndexOf(" "));
				displayString = displayString.substring(0, displayString.lastIndexOf(" ")+2);
			}
			break;
		default:
			codeString = codeString.concat(next);
			displayString = displayString.concat(next);
			displayString = displayString.concat("\n");
			break;
		}	
	var ret = new Array(codeString, displayString, ends);
	return ret;
}



Leave a Reply