This project is based on the darcula look and feel for Swing.
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:
<dependency>
<groupId>com.github.weisj</groupId>
<artifactId>darklaf-core</artifactId>
<version>3.0.2</version>
</dependency>
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")
}
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.
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.
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.
Check out the darklaf-extension project for additional artifacts which add support for some third-party projects.
./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.
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:
- Native window decorations on Linux.
- Localization:
- Theme preferences panel. here
- 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.
Please send me your project, and I'll add it here.
This project is licensed under the MIT license.