Skip to content

Modern desktop framework from low-level 3D graphics API to high-level view model, for development of 2D/3D rendering software or game engine, with internationalization support and many new technologies.

License

Notifications You must be signed in to change notification settings

BloCamLimb/ModernUI

Folders and files

NameName
Last commit message
Last commit date

Latest commit

bb68f07 · Jan 30, 2025
Apr 15, 2024
Jan 14, 2025
Jan 30, 2025
Dec 9, 2024
Nov 7, 2024
Aug 19, 2024
Jul 12, 2020
Dec 22, 2024
Apr 4, 2024
Oct 18, 2023
Nov 3, 2019
Jun 6, 2023
Jul 10, 2020
Dec 28, 2024
Jan 14, 2024
Nov 21, 2024
Dec 28, 2024
Apr 23, 2022
Apr 23, 2022
Mar 14, 2024

Repository files navigation

Modern UI

MavenCore Discord

Description

Modern UI (by Icyllis Milica) is a desktop application framework designed for standalone 2D and 3D rendering software development. It makes use of modern 3D graphical APIs and technologies to provide high real-time rendering performance. This framework is similar to JavaFX or Android, with a complete set of event loops, rendering systems, and UI components, which are also suitable for game development.

There is also an official version that extends to Minecraft and Forge, it combines Modern UI with Minecraft and provides a number of additional features and modding APIs. See ModernUI-MC repository.

What are the advantages?
Powerful UI functionality, good internationalization support, complete text layout engine based on HarfBuzz. This framework has a powerful graphics engine, which is good to OpenGL 3.3 and OpenGL 4.5 core profiles and is specifically optimized for desktop GPUs, some engine designs are better than Google Skia.

This project is still at a relatively early stage.
Releases for Minecraft Mod are available on CurseForge.
If you have any questions, feel free to join our Discord server.

License

  • Modern UI
    • Copyright (C) 2019-2024 BloCamLimb
    • License
    • Copyright (C) 2006 The Android Open Source Project
    • License
  • Runtime Libraries (not part of the ModernUI project)

Documentation

JavaDoc
Specification (WIP)

Environment requirements

  • Windows 10 or above, Linux, macOS 10.10 or above
  • JDK 17.0.1 or above
  • OpenGL 3.3 or above (OpenGL 4.3 is recommended)
  • Vulkan 1.1 or above (WIP)

Gradle configuration

repositories {
    maven {
        name 'IzzelAliz Maven'
        url 'https://maven.izzel.io/releases/'
    }
}
dependencies {
    implementation "icyllis.modernui:ModernUI-Core:${modernui_core_version}"
    // apply appropriate LWJGL platform here (mandatory)
    // apply other Modern UI modules (optional)
}

Building Modern UI

JDK 21 is preferred. The build command: gradlew build

Modern UI requires Arc 3D codebase to build. Arc 3D is a low-level graphics engine and frequently updated. It won't be published on Maven repository. A snapshot is merged into this repository in /external subdirectory, and all Arc3D classes and sources will be included in ModernUI-Core. You may follow these steps when you want to update it.

// add remote if not
git remote add -f --no-tags arc3d [email protected]:BloCamLimb/Arc3D.git
// fetch if not
git fetch --no-tags arc3d
// delete the old code if any
git rm -rf external/Arc3D
// merge arc3d/master branch
git merge -s ours --no-commit arc3d/master --allow-unrelated-histories
// read the root directory of arc3d/master into 'external/Arc3D'
git read-tree --prefix=external/Arc3D -u arc3d/master:
git commit

Note: You must not make any local changes to /external.