- Consio::clrscr
- Clears screen (console buffer).
- Consio::gotoxy x y
- Sets a new cursor location to (x;y).
- Consio::wherex
- Returns the X position of the cursor in the console buffer.
- Consio::wherey
- Returns the Y position of the cursor in the console buffer.
- Consio::bufferwidth
- Returns the width of the console buffer.
- Consio::bufferheight
- Returns the height of the console buffer.
- Consio::getch
- Waits for single key press.
- Consio::getche
- Waits for single key press and echoes it back to the console.
- Consio::putch chr
- Inserts a character to the cursor location.
- Consio::kbhit
- checks if there are any keystokes waiting in the input buffer. This function doesn't block or remove anything from the buffer. The function will return 1 if there are keystrokes waiting in the input buffer. Otherwise returns 0.
- Consio::textattr foreground background
- Sets foreground and background color. Available color attributes for both foreground and background color are:
black blue green cyan red magenta brown lightgray darkgray lightblue lightgreen lightcyan lightred lightmagenta yellow white - Consio::cputs ?-nonewline? string
- Prints string to standard output. If -nonewline is specified, then then the newline will not be printed at the end of the line.
- Consio::cgets
- Reads keystrokes from the console until Enter key is pressed. Linefeed or newline characters are not included in the result.
- Consio::cgetse
- Reads keystrokes from the console and echoes them back until the Enter key is pressed. Linefeed or newline characters are not included in the results.
- Consio::getchex
- Extended getch. Getch is unable to return a meaningful code for all keys. For example, there is no easy way to return arrow keys as a single character. Getchex works like getch except it will return key presses as an integer value. This way it's possible to receive a code from all keys, including shifts, function keys, arrows etc. The code is device-independent and defined by Windows.
- Consio::getkeystate
- See GetAsyncKeyState in MSDN
- Consio::getch2
- Waits for a keypress. Doesn't echo it to the console. This is a replacement for Consio::getch function. This is based on MSVCRT implementation. See more information here: getch in MSDN
mjk 2005-10-17: At the moment, this library has been tested only under Windows XP. All feedback is welcome and I would appreciate it greatly if people would tell me, how the library works under different flavors of Windows. The feedback can be appended to this page or sent directly to me (e-mail address is included in the package).jmn 2005-10-18 Nice work - thanks for sharing.It works fine on my old Windows NT & 2000 server boxes.A consequence of course of using ReadConsole instead of lower level Console API functions such as ReadConsoleInput; is that Consio as it stands doesn't catch certain keys such as arrows, delete, end etc.. Perhaps 'press any key' in the demo should be qualified a little - otherwise the old joke about lusers hunting for the key marked 'any' just isn't as funny ;)LES: this is very nice, and seems to work in my Windows 98. I couldn't make getch and getche work, but I suspect I just did something wrong.mjk 2005-10-20: jmn, the "any key" issue will be fixed in next version, so no stupid user will be lost in the quest for finding the "any key" :) LES, I'm afraid that there is a small possibility that (at least at this point) this library will not work flawlessly under Windows 9x. Microsoft documentation claims that all functions I'm using are supported under older operating systems, but I'm not sure, if I can trust that. But I'm going to study this issue further at some point.mjk 2005-10-20: Well, there is now the version 0.2 available and it among other things has an extended version of the getch command called "getchex", which will capture any keypress from the console and return a key code.mjk 2017-06-10: Almost 12 years has passed and here we are, with a new version :) For source code and compiled binaries, please see the description above. The main reason for this release is the new command: Consio::getch2, which allows capturing key combinations, for example Alt+F1 and also recognizes arrow keys etc. with modifiers (Alt+arrow up, etc.)
Here's a conversation about this page, from the TkChat channel, on 2006-03-14. willdye
<mAcZ> is there possible to write "raw" to console? <mAcZ> windows console supports command "prompt" which can allows ASCII <mAcZ> and i wanna try to use this tclguy ?? kbk mAcZ - What are you trying to do, in more general terms. <mAcZ> i wanna use ascii chars in windows console, to use color for text aku I would say that you want ANSI sequences, not ASCII kbk Windows console - the black thing from a command line application, or the Wish console? The answers are different for the two. <mAcZ> the black thing * kbk tries to remember what's to be done for the Windows console - suspects that the answer is "it's not easy." tclguy that requires C API stuff IIRC, not just terminal control codes like a unix tty kbk tclguy - ISTR there's a way to jigger a Command Prompt to take ANSI escape sequences, but don't remember what it is. (And I don't remember whether it takes C code that we don't have) kbk console I/O extension - http://wiki.tcl.tk/14850 <mAcZ> AH! <mAcZ> perfect, big thanks * kbk bows. :)
What a pitty that this package didn't get further... And unfortunally, there's no modern CTk available for win32.APN TWAPI's console module provides (I believe) a superset of these commands. MHo Yes. But what's really neaded is a cross platform CTk, otherwise one had to reinvent the wheel... And TWAPI, consio and ::term are not crossplattform. It's simply not possible to develop cross-platform tcl apps with a tui interface.