1.2 / December 30, 2017
|OS||Microsoft Windows, Linux, macOS|
QB64 (originally QB32) is a self-hosting BASIC compiler for Microsoft Windows, Linux and Mac OS X, designed to be compatible with Microsoft QBasic and QuickBASIC. QB64 is a C++ emitter, which is integrated with a C++ compiler to provide compilation via C++ code and GCC optimization.
QB64 implements most QBasic statements, and can run many QBasic programs, including Microsoft's QBasic Gorillas and Nibbles games. Furthermore, QB64 has been designed to contain an IDE resembling the QBASIC IDE. QB64 also extends the QBASIC programming language to include 64-bit data types, as well as better sound and graphics support. It can also emulate some DOS/x86 specific features such as INT 33h mouse access, and multiple timers.
QB64 was originally compiled with QuickBASIC 4.5. After significant development, Rob Galleon, the developer, became hindered by QuickBASIC's memory limitations and switched to Microsoft Basic PDS 7.1, which solved these problems for a short time. After version 0.63, QB64 was able to compile itself so the Conventional memory limitations no longer applied.
An example Hello, World program is:
PRINT "Hello, World!"
An example of QB64's emulation of VGA memory for compatibility:
CLS S$ = "Hello, World!" DEF SEG = &HB800 'sets the segment to video memory FOR I = 1 TO LEN(S$) POKE 160 + (I - 1) * 2, ASC(MID$(S$, I, 1))'character NEXT DEF SEG 'reset the segment to default
An example of how QB64 allows audio files:
sound_effect& = _SNDOPEN("sound.wav") 'WAV, OGG or MP3 _SNDPLAY sound_effect&
An example of how QB64 allows picture files:
SCREEN _NEWIMAGE(800, 600, 32) 'creates a 32-bit screen imagename& = _LOADIMAGE("image__name.png") 'BMP, JPG, PNG, etc. _PUTIMAGE (0, 0), &imagename _FREEIMAGE &imagename 'release assigned memory
An example of how QB64 uses multiple timers:
t1 = _FREETIMER t2 = _FREETIMER ON TIMER(t1, 1) GOSUB Timer.Trap 'the code following the Timer.Trap label will be run every 1 second ON TIMER(t2, .5) mySub 'QB64 can also trigger a SUB procedure with TIMER; ' in this case mySUB will be triggered every 500 milliseconds 'activate timers: TIMER(t1) ON TIMER(t2) ON DO 'go into an infinite loop until the window is closed _LIMIT 1 'run the main loop at 1 cycle per second, to show how timers are independent from main program flow LOOP Timer.Trap: PRINT "1s; "; RETURN SUB mySub PRINT "500ms; "; END SUB
Extensions to QBASIC
QB64's extended commands begin with an underscore in order to avoid conflicts with any names that may be used in a QuickBASIC program.
QB64 extends the QuickBASIC language in several ways. It adds the new data types including
_FLOAT as well as unsigned data types. The new data types have suffixes just like the traditional BASIC data types. QB64 also includes an audio library which allows playing most common audio formats including MP3, Ogg Vorbis, and WAV files as well as libraries allowing users to use higher resolution graphics than the 640×480 offered by QuickBASIC, use different fonts, and plot images in BMP, PNG, and JPEG format. It also allows the use of 32-bit colors as opposed to the limited 256 (or 16, depending) colors originally offered.
The programmer also does not have to specify which programming libraries to include since QB64 does it automatically. The programmer has the option to include a library of their own through the $INCLUDE command just as QuickBASIC did.
Weekly builds are generated with additions and fixes to the code base, hosted on GitHub.
QB64 can also use DLL libraries for Windows, C++ and SDL functions and statements with a DECLARE LIBRARY block. Users can also access C header files to run C functions.
- Stephane Richard (2007-11-16). "In The News". PCOPY! Issue #50. Basic Programming. Archived from the original on 2009-12-21. Retrieved 2008-08-17.
- E.K.Virtanen (2008-05-26). "Interview With Galleon". PCOPY! Issue #70. Basic Programming. Archived from the original on 2008-08-21. Retrieved 2008-07-14.
- "QB64 Screenshots - QB64/QBASIC Gorillas in QB64". Retrieved 2010-07-27.
- "QB Advisor: Screen Modes 11, 12, and 13". Microsoft Corporation. 1988. Retrieved 2008-07-25.