Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/oprypin/crystal-imgui-sfml
Crystal bindings to ImGui-SFML
https://github.com/oprypin/crystal-imgui-sfml
Last synced: 3 months ago
JSON representation
Crystal bindings to ImGui-SFML
- Host: GitHub
- URL: https://github.com/oprypin/crystal-imgui-sfml
- Owner: oprypin
- License: mit
- Created: 2020-08-10T21:16:31.000Z (over 4 years ago)
- Default Branch: master
- Last Pushed: 2024-05-19T19:31:24.000Z (8 months ago)
- Last Synced: 2024-10-04T13:36:23.035Z (4 months ago)
- Language: Crystal
- Homepage:
- Size: 61.5 KB
- Stars: 17
- Watchers: 3
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE.md
Awesome Lists containing this project
- awesome-crystal - crystal-imgui-sfml - Bindings to integrate [Dear ImGui](https://github.com/ocornut/imgui) into an [SFML](https://www.sfml-dev.org/) project (Game Development)
README
# crystal-imgui-sfml
#### [Crystal][] bindings to [ImGui-SFML][]
Introduction
------------This library makes it straightforward to
use [Dear ImGui][imgui] (through its [crystal-imgui][] binding)
with [SFML][] (through its [CrSFML][] binding).**See the [example](examples/simple.cr).**
*crystal-imgui-sfml* does _not_ attempt to serve as a _wrapper_ for all of these, rather it's just the "glue",
and so both [crystal-imgui][] and [CrSFML][] will still be explicit dependencies of your project.That said, *crystal-imgui-sfml* _does_ take over some parts of the installation process from [crystal-imgui][].
Documentation
-------------* [API documentation](https://oprypin.github.io/crystal-imgui-sfml)
* [ImGui-SFML introduction](https://github.com/eliasdaler/imgui-sfml#using-imgui-sfml-in-your-code)Installation
------------First, [install SFML](https://github.com/oprypin/crsfml#prerequisites).
Then add to your project's _shard.yml_ file:
```yaml
dependencies:
crsfml:
github: oprypin/crsfml
imgui:
github: oprypin/crystal-imgui
imgui-sfml:
github: oprypin/crystal-imgui-sfml
```Resolve dependencies with [Shards][]:
```bash
shards install
```During installation this will invoke `make` to build the C++ wrappers as object files. SFML headers are expected to be available in the default include path.
### Building a project
Try the example from inside the folder of *crystal-imgui-sfml*:
```bash
crystal build examples/simple.cr
```Although building the example automatically added the `libcimgui.so` library (bundled with the project) to the search path, running it will require that addition to be done manually:
```bash
export LD_LIBRARY_PATH="$(pwd)"
./example
```For your own project, *crystal-imgui-sfml* will be in a subdirectory, so adjust this accordingly:
```bash
export LD_LIBRARY_PATH="$(pwd)/lib/imgui-sfml"
printf 'require "crsfml"\nrequire "imgui"\nrequire "imgui-sfml"\n' >> my_project.cr
crystal run my_project.cr
```### Custom SFML location
If SFML's headers and libraries are not in a path where the compiler would look by default, additional steps are needed.
Before building the extensions (`make`) you need to configure the include path:
```bash
export CXXFLAGS="-I/full/path/to/sfml/include"
export LIBRARY_PATH="/full/path/to/sfml/lib"
make
```[More details at CrSFML](https://github.com/oprypin/crsfml#custom-sfml-location)
### crystal-imgui-sfml without Shards
It's also possible to use *crystal-imgui-sfml* outside of Shards, as with any library. One option is to directly create a symbolic link to *crystal-imgui-sfml* in your project's *lib* folder.
```bash
mkdir lib
ln -s /full/path/to/crsfml lib/crsfml
ln -s /full/path/to/crystal-imgui lib/imgui
ln -s /full/path/to/crystal-imgui-sfml lib/imgui-sfml
```Note, though, that the C bindings inside the _crystal-imgui-sfml_ directory must be additionally built using `make`.
Credits
-------*crystal-imgui-sfml* was made by [Oleh Prypin][oprypin]. It uses and is based on [ImGui-SFML].
*crystal-imgui-sfml* is [licensed](LICENSE.md) under the terms and conditions of the *MIT* license.
[imgui-sfml]: https://github.com/eliasdaler/imgui-sfml
[imgui]: https://github.com/ocornut/imgui
[sfml]: https://www.sfml-dev.org/ "Simple and Fast Multimedia Library"
[crystal-imgui]: https://github.com/oprypin/crystal-imgui
[crsfml]: https://github.com/oprypin/crsfml[crystal]: https://crystal-lang.org/
[shards]: https://github.com/crystal-lang/shards[oprypin]: https://github.com/oprypin