You cannot select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
	
	
		
			199 lines
		
	
	
		
			7.3 KiB
		
	
	
	
		
			XML
		
	
			
		
		
	
	
			199 lines
		
	
	
		
			7.3 KiB
		
	
	
	
		
			XML
		
	
| vbox(margin = '10 10 0 0' clip = '0') ::
 | |
| {
 | |
| 	vbox(id = 'medit_basic' clip = '0') ::
 | |
| 	{
 | |
| 		//----------------
 | |
| 		// Tool
 | |
| 		//----------------
 | |
| 		switch(class = 'panel')(def='h2' selected = '1' text = 'Tool' size = '28')
 | |
| 		vbox ::
 | |
| 		{
 | |
| 			hbox(size = '28' next = '1') ::
 | |
| 			{
 | |
| 				button(onClick = 'full' text = 'Full' flex = '1' next = '1')(corner = '4')(hint = 'Full Volume [U]')
 | |
| 				button(onClick = 'fill' text = 'Fill' flex = '1')(corner = '8')(hint = 'Fill Voxels with Same Color [I]')
 | |
| 			}
 | |
| 
 | |
| 			hbox(size = '28' next = '2') ::
 | |
| 			{
 | |
| 				button(onClick = 'zero' text = 'Clear' flex = '1' next = '1')(hint = 'Clear Voxels [Backspace/Delete]')
 | |
| 				button(onClick = 'rev' text = 'Reverse*')(flex = '1')(hint = 'Reverse Empty Space')
 | |
| 			}
 | |
| 
 | |
| 			hbox(size = '28') ::
 | |
| 			{
 | |
| 				button(onClick = 'x2' text = '2X')(flex = '1' next = '1')(corner = '1')(hint = 'Double Size')
 | |
| 				button(onClick = 'xh' text = '1/2')(flex = '1' next = '0')(corner = '2')(hint = 'Half Size')
 | |
| 			}
 | |
| 		}
 | |
| 
 | |
| 		//----------------
 | |
| 		// Select
 | |
| 		//----------------
 | |
| 		switch(class = 'panel')(def='h2' selected = '1' text = 'Select' size = '28')
 | |
| 		vbox(next = '8') ::
 | |
| 		{
 | |
| 			hbox(size = '28' next = '1') ::
 | |
| 			{
 | |
| 				button(onClick = 'sel_all' text = 'Select All*')(flex = '1' next = '1' corner = '4')(hint = 'Select All [CTRL+A]')
 | |
| 				button(onClick = 'sel_inv' text = 'Inverse*')(flex = '1' corner = '8')(hint = 'Select Inverse [CTRL+I]')
 | |
| 			}
 | |
| 			hbox(size = '28' next = '2') ::
 | |
| 			{
 | |
| 				button(onClick = 'sel_none' text = 'None')(flex = '1')(hint = 'Select None [CTRL+D]')
 | |
| 			}
 | |
| 
 | |
| 			hbox(size = '28' next = '1') ::
 | |
| 			{
 | |
| 				button(onClick = 'copy' text = 'Copy')(flex = '1' next = '1')(hint = 'Copy Voxels [CTRL+C]')
 | |
| 				button(onClick = 'cut' text = 'Cut')(flex = '1')(hint = 'Cut Voxels [CTRL+X]')
 | |
| 			}
 | |
| 			hbox(size = '28') ::
 | |
| 			{
 | |
| 				button(onClick = 'paste' text = 'Paste')(flex = '1')(corner = '3')(hint = 'Paste Voxels [CTRL+V]')
 | |
| 			}
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	sp(id = 'medit_sep0')(def = 'bar-h' size = '3' prev = '4' next = '4')
 | |
| 	
 | |
| 	vbox(id = 'medit_tran' clip = '0') ::
 | |
| 	{
 | |
| 		//----------------
 | |
| 		// Rot
 | |
| 		//----------------
 | |
| 		switch(class = 'panel')(def='h2' selected = '0' text = 'Rotate 90' size = '28')
 | |
| 		hbox(size = '28' )(hint = 'Rotate Model 90 Degrees') ::
 | |
| 		{
 | |
| 			button(onClick = 'rot90 x' text = 'X')(flex = '1' next = '1' corner = '5')
 | |
| 			button(onClick = 'rot90 y' text = 'Y')(flex = '1' next = '1')
 | |
| 			button(onClick = 'rot90 z' text = 'Z')(flex = '1' corner = '10')
 | |
| 		}
 | |
| 
 | |
| 		//----------------
 | |
| 		// Flip
 | |
| 		//----------------
 | |
| 		switch(class = 'panel')(def='h2' selected = '0' text = 'Flip' size = '28')
 | |
| 		hbox(size = '28' )(hint = 'Flip Model') ::
 | |
| 		{
 | |
| 			button(onClick = 'flip x' text = 'X' flex = '1' next = '1')(corner = '5')
 | |
| 			button(onClick = 'flip y' text = 'Y' flex = '1' next = '1')
 | |
| 			button(onClick = 'flip z' text = 'Z' flex = '1')(corner = '10')
 | |
| 		}
 | |
| 
 | |
| 		//----------------
 | |
| 		// Loop
 | |
| 		//----------------
 | |
| 		switch(class = 'panel')(def='h2' selected = '0' text = 'Loop' size = '28')
 | |
| 		vbox(hint = 'Move Model') ::
 | |
| 		{
 | |
| 			hbox(size = '28' next = '1') ::
 | |
| 			{
 | |
| 				button(onClick = 'loop x +1' text = '+X' repeated = '1')(corner = '4')(flex = '1'  next = '1')
 | |
| 				button(onClick = 'loop y +1' text = '+Y' repeated = '1')(flex = '1'  next = '1')
 | |
| 				button(onClick = 'loop z +1' text = '+Z' repeated = '1')(corner = '8')(flex = '1')
 | |
| 			}
 | |
| 
 | |
| 			hbox(size = '28') ::
 | |
| 			{
 | |
| 				button(onClick = 'loop x -1' text = '-X' repeated = '1')(corner = '1')(flex = '1'  next = '1')
 | |
| 				button(onClick = 'loop y -1' text = '-Y' repeated = '1')(flex = '1'  next = '1')
 | |
| 				button(onClick = 'loop z -1' text = '-Z' repeated = '1')(corner = '2')(flex = '1')
 | |
| 			}
 | |
| 		}
 | |
| 
 | |
| 		switch(class = 'panel')(def='h2' selected = '0' text = 'Scale' size = '28')
 | |
| 		textField(onEnter = 'scale' default = 'axis scale' text = 'xyz 2' maxLength = '30' bgColor = '40 40 40')
 | |
| 		(size = '28')
 | |
| 		(hint = 'Scale Model : [Axis] [Scale]')
 | |
| 
 | |
| 		switch(class = 'panel')(def='h2' selected = '0' text = 'Shear' size = '28')
 | |
| 		textField(onEnter = 'shear' default = 'axis scale' text = 'z 0.2 0.2' maxLength = '30' bgColor = '40 40 40')
 | |
| 		(size = '28')
 | |
| 		(hint = 'Shear Model : [Axis] [Scale]')
 | |
| 		
 | |
| 		switch(class = 'panel')(def='h2' selected = '0' text = 'Rotate' size = '28')
 | |
| 		textField(onEnter = 'rot' default = 'axis angle' text = 'z 45' maxLength = '30' bgColor = '40 40 40')
 | |
| 		(size = '28')
 | |
| 		(hint = 'Rotate Model : [Axis] [Angle]')
 | |
| 
 | |
| 		switch(class = 'panel')(def='h2' selected = '0' text = 'Repeat' size = '28')
 | |
| 		textField(onEnter = 'repeat' default = 'axis scale' text = 'xy 2' maxLength = '30' bgColor = '40 40 40')
 | |
| 		(size = '28' next = '6')
 | |
| 		(hint = 'Repeat Model : [Axis] [Scale]')
 | |
| 	}
 | |
| 
 | |
| 	sp(id = 'medit_sep1')(def = 'bar-h' size = '3' prev = '4' next = '4')
 | |
| 	
 | |
| 	vbox(id = 'medit_mod' clip = '0') ::
 | |
| 	{
 | |
| 		//----------------
 | |
| 		// Sym
 | |
| 		//----------------
 | |
| 		switch(class = 'panel')(def='h2' selected = '0' text = 'Mirror' size = '28')
 | |
| 		hbox(size = '28')(hint = 'Mirror') ::
 | |
| 		{
 | |
| 			button(onClick = 'mir x' text = 'X' repeated = '1')(corner = '5')(flex = '1' next = '1')
 | |
| 			button(onClick = 'mir y' text = 'Y' repeated = '1')(flex = '1' next = '1')
 | |
| 			button(onClick = 'mir z' text = 'Z' repeated = '1')(corner = '10')(flex = '1')
 | |
| 		}
 | |
| 
 | |
| 		switch(class = 'panel')(def='h2' selected = '0' text = 'Diagonal' size = '28')
 | |
| 		hbox(size = '28')(hint = 'Diagonal') ::
 | |
| 		{
 | |
| 			button(onClick = 'dia x' text = 'X' repeated = '1')(corner = '5')(flex = '1' next = '1')
 | |
| 			button(onClick = 'dia y' text = 'Y' repeated = '1')(flex = '1' next = '1')
 | |
| 			button(onClick = 'dia z' text = 'Z' repeated = '1')(corner = '10')(flex = '1')
 | |
| 		}
 | |
| 		
 | |
| 		//----------------
 | |
| 		// Prim
 | |
| 		//----------------
 | |
| 		switch(class = 'panel')(def='h2' selected = '0' text = 'Shape' size = '28')
 | |
| 		vbox ::
 | |
| 		{
 | |
| 			hbox(size = '28' next = '1') ::
 | |
| 			{
 | |
| 				button(onClick = 'prim elli'	text = 'Ellipsoid'	flex = '1' next = '1')(corner = '4')(hint = 'Ellipsoid')
 | |
| 				button(onClick = 'prim cyli'	text = 'Cylinder'	flex = '1')(corner = '8')(hint = 'Cylinder')
 | |
| 			}
 | |
| 			hbox(size = '28' next = '1') ::
 | |
| 			{
 | |
| 				button(onClick = 'prim pyra'	text = 'Pyramid'	flex = '1' next = '1')(hint = 'Pyramid')
 | |
| 				button(onClick = 'prim cone'	text = 'Cone'	flex = '1')(hint = 'Cone')
 | |
| 			}
 | |
| 			hbox(size = '28' next = '1') ::
 | |
| 			{
 | |
| 				button(onClick = 'maze'		text = 'Maze'	flex = '1' next = '1')(hint = 'Maze')
 | |
| 				button(onClick = 'noise -1'	text = 'Perlin'	flex = '1')(hint = 'Perlin Noise')
 | |
| 			}
 | |
| 			hbox(size = '28') ::
 | |
| 			{
 | |
| 				button(onClick = 'fractal' text = 'Fractal')(flex = '1' corner = '3')(hint = 'Fractal Model with Patterns')
 | |
| 			}
 | |
| 		}
 | |
| 		
 | |
| 		//----------------
 | |
| 		// Modify
 | |
| 		//----------------
 | |
| 		switch(class = 'panel')(def='h2' selected = '0' text = 'Modify' size = '28')
 | |
| 		vbox ::
 | |
| 		{
 | |
| 			hbox(size = '28' next = '1') ::
 | |
| 			{
 | |
| 				button(onClick = 'flood 0' text = 'Hull')(flex = '1' next = '1')(corner = '4')(hint = 'Remove All Invisible Voxels')
 | |
| 				button(onClick = 'flood'   text = 'Flood')(flex = '1')(corner = '8')(hint = 'Flood Fill All Invisible Space')
 | |
| 			}
 | |
| 			hbox(size = '28' next = '1') ::
 | |
| 			{
 | |
| 				button(onClick = 'mask' text = 'Mask')(flex = '1' next = '1')(hint = 'Mask Model with Patterns')
 | |
| 				button(onClick = 'tex'	text = 'Texture')(flex = '1')(hint = 'Texture Model with Patterns')
 | |
| 			}
 | |
| 			hbox(size = '28') ::
 | |
| 			{
 | |
| 				button(onClick = 'dil' repeated = '1'	text = 'Dilation')(flex = '1' next = '1')(corner = '1')(hint = 'Dilation')
 | |
| 				button(onClick = 'ero' repeated = '1'	text = 'Erosion')(flex = '1')(corner = '2')(hint = 'Erosion')
 | |
| 			}
 | |
| 		}
 | |
| 	}
 | |
| } |