Libgdiplus is the Mono library that provides a GDI+-compatible API on non-Windows operating systems. Our implementation uses Cairo to do most of the heavy lifting.
To run this code in your machine with Code::blocks IDE, add a link library libgdi32.a (it is usually inside MinGWlib ) in linker setting and make the file extension.cpp but not.c. For C user, here is a link to download C file of this tutorial. The Eclipse Foundation - home to a global community, the Eclipse IDE, Jakarta EE and over 350 open source projects, including runtimes, tools and frameworks.
Mono’s implementation of GDI+ lives in the libgdiplus GitHub repository.
See here if you’re having problems initializing libgdiplus.
Due to its tight relation with System.Drawing, new versions of libgdiplus are released with (almost) every new version of Mono.
The current custom text engine is limited. GDI+ offers many (little used) options that are not, or incorrectly, supported by libgdiplus. The plan is to use Pango to replace our custom engine—but no work is being done on this task at the moment.
A proof-of-concept is already in git but is unsupported and less complete than the current text engine. You can use –with-pango to enable it.
Cairo doesn’t provide 100% of the functionalities required to implement GDI+ or System.Drawing. A few features were added directly in libgdiplus (unmanaged) or System.Drawing (managed).
However some features are still missing, check the TODO file in the repository. Contributions toward completing those tasks are welcome.