The ATASCII character set, from ATARI Standard Code for Information Interchange, alternatively ATARI ASCII, is a character encoding used in the Atari 8-bit family of home computers. ATASCII is based on ASCII, but is not fully compatible with it.
The first computers in the Atari 8-bit family are the Atari 400 and 800, released in 1979, and later models were released throughout the 1980s. The last computer to use the ATASCII character set is the Atari XEGS, which was released in 1987 and discontinued in 1992. The Atari ST family of computers use the different Atari ST character set.
Like most other variants of ASCII, ATASCII has its own distinct characters (arrows, blocks, box-drawing characters, playing card suits, etc.) in place of the C0 control codes in ASCII (characters 0–31), as well as replacing a few other ASCII code points.
Implementation
Atari 8-bit systems have three distinct sets of codes: interchange codes (ATASCII), internal codes (also called screen codes), and keyboard codes.[1][2]
Keyboard codes represent the codes sent by the keyboard. Pressing one of the two modifier keys (Shift and Control) modifies the value input by pressing other keys. Due to there being two modifier keys, there are four distinct keyboard codes that can be sent by each character; however, several keys (the exact keys depend on the model) do not send a control code if they are pressed while holding both Shift and Control.[1] When entering text, the Atari keyboard handler converts these signals into ATASCII.[3]
ATASCII and internal codes contain the same character set, but indexed differently. ATASCII codes are used by BASIC, while internal codes are used to look up how to render the character on-screen.[1]
Atari 8-bit systems have several distinct graphics modes; these modes can be classified as pure text modes, pure graphics modes, or mixed modes. Modes 0, 1 and 2 represent pure text modes, while Modes 3 and above represent mixed or pure graphics modes (the exact number of distinct modes depending on the model).[4] Mode 0 displays characters at the default size, Mode 1 displays them twice as wide (but the same height), and Mode 2 displays them twice as wide and twice the height.[4] Mode 0 is the default graphics mode and supports 128 unique characters in one of two colors (regular or inverse video, depending on the upper bit); Modes 1 and 2 only support 64 unique characters, but support four different colors (as they use the upper two bits as color information instead).[2] The 64 characters available in Modes 1 and 2 are the first 64 characters in the internal code, which correspond to ASTASCII codes 32 to 95 (0x20 to 0x5F).[3] This includes all uppercase letters and punctuation, but excludes lowercase letters and graphics characters.
The Atari screen editor implements the text cursor by simply inverting the character at the cursor position (by XOR with 0x80). It does not flash.
Inverse video
ATASCII only has 128 unique graphic characters, with the upper 128 graphic characters (index 128 to 255) being inverse video variants of the lower 128 graphic characters (index 0 to 127). If the high-order bit is set on a character (i.e., if the byte value of the character is between 128 and 255), the character is generally rendered as the inverse video variant of its counterpart between 0 and 127, using a bitwise negation of the character's glyph. This is done by the ANTIC chip.
Due to this behavior, there is asymmetry in the selection of block-drawing characters. In normal video, there are lower triangles but no upper triangles, a left half block but no right half block, and a lower half block but no upper half block; these ostensibly missing characters can be displayed by using inverse video.
Alternate character sets
Atari 8-bit computers, via the ANTIC coprocessor, supported indirection of the character set graphics, allowing a program to redefine the graphical glyphs that appear for each ATASCII character.[2] This can be used as a new font for text, to support an additional character set, or for tile graphics in a video game or other application. Cycling between multiple redefined character sets can be used to provide simple animation at very little CPU cost (in exchange for memory used to store the character set data). Altering a character set in RAM can also be used for animation.
In the XL and XE lines, the Atari OS ROM includes an "international character set" that replaces 29 of the graphical glyphs with Latin alphabetical characters containing diacritics, such as e-acute (é). The OS built into the Atari 1200XL, the only Atari 8-bit model with function keys, allowed users to switch between the standard and alternate character sets by pressing CTRL+F4.[5] Later XL and XE models required the user to update a register in RAM (e.g., via a POKE command in BASIC).[2]
In some regions, a different character set was included instead of the default international character set, in order to better accommodate the target market, including Polish, Arabic, and Hebrew. Atari 192XT and 256XT systems distributed in Eastern Europe by P.Z.Karen had a Polish character set in place of the international character set.[6][7] The Atari 65XE Najm, which was distributed in the Middle East, has an Arabic character encoding as its default encoding and displays text right-to-left, while the international character set was replaced by the standard ATASCII encoding.[7][8][9][10] Hebrew versions of the Atari 600XL and 800XL were distributed in Israel, which had a Hebrew character set in place of the international character set. The Hebrew character set had Hebrew letters instead of lowercase Latin letters, but preserved the uppercase Latin letters. When typing in Hebrew mode, typing Latin letters advances the cursor to the right, while typing Hebrew letters advances the cursor to the left.[7][11]
Character set
Default graphic characters
The following table shows the default ATASCII character set. Control characters with a graphic representation are displayed using that representation. Each character is shown with a Unicode equivalent.
ATASCII[12][13] | ||||||||||||||||
0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | A | B | C | D | E | F | |
0x | ♥ | ├ | 🮇 | ┘ | ┤ | ┐ | ╱ | ╲ | ◢ | ▗ | ◣ | ▝ | ▘ | 🮂 | ▂ | ▖ |
1x | ♣ | ┌ | ─ | ┼ | • | ▄ | ▎ | ┬ | ┴ | ▌ | └ | ␛ | ↑ | ↓ | ← | → |
2x | SP | ! | " | # | $ | % | & | ' | ( | ) | * | + | , | - | . | / |
3x | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | : | ; | < | = | > | ? |
4x | @ | A | B | C | D | E | F | G | H | I | J | K | L | M | N | O |
5x | P | Q | R | S | T | U | V | W | X | Y | Z | [ | \ | ] | ^ | _ |
6x | ♦ | a | b | c | d | e | f | g | h | i | j | k | l | m | n | o |
7x | p | q | r | s | t | u | v | w | x | y | z | ♠ | | | 🢰 | ◀ | ▶ |
8x | ♥ | ├ | ▊ | ┘ | ┤ | ┐ | ╱ | ╲ | ◤ | ▛ | ◥ | ▙ | ▟ | ▆ | 🮅 | ▜ |
9x | ♣ | ┌ | ─ | ┼ | ◘ | ▀ | 🮊 | ┬ | ┴ | ▐ | └ | EOL | ↑ | ↓ | ← | → |
Ax | █ | ! | " | # | $ | % | & | ' | ( | ) | * | + | , | - | . | / |
Bx | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | : | ; | < | = | > | ? |
Cx | @ | A | B | C | D | E | F | G | H | I | J | K | L | M | N | O |
Dx | P | Q | R | S | T | U | V | W | X | Y | Z | [ | \ | ] | ^ | _ |
Ex | ♦ | a | b | c | d | e | f | g | h | i | j | k | l | m | n | o |
Fx | p | q | r | s | t | u | v | w | x | y | z | ♠ | - | 🢰 | ◀ | ▶ |
The box-drawing characters are arranged relative to their corresponding letter keys on the Atari keyboard, appearing 64 code points earlier than the corresponding uppercase letter. For example, ┌, ┬, and ┐ are the graphics characters found on the top left Q, W, and E keys, and appear 64 code points before those uppercase letters in ATASCII.
International character set
The following table shows the lower half of ATASCII international character set. The upper half are inverse video variants of the lower half, in exactly the same way as the standard ATASCII character set.
ATASCII international character set[14] | ||||||||||||||||
0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | A | B | C | D | E | F | |
0x | á | ù | Ñ | É | ç | ô | ò | ì | £ | ï | ü | ä | Ö | ú | ó | ö |
1x | Ü | â | û | î | é | è | ñ | ê | å | à | Å | ␛ | ↑ | ↓ | ← | → |
2x | SP | ! | " | # | $ | % | & | ' | ( | ) | * | + | , | - | . | / |
3x | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | : | ; | < | = | > | ? |
4x | @ | A | B | C | D | E | F | G | H | I | J | K | L | M | N | O |
5x | P | Q | R | S | T | U | V | W | X | Y | Z | [ | \ | ] | ^ | _ |
6x | ¡ | a | b | c | d | e | f | g | h | i | j | k | l | m | n | o |
7x | p | q | r | s | t | u | v | w | x | y | z | Ä | | | 🢰 | ◀ | ▶ |
Differs from standard ATASCII
|
Control characters
ATASCII has 16 control characters, defined in four separate ranges (0x1B to 0x1F, 0x7D to 0x7F, 0x8B to 0x8F, and 0xFD to 0xFF).[15] This is a key difference between ASCII and ATASCII—in ASCII, there are 32 control characters, defined in the range 0 to 31 (0x00 to 0x1F).
All ATASCII control characters except End of Line (0x9B) have a graphic representation, which can be produced by escaping that character by pressing the Escape key before inputting that control character.[15] For example, typing "Escape" followed by "cursor right" will produce a right arrow. Uniquely, the End of Line control character always renders a newline, regardless of the presence of a preceding escape character.[15]
Hex | Decimal | Function | Keystroke |
---|---|---|---|
1B | 27 | Escape key | ESC |
1C | 28 | Cursor Up | CTRL+- |
1D | 29 | Cursor Down | CTRL+= |
1E | 30 | Cursor Left | CTRL++ |
1F | 31 | Cursor Right | CTRL+* |
7D | 125 | Clear Screen | CTRL+< or ⇧ Shift+< |
7E | 126 | Delete | ← Backspace |
7F | 127 | Tab | Tab ↹ |
9B | 155 | End of line | RETURN |
9C | 156 | Delete Line | ⇧ Shift+← Backspace |
9D | 157 | Insert Line | ⇧ Shift+> |
9E | 158 | Clear Tab stop | CTRL+Tab ↹ |
9F | 159 | Set Tab stop | ⇧ Shift+Tab ↹ |
FD | 253 | Buzzer | CTRL+2 |
FE | 254 | Delete Character | CTRL+← Backspace |
FF | 255 | Insert Character | CTRL+> |
Inter-operation
The differences between character representation can cause problems during modem communication between Ataris and other computers. Cursor movement commands (and even carriage returns and line feeds) from computers not using ATASCII will be nonsense on an Atari, and vice versa. Terminal programs need to translate between ATASCII and standard ASCII.
Some Atari-based BBSs exploited this difference by asking the client to hit the "Return" key. If it got 13 (ASCII CR), then standard ASCII would be used. If it got 155 (ATASCII CR) it would switch to ATASCII, allowing full use of the ATASCII graphic set. Some Atari BBSs would also block features (or even block access completely) for non-Atari users.
Text files encoded in ATASCII also need conversion to be viewed on modern PCs and vice versa—utilities are available to facilitate this.[16]
ATASCII animations
The control codes in ATASCII are transmissible to other computers such as BBSs, and crude animations are possible. These animations, also known as "break movies", often take the form of short cartoons, and were a popular feature of Atari BBSs in their heyday.[17]
Because cursor control operations are represented with a single character (as opposed to multi-byte sequences that were common in other schemes, like ANSI or VT100), it is quite easy to make these animations. They can be created by a short BASIC program that captures keyboard commands, echoes them to the screen and saves them to a file.[18] The Atari also allowed commands to be typed and captured as part of its operating system. Of course this required care to get it right, but after a few attempts it normally became quite easy. The simple capture programs didn't have editing features, so ATASCII movies frequently had errors that were corrected by repositioning the cursor and printing over the mistake.
See also
References
- 1 2 3 Card, Orson Scott (1984). "Reading the Keyboard Codes". Compute!'s Third Book of Atari. Compute! Books. ISBN 978-0-942386-18-9.
- 1 2 3 4 Wilkinson, Bill (March 1986). "INSIGHT: Atari—Atari Character Codes". Compute!. Vol. 8, no. 70. Compute! Publications. pp. 112–113. ISSN 0194-357X.
- 1 2 3 Chadwick, Ian (1985). "Appendix 10 - ATASCII And Internal Character Code Values". Mapping the Atari (Revised ed.). Compute! Books. pp. 180–181. ISBN 0874550041.
- 1 2 Halfhill, Tom R. (1982). "The Basics of Atari Graphics". Compute!'s First Book of Atari Graphics. Compute! Books. ISBN 978-0-942386-08-0.
- ↑ The Atari 1200XL Home Computer Owner's Guide. Atari. 1982.
- ↑ "ATASCII". Atariki (in Polish). 5 May 2020.
- 1 2 3 Current, Michael (29 May 2023). "Atari 8-Bit Computers Frequently Asked Questions List". comp.sys.atari.8bit newsgroup. Retrieved 29 November 2023.
- ↑ Nosty (2007-07-13). "Atari Allacha". Atari Online.pl (in Polish).
- ↑ Parent, Eric. "ATASCII Character Sets". Joyful Coder. Archived from the original on 16 March 2016.
- ↑ Savetz, Kevin (19 November 2003). "Exploring the "Star" Arabic Atari 65 XE". Atari 8-Bit Computer WebRing. Retrieved 29 November 2023.
- ↑ The Modern Atari 8bit computer (11 October 2017). "Hebrew ATARI XL Computer". YouTube. Retrieved 29 November 2023.
{{cite web}}
: CS1 maint: numeric names: authors list (link) - ↑ Bettencourt, Rebecca G. "ATASCII to Unicode Mapping". Kreative Korp.
- ↑ Bettencourt, Rebecca (2018-04-20), "ATARI8IG.TXT", L2/19-025: Proposal to add characters from legacy computers and teletext to the UCS (PDF)
- ↑ Bettencourt, Rebecca (2018-04-20), "ATARI8II.TXT", L2/19-025: Proposal to add characters from legacy computers and teletext to the UCS (PDF)
- 1 2 3 Atari 400/800: Atari Home Computer Operating System User's Manual. Atari. 1982. pp. 68–70, 183–184.
- ↑ "ATASCII". Just Solve the File Format Problem.
- ↑ "AtasciiTube". Break Into Chat.
- ↑ Ratcliff, Matthew (August 1985). "Atari 'Toons". Antic. Vol. 4, no. 4.