Darklaf - A themeable swing Look and Feel based on Darcula-Laf
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
Jannis Weis b9eed12f1d
Update CodeQL to version 2
2 years ago
.github Update CodeQL to version 2 2 years ago
annotations Fix license header year ranges 3 years ago
annotations-processor Fix license header year ranges 3 years ago
buildSrc Build: Update gradle to version 8.1.1 2 years ago
compatibility Menu: Improve spacing for toggle button menu items 2 years ago
config Replace autostyle with spotless 3 years ago
core FileChooser: Catch all exception when probing file icon 2 years ago
gradle/wrapper Build: Update gradle to version 8.1.1 2 years ago
iconset Icons: Add visualPadding properties to checkbox and radiobutton 2 years ago
img Updated preview images. 5 years ago
licenses TransformUI: Replace JXLayer with JLayer 3 years ago
macos Formatting 2 years ago
native-utils Native: Clean up left over temp files 2 years ago
platform-base Windows: Don't hardcode menubar layout adjustment 2 years ago
platform-decorations Provide more descriptive error messages when the window isn't displayable 3 years ago
platform-preferences Initialize ThemePreferenceProvider in SystemPreferencesManager 3 years ago
property-loader Update jsvg to version 1.0.0 2 years ago
theme Defaults: Change default dark theme to OneDarkTheme 2 years ago
theme-spec Implement equals and hashCode for FontPrototype 3 years ago
utils Menu: Improve spacing for toggle button menu items 2 years ago
windows Windows: Don't hardcode menubar layout adjustment 2 years ago
.editorconfig Add rules for .properties files to .editorconfig 3 years ago
.gitattributes Add .gitattributes to ensure files have expected line endings 5 years ago
.gitignore Build: Update to Gradle 7 4 years ago
LICENSE Replace autostyle with spotless 3 years ago
README.md Release version 3.0.2 2 years ago
build.gradle.kts Build: Update gradle to version 8.1.1 2 years ago
change_notes.md Release version 2.5.4 4 years ago
gradle.properties Update jsvg to version 1.0.0 2 years ago
gradlew Build: Update gradle to version 8.1.1 2 years ago
gradlew.bat Build: Update gradle to version 8.1.1 2 years ago
settings.gradle.kts Build: Update gradle to version 8.1.1 2 years ago

README.md

Darklaf - A themeable swing Look and Feel

CI Status Native Libraries Code Style Maven Central

This project is based on the darcula look and feel for Swing.

Screenshots

IntelliJ Darcula
Solarized Light Solarized Dark
High Contrast Light High Contrast Dark

Usage & Features

A list of all features can be found here. The LaF is compatible with Java >=1.8 (you need >=1.9 to get proper scaling).

You can find all property values on weisj.github.io/darklaf-docs

This project is available on Maven Central:

Maven

<dependency>
  <groupId>com.github.weisj</groupId>
  <artifactId>darklaf-core</artifactId>
  <version>3.0.2</version>
</dependency>

Gradle

implementation("com.github.weisj:darklaf-core:3.0.2")

You can also use the latest nightly build.

repositories {
    maven {
        url = uri("https://oss.sonatype.org/content/repositories/snapshots/")
    }
}

configurations.all {
    resolutionStrategy.cacheChangingModulesFor(0, "seconds")
}

dependencies {
    implementation("com.github.weisj:darklaf-core:latest.integration")
}

Installation

The LookAndFeel can be easily installed using the LafManager

// For default theme (IntelliJ)
LafManager.install();
// Specify explicit theme.
LafManager.setTheme(new IntelliJTheme());
LafManager.install();
// Directly install theme
LafManager.install(new DarculaTheme());

For more information see the wiki.

Note: The recommended method is using the LafManager as it automatically handles reloading the ui.

Choosing a theme

It is highly encouraged to provide users more than one theme. Forcing users to use a light/dark theme because of personal preferences might be degrading their experience in certain situations. For the visually impaired darklaf provides a set of high contrast themes, HighContrastThemeLight and HighContrastThemeDark.

Darklaf supports detecting the system theme on macOS and Windows with the ability to automatically change the theme if the settings change.

// This returns the preferred theme of the system settings.
LafManager.themeForPreferredStyle(getPreferredThemeStyle());

The following settings are picked up by darklaf:

Windows macOS Setting
Light/Dark mode
High contrast mode
Accent color
Selection color
Font size

You can use the ThemeSettings class with ThemeSettings#showSettingsDialog or ThemeSettings#getSettingsPanel to provide the user the most possible customization.

Example

import com.github.weisj.darklaf.LafManager;
import javax.swing.*;
import java.awt.*;

public class DarklafDemo {

    public static void main(final String[] args) {
         SwingUtilities.invokeLater(() -> {
            LafManager.install();

            JFrame frame = new JFrame("Darklaf - A themeable LaF for Swing");
            frame.setSize(600, 400);

            JButton button = new JButton("Click here!");

            JPanel content = new JPanel();
            content.add(button);

            frame.setLocationRelativeTo(null);
            frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
            frame.setContentPane(content);
            frame.setVisible(true);
        });
    }
}

All custom component-variants and settings can be enabled by setting the appropriate client property of the component. They can be found here.

This LookAndFeel supports custom window decorations (only on Windows at this point). In contrast to most other LaFs the native window behaviour is not compromised giving a seamless experience that still looks native.

Extensions

Check out the darklaf-extension project for additional artifacts which add support for some third-party projects.

Build

./gradlew build

When building on Windows, you need a C++ toolchain installed to build native extension.

When building on macOS you need to have XCode (or the command line tools) installed to build the native extension.

If you want to build for platforms different from your machine the necessary binaries are automatically downloaded. For this you have to specify a valid GithubAccessToken using githubAccessToken property in your local gradle.properties file. The access token only needs to have the permission to read repositories.

You can also manually download the respective native libraries from the latest successful run of the Build Native Libraries Action and place it in the corresponding <variant>/libraries folder. This is necessary if you don't have the appropriate toolchain installed, but you machine is a binary target.

Note: You can still build the project without the libraries, but then custom decorations won't be supported.

Contribute

Here is a list of things that currently are not finished or need refinement. This list is a work in progress and being updated regulary. If you find any problems with the LaF feel free to submit an issue:

Artifacts

  • Group ID: com.github.weisj
  • Version: 3.0.2
  • Artifact IDs:
    • darklaf-core The LaF itself. Include this in your project to use the LaF. Includes all other artifacts.
    • darklaf-iconset The icons used by the laf.
    • darklaf-theme The themes to use with the LaF.
    • darklaf-theme-spec Relevant classes needed to implement a custom theme.
    • darklaf-property-loader Library to load and parse property files and icon.
    • darklaf-utils Shared utility classes for other modules.
    • darklaf-native-utils Loading of native libraries.
    • darklaf-platform-base Common classes for the platform modules.
    • darklaf-platform-decorations Standalone module to provide custom window decorations on macOS and Windows.
    • darklaf-platform-preferences Standalone module to access and listen to changes to the system theme.
    • darklaf-windows Code specific to Windows.
    • darklaf-macos Code specific to macOS.
    • darklaf-compatiblity Don't use this. It's only meant to encapsulate code not portable across JVM versions.

Projects using Darklaf

Please send me your project, and I'll add it here.

License

This project is licensed under the MIT license.