Harfang for CPython
Harfang for Python is distributed as a wheel package (.whl)
compatible with official builds of the CPython interpreter version 3.4 or newer.
Installation
- On Windows, install from the command line by typing
pip install harfang
. - On Linux, download the wheel for your distribution then install from a terminal by typing
pip install /path/to/harfang.whl
.
Testing your Installation
Start the python interpreter and type import harfang
, you should get an output similar to the following:
Harfang 2.0.0 for CPython 3.2+ on windows-x64 (build ba08463ee9e6c0c93960230fb880c1d9b230610d Sep 30 2020 16:08:22)
See https://www.harfang3d.com/license for licensing terms
Troubleshooting
pip install
fails with a message sayingharfang is not a supported wheel on this platform
.Make sure that your pip install is up to date. Outdated pip versions have been known to cause such problems.
The dynamic library fails to load when importing the
harfang
module in Python.Make sure your system has the required runtime dependencies installed. It should have OpenAL and on Windows the Visual C++ 2017 redistributable installed.
ImportError: DLL load failed: %1 is not a valid Win32 application.
error when importing theharfang
module.This error usually happens when installing the incorrect version of Harfang for your Python version. For example when installing the 64 bit version of Harfang on a 32 bit install of the Python interpreter.
First Program
Let’s write a simple test program, create a new file named test.py
and paste the following code into it.
import harfang as hg
hg.InputInit()
hg.WindowSystemInit()
win = hg.RenderInit(400, 300, hg.RF_None)
while not hg.ReadKeyboard().Key(hg.K_Escape):
hg.SetViewRect(0, 0, 0, 400, 300)
hg.SetViewClear(0, hg.CF_Color, hg.RGBA32(96, 32, 255))
hg.Touch(0)
hg.Frame()
hg.UpdateWindow(win)
hg.DestroyWindow(win)
When executed, this program demonstrates how to create an output window, initialize the input and render systems and paint the whole window in blue until the escape key is pressed.
In order to draw anything on screen we will need to create at least a shader and compile it before using it in our program, this process is documented in the Resources & Assets page.
Quickstart documents how to quickly get the more interesting tutorial programs running.