• General
  • BESCII the ASCII font for Basic Engine

uli Yes, I can fix that without problem. 👍
I'll do it as soon as possible.
I was also thinking: is it possible to create some sort of "graphic mode" that enable to put other available characters?
Just speaking my mind here. Don't know if possible or practical. But it would be nice to have more characters available.
If possible it would allow for many glyphs more to be used for creating games.
Edit: btw, if you want me to leave the original PETSCII characters as they are, I can do that. It's just that some are simply bad, and given the opportunity to fix them (and give BE a special flavour) seemed like too tempting a opportunity to miss... 😅

  • uli replied to this.

    Dmian Yes, I can fix that without problem. 👍
    I'll do it as soon as possible.

    Thank you. No rush, though.

    Dmian is it possible to create some sort of "graphic mode" that enable to put other available characters?

    Can you elaborate on what you mean by that?

    Dmian if you want me to leave the original PETSCII characters as they are, I can do that

    I think having a unique design is a good thing. Also the overall feel of the font is maintained, IMO.

      uli Can you elaborate on what you mean by that?

      Yes. What I was thinking was that maybe a key combination can be used to enable a further graphics mode.

      What I mean is: lets say you hit CTRL-ALT-' (the key to the left of one in the keyboard, for example). That enables a special "graphic mode" (with a different cursor to signal you're in that special mode). When you enable this mode, instead of the regular characters, you get a complete new set of characters from the same key combinations, that are mapped to a different place in Unicode. These could be the characters from the Pixel Art section, for example. This mode could be disabled by hitting the same key combination or the ESC key.

      The idea is to give easy access to more characters, without resorting to obscure key combinations, like the Alt-codes of the past. Because there's no easy way to use more characters from Unicode's higher planes than the ones already mapped to the keyboard. If I don't have a German keyboard, and I want to write an eszett, what can I do? This is normally solved with Alt-codes. It's a pretty obscure solution.

      But it's just an idea. I don't know if it's possible of practical.

      (Btw: when thinking about this, I remembered the Spectrum, where the cursor was modal and would change to allow you to type BASIC commands by just pressing one key. In the "command mode", pressing [P] will give you "PRINT". and it's this modal nature that made me think of this idea. But modal interfaces could be difficult to understand, if not implemented correctly).

      uli It seems to me that the PUA mapping is not identical to the C64 Pro Mono font, though. Could that be fixed?

      I'll need a little help from you here, because I've checked the font and there are several mappings included for any single character.
      Are the ones you need the ones they call "Direct PETSCII PUA mapping" from E020 to E0FF?
      They also have the inverted ones from E220 to E2FF. Do you need those too?
      There's a secondary PUA mapping for those same characters from EE20 to EEDE. Do you need that mapping too?

      I have my characters mapped to the regular Unicode mappings. I can add the PUA mappings without problems, just let me know which ones you need. The Pixel Art ones were from E000 to E052, but I'm moving them to F000 onwards, so there's no possible collision there.

      • uli replied to this.

        Dmian Look at petascii_to_utf8 in https://github.com/uli/basicengine-firmware/blob/nextgen/ttbasic/codepages.h
        The values on the right-hand side are the codepoints used for converting legacy programs to UTF-8. (I guess you can ignore the part that follows // from here identical to Amstrad CPC for this purpose.)

        The other bit to look at is the keyboard mapping in https://github.com/uli/basicengine-firmware/blob/nextgen/libraries/TTBAS_LIB/ps22tty.cpp, namely cbm_alt_keymap and cbm_gui_keymap. I don't know if there are any codepoints in there that are not in the conversion map, but it may be worth checking.

        The inverted codepoints are not used, and I don't think are really necessary.

          uli Perfect! I'll use that as a reference. Thanks.

          uli New version of Bescii! (v1.2)

          http://damianvila.com/bescii/bescii.ttf

          I mapped all the PUA characters to the PETSCII reference. Both your mappings and Tamakichi-san's mappings should be there (I checked, but if you see something missing, let me know.)

          I also mapped the Amstrad characters you have mapped to 0x20 to the following code points:

          [0xef] = 0xefef, (rocket symbol)
          [0xfc] = 0xeffc, (bomb symbol)
          [0xfd] = 0xeffd, (wtf? > cloud with lightning symbol)

          I'll include the same mapping in the Amstrad font, but I'll update that later, since I want to expand it to support more languages.

          And I modified a couple pixel art characters, and added a few more (they're remapped to f000-f067):

          Pixel Art 3

          Let me know what you think.

          Amstrad CPC 464 font updated to v1.1:

          http://damianvila.com/basicengine/cpc464.ttf

          Includes all Mac Roman and Windows 1252 characters (Western European languages), and the non-unicode characters mapping mentioned before.
          Edit: the uppercase Eszett is included, even though is not included in Mac Roman and Windows 1252.

          Alright, I have updated the CPC font and replaced C64 Pro Mono with BESCII. Excellent work, thanks a lot!

            uli Wonderful!
            Let me know if you need anything else with any other font.

            6 days later

            I couldn't contain myself, and created yet another font: ATASCII, based on Atari ASCII.

            ATASCII

            The glyphs are taken mainly from the Atari 8-bit family charset, with some from the Atari ST line (for example, the Hebrew glyphs and special chars), and a few modifications when the ST glyphs conflicted with the original glyphs.
            It has a very different flavour to PETSCII or Amstrad CPC 464 ASCII, since capital letters are smaller.

            You can get it here: https://damianvila.com/atascii/atascii.ttf

            I'm starting to publish all these on my GitHub:

            https://github.com/damianvila/font-bescii
            https://github.com/damianvila/font-cpc464

            When ready, this one will be at: https://github.com/damianvila/font-atascii (I still need to create the description and demo page).

            I hope you like it.

              Nice!

              Since you seem to be on a roll, could I be so bold as to request a 6x8 font? The HP 100 LX 6x8 font (which I got from https://int10h.org/oldschool-pc-fonts/fontlist/?2#hp) is quite nice, maybe it could be extended with Kana and whatever else is missing.

              The original BE had a 6x8 font with Katakana (https://github.com/uli/basicengine-firmware/blob/master/libraries/TTVoutfonts/font6x8tt.cpp), but I have removed it because it doesn't have a TTF version. Also, the Latin part is highly unattractive...

              [There is also a Japanese 6x8 with Kanji(!) at https://littlelimit.net/k6x8.htm, but I cannot open the TTF version of that in either Engine BASIC or fontforge; I don't know what's going on there. Either way, the author helpfully points out: "実用性極めて低し。" ("Very low practicality."). 😆 So I don't know if that helps with anything, maybe the Kana are usable.]

                uli No problem! I was planning on doing a 6x8, since I know you prefer that. 😉
                I'll try to make it as complete as possible, though kana in a 6x8 is really challenging, especially with the modifiers.

                (As a note: most kana or kanji pixel fonts I see are at least 12px tall. C64 is one of the few 8x8 one's out there).

                Edit: I just checked that 6x8 kanji... it's simply useless, as expected. You get a hint of the character, but need a lot of imagination to find out which one it is. 😛 The kana is useful. 👍

                uli Ok, here you have a first version. I called the font "Lexis" (for the "LX" in "100LX", which, by the way, comes from "Lotus eXpandable"):

                https://damianvila.com/lexis/lexis.ttf

                These are the included characters:

                Lexis chars

                They include all Mac Roman and Windows-1252 characters (for Western European Languages), Cyrillic, Hebrew, Greek (classic), Hiragana and Katakana (taken, from the 6x8 font you linked, I didn't want to take chances here, and prefer using something done by a Japanese person), all the included extra characters in the original font.

                Let me know what you think, or if you need anything else/different.

                It's in. Another excellent job, thanks a lot.

                10 days later
                4 months later

                Dmian
                I like the atascii font more than the other BASIC Engine fonts (maybe because my second computer in the 80s was a ATARI 600XL 😉 )
                Is there any way to make the atascii-Font the default font at bootup?
                Because it isnt one of the 4 default loaded font.
                @uli there isnt anything like a "AUTOEXEC.BAT" for the BASIC-Engine?
                Or can this be done in the config.ini?
                For now I have to
                CHDIR "/sys/fonts"
                FONT LOAD "atascii.ttf"
                FONT "atascii" SIZE 8,8

                BTW: Why cant I FONT LOAD "/sys/fonts/atascii.ttf" ?
                Gives me a Sytax error (expected numeric expression"

                • uli replied to this.

                  guidol @uli there isnt anything like a "AUTOEXEC.BAT" for the BASIC-Engine?

                  Yes, there is, and it's called -- wait for it -- AUTOEXEC.BAS. 😀

                  guidol BTW: Why cant I FONT LOAD "/sys/fonts/atascii.ttf" ?
                  Gives me a Sytax error (expected numeric expression"

                  Because it's LOAD FONT, not FONT LOAD.

                    uli
                    AUTOEXEC.BAS did work fine 😉

                    The font loading was my fault 🙁
                    because of "FONT "atascii" SIZE 8,8
                    I had in my head that the FONT keywork should also as the first in the other command 🙂
                    The right order of command and it did work with the full path.

                    Is the AUTOEXEC.BAS documented? Hadnt read it 🙁
                    BTW: where could I find the Z-Code-Interpreter which is also mention on the webpage for the NG version?

                    • uli replied to this.

                      Powered by: FreeFlarum.
                      (remove this footer)