| 
									
										
										
										
											2016-09-23 16:26:03 -03:00
										 |  |  | Software cursor for VGA
 | 
					
						
							|  |  |  | =======================
 | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-23 16:26:03 -03:00
										 |  |  | by Pavel Machek <pavel@atrey.karlin.mff.cuni.cz>
 | 
					
						
							|  |  |  | and Martin Mares <mj@atrey.karlin.mff.cuni.cz>
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-12-13 11:18:24 -08:00
										 |  |  | Linux now has some ability to manipulate cursor appearance.  Normally,
 | 
					
						
							|  |  |  | you can set the size of hardware cursor.  You can now play a few new
 | 
					
						
							|  |  |  | tricks: you can make your cursor look like a non-blinking red block,
 | 
					
						
							|  |  |  | make it inverse background of the character it's over or to highlight
 | 
					
						
							|  |  |  | that character and still choose whether the original hardware cursor
 | 
					
						
							|  |  |  | should remain visible or not.  There may be other things I have never
 | 
					
						
							|  |  |  | thought of.
 | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-23 16:26:03 -03:00
										 |  |  | The cursor appearance is controlled by a ``<ESC>[?1;2;3c`` escape sequence
 | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | where 1, 2 and 3 are parameters described below. If you omit any of them,
 | 
					
						
							|  |  |  | they will default to zeroes.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-23 16:26:03 -03:00
										 |  |  | first Parameter
 | 
					
						
							|  |  |  | 	specifies cursor size::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		0=default
 | 
					
						
							|  |  |  | 		1=invisible
 | 
					
						
							|  |  |  | 		2=underline,
 | 
					
						
							|  |  |  | 		...
 | 
					
						
							|  |  |  | 		8=full block
 | 
					
						
							|  |  |  | 		+ 16 if you want the software cursor to be applied
 | 
					
						
							|  |  |  | 		+ 32 if you want to always change the background color
 | 
					
						
							|  |  |  | 		+ 64 if you dislike having the background the same as the
 | 
					
						
							|  |  |  | 		     foreground.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	Highlights are ignored for the last two flags.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | second parameter
 | 
					
						
							|  |  |  | 	selects character attribute bits you want to change
 | 
					
						
							|  |  |  | 	(by simply XORing them with the value of this parameter). On standard
 | 
					
						
							|  |  |  | 	VGA, the high four bits specify background and the low four the
 | 
					
						
							|  |  |  | 	foreground. In both groups, low three bits set color (as in normal
 | 
					
						
							|  |  |  | 	color codes used by the console) and the most significant one turns
 | 
					
						
							|  |  |  | 	on highlight (or sometimes blinking -- it depends on the configuration
 | 
					
						
							|  |  |  | 	of your VGA).
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | third parameter
 | 
					
						
							|  |  |  | 	consists of character attribute bits you want to set.
 | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-23 16:26:03 -03:00
										 |  |  | 	Bit setting takes place before bit toggling, so you can simply clear a
 | 
					
						
							|  |  |  | 	bit by including it in both the set mask and the toggle mask.
 | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-10-26 16:14:52 -06:00
										 |  |  | Examples
 | 
					
						
							|  |  |  | --------
 | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-23 16:26:03 -03:00
										 |  |  | To get normal blinking underline, use::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	echo -e '\033[?2c'
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | To get blinking block, use::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	echo -e '\033[?6c'
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | To get red non-blinking block, use::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	echo -e '\033[?17;0;64c'
 |