Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
JaxCore is a collection of utility modules designed to improve your desktop experience and increase your productivity. It also includes a few additional widgets to spice up your desktop.
JaxCore (configuration hub) acts as a settings menu for all JaxCore modules, while providing continuous support for patch / feature updates. It also allows you to access other modules more quickly!
Guide to installing JaxCore
Windows 10 (x64) or above
Paste & run the following command in Powershell (win + r
-> powershell.exe
)
Proceed through the welcome screen (highly recommended to read everything so you don't get lost).
You'll be greeted with a screen which asks you want modules or widgets to be installed. Select the one(s) you want.
A cache skin is used to get the latest version, and unifies the installation methods of JaxCore.
This is the detailed documentation for JaxCore, its structure and how to build a module for JaxCore along with handy tricks used while coding modules for JaxCore (or any Rainmeter skin).
For older systems, Powershell v5.1 or newer is required. Upgrade Powershell !
For installing with other methods, click
You should be re-directed if you're trying to install from DeviantArt / RM Forums.
Download from the respective posts from the site, run the .rmskin
installer. It will install a cache skin which installs JaxCore.
Walkthrough of the user interface.
To go to the home page, click the home icon located at the top right hand side of the window.
JaxCore has multiple home pages. Refer to the table below to know more about these pages.
Discover
Discover the best modules and widgets
Shop
Explore free / paid addons for modules
Library
Explore available modules and widgets, and go to their respective settings
Settings
Change JaxCore's settings
ARROW
Some other pages in home
The sidebar contains all the settings pages for the module or widget.
The activation toggle is located at the top and is used to activate or deactivate the module / widget.
Every module has a unique set of pages apart from the Info page, where you can update and check the version of the module.
Open the context menu by right-clicking anything JaxCore.
Configure in Core
Open the settings menu for interacted module or widget
Align
Aligns the widget relative to the screen
Change Z layer
Puts the widget on different layers of the desktop
Refresh
Refreshes the interacted component
Unload
De-activates the interacted component
Rainmeter actions
More actions
Developer tools
Allows you to restart Rainmeter / slow-refresh component
2. Install ImageMagick. You must check Add application directory to your system path
:
3. Restart Rainmeter by Right Click (Anything JaxCore) -> Developer options -> Reload Rainmeter
1. Open Powershell, copy the following commands, paste and press enter:
2. And finally, run the following command to save and apply all your changes:
3. Restart Rainmeter by Right Click (Anything JaxCore) -> Developer options -> Reload Rainmeter
1. Download ImageMagick:
This is only required if you're setting up Spotify using Auto
media method setting.
If aren't using Spicetify for theming, run the following command
You can change the time format to 24-hour or 12-hour.
Weather temperature unit: Imperial (F) or Metric (C, default)
Change your weather location here. To find your weather location:
Copy the location similar to the picture below, and paste it in the weather location field in JaxCore
How to uninstall a module/widget, JaxCore or Rainmeter
Go to the settings page in .
Click on Global settings in the .
Go to
Enter your location in the search bar , and click on the correct result
modules or widgets which displays weather information
If it still fails, try
Experiencing issues? Join the for help.
If you're experiencing problems with JaxCore, you can search for related issues at , or create an issue on the / help thread on the !
JaxCore is a set of modules and widgets that you can use to customize different aspects of your desktop, like the start menu, volume flyout or desktop clock.
No. JaxCore doesn't modify any critical files on your system, and only displays windows over the default layer.
While downloading the .bat installation file for JaxCore, most, if not all, browsers may flag the .bat file as malicious and prevent you from downloading it. This false positive occurs because JaxCore's website is an “unknown provider” as per the browser and thus, the file is deemed insecure or unsafe.
You may also encounter a similar problem when attempting to run the file after it has been downloaded. Windows Smart Screen prevents you from running the file and attempts to warn you that it may be unsafe. The reason is the same as before: The file was obtained from an unknown source.
However, you can rest assured that the .bat file is completely safe.
The installation package may trigger a false positive alert in your antivirus program. This is due to the .exe
files stored in the package, which is required to automate parts of the program. The program being flagged is usually done through heuristic analysis, not via a database of known viruses. That means that the antivirus program thinks that due to the nature of the code in this application, it likely may be a virus, a program that the user does not really mean to run.
Some antivirus software may occasionally flag JaxCore's files as malware, resulting in those files being quarantined the majority of the time. But, like the previous false positives, this one is also a false positive. What actually happens is that the antivirus flags the powershell processes that JaxCore requires to function properly, resulting in false positives. However, regardless of the warning or the cause of the false positive, all of JaxCore's files and JaxCore are completely safe.
The original color picker had been removed due to being flagged as a malicous executable by Windows defender. An alternative will be added soon.
TLDR: No support yet
Core supported multi-language before, but I've removed it for now since it is impossible to get accurate translations for each version of core. Support for multiple languages will be added after the upcoming Difia update!
JaxCore currently does not function properly for 32-bit Window installations. Stay tuned for updates on this issue.
There are missing dependencies on your system.
Launch JaxCore again. If it still doesn't load, try restarting your device.
Also, the source code is always available , so you have all the tools necessary to make an informed decision.
Read
Follow through video guide:
Please DO report this issue to me on our ! (Just let me know that this happens)
Download the and install it. Run with administrator priviledges if it fails to install.
Download the Visual C++ Redistributable for your system: |
It does that by default. However, only modules and widgets are loaded, and the config hub will not load on startup.
No. The configuration hub will not run in the background. Only activated modules and widgets will.
Yes. You can toggle on Gamemode in the JaxCore settings.
Go to the Rainmeter Manage panel (found in your app tray)
Set #JaxCore\Main\Home.ini
coordinates to 0 0
. If the option is greyed out, load it.
Unload and load it
After that, Re-create JaxCore's shortcut in it's setting page so that this issue never happens again
Select option 3 when the powershell prompt asks for an installation preferences. Then choose a folder once prompted. It is recommended to choose an empty folder as the installer creates 2 folders in the selected directory. If the installer is stuck after clicking OK, press enter.
Run the following command in Powershell, replacing <LOC>
with the absolute path to the folder you want JaxCore installed in, and this folder should contain the Rainmeter folder that you have installed to before.
This happens because your anti-virus prevented the Powershell instance to launch. To fix this, exclude the following paths in your anti-virus.
Save your configuration in your anti-virus and restart.
Run the following command to install a specific module. Replace YourFlyouts with the name of the module that you want to install.
Try turning on Use legacy .rmskin extension installer in JaxCore settings.
Reinstallating would help remove broken folder structures and start fresh
Uninstall Rainmeter via Windows Settings
Delete %appdata%\JaxCore
and %appdata%\Rainmeter
Note: This will remove all modules & widgets.
Download JaxCore from
More about false positives
We're constantly trying to improve the standard installer! If you are willing to help debug this, please create a bug tread on our or
Install from
Try YourMixer
For module guides, check out the or section.
Unfortunately ValliStart does not have a built-in search menu yet. This will hopefully be added after JaxCore's Difia update, where things will be faster and easier to manage.
By default, ValliStart opens the search menu by Win + S. Make sure this hotkey functions properly in your system. If not, change it to something that opens your search / launcher.
Yes. Change ValliStart -> General -> Setting: Key to run after key input is captured
to the hotkey which you launch your launcher.
Change the scale option.
If you are confused as how to use the hotkey configurator, click
Refer .
Padding refers to the space that exists between the module and the screen border in pixels.
Monitor index refers to which monitor the module is located at
Use the direction boxes to change where the module is aligned to, relative to the screen
Unfortunately not. Part of the module is hard-coded to itself, so clones of modules will not function.
Click on the option which changes the hoktey, most often in the general settings. It will show a popup which looks like the following:
Navgiate this popup from top to bottom.
Focus on the hotkey field (The None box)
Press the hotkey that you want. If it contains a key listed below the box, click any other key first. (For example, if you want alt+space
, pressalt+s
first)
If your desired hotkey contains a key listed in the second section, check the radio button, else simply skip this section. (Continuing example, click on the button for Space
)
If you also want the Windows key to be part of the hotkey, check the last box
Click confirm
Clear setup wizard data from the info page with the debug actions
Click on patch notes
Click on new to module
This feature is only supported for Windows 11 or above.
Click on debug options on the info page of settings
Click on uninstall
Select the last option, the module will be removed after that
Install the module again by pressing the download button
Refer to
Make sure the module is activated first. Check the toggle button located at the top of the in the .
Head to the Position settings via the , and change the options here
Change the position settings.
Go to the position settings, and change the following options:
Screen to display on The index of the screen to display the main section of IdleStyle. (e.g. second monitor: 2)
Number of screens to stretch horzontally The number of screens that you want IdleStyle to cover. If you only want it to cover your primary monitor, set this value to 0.
Alignment of screensaver Direction of the screens from the main sections' position
If you are unable to achieve the results you want, turn off Smart detection and change the following options:
Screen to display on The index of the screen to display the main section of IdleStyle. (e.g. second monitor: 2)
Click on Open Editor and position the overlay over all of your monitors, then press Enter.
Windows might be constantly checking for driver updates, and hence resetting the timer. You can try making sure all your drivers are up to date.
Unfortunately not.
Launch Rainmeter using search
Launch JaxCore
Launch Rainmeter if it already crashed
Open JaxCore
Go to your modules, and set Media method (Music settings) to Auto for all
Unfortunately, there are no direct, magical solutions to this issue, but you can try the following solutions:
Make sure JaxCore is up to date, check in core settings
Turn on hardware acceleration in core settings
This issue mainly happens when a part of MetroUI (e.g. Default start menu / taskbar calendar) is active, preventing JaxCore from taking focus from these UI features. It might also happen when simply trying to load core using a desktop icon.
To fix this issue, load JaxCore using Right click --> Configure in core --> Home instead of using the Taskbar icon, and simply try to avoid launching core modules when a part of metro UI is active. When that happens, simply click on the desktop.
Setup your media players for the Auto method following
If issue persist,
Make sure you met the
The issue is caused by the media player (Spotify / browser) itself, and is not a problem with the module.
This mostly happens with modern
method as Windows often doesn't request the current position
You can fix this by using Auto
method for your modules instead (See below)
There is no setup needed by default. Everything should work out of the box
Users can choose to use Auto
method to fully support certain media players.
Make sure this option is turned on in Spotify's settings. (Default is on)
You can clone widgets within JaxCore. Note that cloned widgets will not receive style updates / bug fixes.
Go to the info setting for the widget you want to copy
Click on make clone in actions
Enter the clone's name, make sure it does not have any spaces in it
Click on Go to settings of widget or module...
Enter the cloned widget name
Hold Ctrl and then Right click
Right click -> Align
This issue is caused by Windows providing the wrong wallpaper path, causing the blur to refresh everytime the clock refreshes.
To fix this issue, change your wallpaper to something else, rename the original wallpaper with simple charcters / relocate to desktop and refresh the widget.
Spotify: Requires
Web browsers (Youtube / Soundcloud etc.): Requires companion
MusicBee: Turn on option in MusicBee settings
Foobar: Install the plugin for foobar
JaxCore would close after that. Restart it and go to the library page in .
Activate the newly created clone from the .
Modules replaces certain parts of the system's UI. For example, YourFlyouts replaces the default windows flyouts and ValliStart replaces the start menu. They are different to widgets, as they are not part of the desktop and will not stay there.
All JaxCore modules will allow you to change the bit of the UI to your liking, providing you plenty of customization for appearance and functionality.
Windows Audio / Volume flyouts replacement
YourFlyouts provides multiple replacements for the old, built-in, Metro Design based Audio/Media/Brightness flyouts in Windows which are shown while pressing the media or volume keys. Along with a number of unique designs, it also provides additional customizability towards the behavioral and appearance side of things!
A recent update to Windows 11 changed how volume flyout works, and so the original flyout callback doesn't function properly anymore in the updated version of Windows.
To make YourFlyouts work under this version, turn on options under JaxCore -> YourFlyouts -> General -> Category: Compatability
Brightness and airplane mode flyouts might not work properly on this Windows version
We'll look into fully fixing this issue in the future
More:
This module will retrieve and display media metadata. You can learn how to set it up .
This module automatically positions itself. You can learn how to change the positioning .
Volume Mixer - Check if Rainmeter has been muted or turned low in the volume mixer, simply search volume mixer to go there
Audio Device - Check if your settings correspond to the right audio device
If unfortunately the issue persists, the visualizer might not be compatible with your device.
Make sure you have hardware acceleration turned on in JaxCore settings
Try reducing bar count
Try not using image underlay
A custom volume mixer to replace the default one.
YourMixer replaces the standard Windows Volume Mixer with a fully customizable volume controller.
This is an intended feature. Some apps would have different output channels, for example Discord would have one for notification sounds and one for voice chat sounds.
If after verifying both the visualizer is still static, try updating your (first file).
More:
This module automatically positions itself. You can learn how to change the positioning .
A visualizer.
ModularVisualizer comes with eight custom layouts that you can further customize to your liking. Please keep in mind that each layout has a plethora of customization options that are beyond the scope of this guide, so explore them for yourself.
Further in-depth customization can be done through the Appearance, Render, 3D overlay, and Audio tabs. You won't be constrained by the skin's customization capabilities!
Stylized screensavers
IdleStyle offers fully customizable screensavers with custom animation support. Custom animations can be used to display a range of things such as images and videos.
Choose your preferred animation style in the animations tab.
Configuring ffplay:
Extract the zipped file you just downloaded and open the ffmpeg-master-latest-win64-gpl
folder. Inside, you will find another folder with the same name which will be required in the next step.
Open the ffmpeg-master-latest-win64-gpl
folder, and go into the bin
folder.
Copy the ffplay.exe
(CTRL + C
).
Open File Explorer and navigate to %appdata%\Rainmeter\JaxCore\CoreData\IdleStyle
.
For existing Rainmeter users: %USERPROFILE%\Documents\Rainmeter\Skins\CoreData\IdleStyle
Paste the ffplay.exe
you copied in Step 4 into the folder named IdleStyle
which you opened, on Step 5
Setting up the video background:
Open Core and head over to the Modules section.
Select IdleStyle from the list and proceed to the Animation tab.
Second from the bottom, enable the custom video background preset.
Go to Appearance tab and under Customization press the DefaultVideo
button besides the Video Path
text.
Choose the custom video background you want to use. Please select common file formats such as .mp4
A start menu to replace the un-customizable one that you have right now.
ValliStart is a start menu replacement for Windows, with full customizability, interchangeable modules and more.
ValliStart can be activated in multiple ways:
You can launch ValliStart just like the start menu with the Win
Key. Additionally, you can replace the windows button by:
Navigate to JaxCore -> ValliStart -> General -> Setting: Customize how to activate ValliStart
and turn on override start button.
Select a start orb name. The default is Win11
. You can choose another one / add your own one in the orbs directory, and entering another start orb name.
Press the Create
button above
Core should popup the explorer with shortcut ValliStart.lnk
inside
Drag the shortcut to the taskbar
Now you have a pseudo start button on the taskbar!
Navigate to JaxCore -> ValliStart -> General -> Setting: Customize how to activate ValliStart
and turn on override start button.
Toggle Setting: Display WinBlock element (legacy)
on
Switch Setting: Win block behavior
to edit
Drag the winblocker to desired location
Switch Setting: Win block behavior
to functional
You can also launch ValliStart with the hotkey of your choice. This does not support overriding the displayed window button on your taskbar.
Navigate to JaxCore -> ValliStart -> General -> Setting: How should ValliStart behave?
and switch the option to Separate module
Change Setting: Activation Hotkey
to your desired hotkey
You can fully customize ValliStart's modules in ValliStart's module
settings.
Arrow icon / clicking on the image would allow you to select a module from 4 categories.
Cross icon would empty the module slot
Cog icon would show the settings for that module slot
Layouts are pre-made set of ValliStart modules which you can apply instantly.
After applying the shortcuts module, click on the top right icon in ValliStart to change or add new shortcuts.
You can customize the appearance of the shortcuts by clicking on the cog icon in the shortcuts editor, and choosing 1 of the 3 styles. The default is Win11
.
More:
To use video backgrounds, you must first install and configure ffplay which is a part of . Follow the instructions below to setup ffplay.
Open . This link will download a zipped file named ffmpeg-master-latest-win64-gpl.zip
Required to generate bur and other fancy effects. You can learn how to get it .
This module will retrieve and display media metadata. You can learn how to set it up .
More:
This module will retrieve and display media metadata. You can learn how to set it up .
This module automatically positions itself. You can learn how to change the positioning .
This module can display weather information. You can learn how to set it up .
If you want to remove the stock start button: You can use for Win10. There are no known ways of doing so on Windows 11.
Required to generate bur and other fancy effects. You can learn how to get it .
This module can display weather information. You can learn how to set it up .
Widgets are part of your desktop and stays there. They shows different useful information. For example, mPlayers show NowPlaying information and mClocks shows the current time and weather.
All JaxCore widgets have loads of options and styles for you to change it to your liking.
FAQs
Simple layering effect tool
Let's create a simple effect with this wallpaper and ModularClocks!
Select the image in Overlayer's general settings, and activate Overlayer
Position ModularClocks to your desired location, right click on them and select Change Z Layer... and choose either -1 or -2
There we go!
Create a cut-out of your wallpaper's main object (i.e. a mountain) using a photo-editing tool or a website like
Creating a module with a reactive user interface can be achieved in Rainmeter with inline formulas and mouse action bangs.
In most cases, you do not want to use fixed dimensional values for anything. This includes X Y W H R StrokeWidth FontSize
. The only case that you will have fixed values for anything is if your module is generated from a lua / ps1 script.
To make a module which can scale according to W H
and Scale
you'll need to have position & dimensional options for meters set with inline formulas.
The simplest form of an inline formula is X=(150*#Scale#)
This tells Rainmeter to scale your X value according to the Scale
variable.
To scale any meter is as simple as multiplying their positional and dimensional values.
Most Rainmeter element (except for a few) is aligned from it's top left corner. Therefore, you can't just set a meter's X value to (#W#/2)
and expect it to center
General formula: =(#Total#/2-#Group#/2)
Total is the sum of dimensional units to align the Group center Group is the sum of dimensional units to be aligned center
However, for string
and shape
meters, you can use alternative ways to center them
Aligning left general formula: =(#AnchorDim#+#OffSet#)
Aligning right general formula: =(#AnchorDim#-#OffSet#-#Group#)
AnchorDim is the dimensional positional value where the meter is aligned at OffSet is the distance between the alignment anchor and the meter Group is the sum of dimensional units to be aligned right
A generic mouse over mouse leave action looks like this
However, you can't configure a shape's inline options with !SetOption
. This is what you should do alternatively.
It is highly recommended to have a consistent code format across all your modules.
It is highly recommended to have 4 different sections for every .inc
or .ini
file:
Of course, you can name however you want, but here are some styles that I recommend
#element_Name#
where Name
is a value for element
(e.g. #Pri_Color#
)
#n#
where n
is a short form or first letter of the variable name name
(e.g. #R#
)
[Element.MeterType]
where Element
is what meters make of, and MeterType
is the type of the meters.
[GroupIndex]
where Group
is what the meter is part of (for example, a list) and Index
is an integer appended to the meter. Useful for multiple elements of a list
[Element.MeterType:S]
for a style for MeterType
of Element
[Level.Element:S]
for a style which is above the main module file (e.g. Core) and is applied to a single meter to make Element
.
[ElementStyle]
for a quick low-level meter style for Element
[mFunction]
for a measure with Function
(e.g. toggle
for a toggle function, CPUPer
for returning the percentage of CPU usage)
And again, there are other ways to center String
and Shape
Meters. No examples will be given, as you can probably figure it out
You can use both scaling and aligning to create complex scaleable elements. Example:
[ACTIONACTIONNAME]
for a which executes ACTIONNAME
. The prefix ACTION
is literal.
A NUOL measure is a disabled measure which when updated executes a bang.
And to call this bang, you can simply update the measure with
!UpdateMeasure ACTIONHELLOWORLD
But why not just call a variable with a bang value? That will work... but only when called in the currentconfig. Using a NUOL measure you can call the bangs from a different config with
!UpdateMeasure ACTIONHELLOWORLD "MainConfigName\Main"
mToggle measures are used in most hotkey modules toggle It is not recommended to use mToggle anymore, instead, use lua to achieve better results
A mToggle measure is a measure which when called toggles and execute actions. We'll be using NUOL measures to support calling functions from different configs.
This mToggle works, but you are unable to set it to either value with an action. Therefore, we'll be needing another measure to set mToggle's value: mToggleSet
MeterStyle are base settings that can be applied to meters, to avoid repetitive settings
Should be applied to all string meters
Sometimes, you may come across situations where you'll need multiple meters with same relative positional values but a few different options
You can make use of #CURRENTSECTION#
to reduce the amount of code needed to edit for each meter section.
The most common type of situation is when you need to have multiple buttons next to each other.
More info of part of this code: Scaling Center MouseActions #meter-and-measure-naming
Using .ahk files in a module
The following guide will show you how you can use AHK to run 2 toggling bangs by pressing a hotkey for your module. Of course, this isn't what AHK is limited to do, as demonstrated by the YourFlyouts module.
Create file ./@Resources/Actions/Source code/#SKINNAME#.ahk
And create file ./@Resources/Actions/Source code/Close.ahk
And finally, create file ./@Resources/Actions/Hotkeys.ini
As you can see, in Hotkeys.ini
the values are blank. We'll have to assign a default value first.
You can either put these values in the file, to make the default hotkey LWin W
Or you can visit your settings page (if you made one) and change the hotkey.
Open the @Start
skin from the Rainmeter manage panel.
As you've read about themToggle measure, lets use that to toggle our module.
Paste the 2 blocks into your main skin file.
Add the following contents to the [Rainmeter]
section:
This allows the module to:
Always stay on top of other windows
Launch the ahk process when the module is activated
Dismiss on unfocus
Close all ahk process when the module exits
Create 2 NUOL measures: ACTIONLOAD
& ACTIONUNLOAD
, and have their OnUpdateAction
be whatever you want
Congratulations! All necessary files have been created. Lets move on to the code part...
Guide on how to use JaxCore's powerful version control tool.
CoreInstaller allows your users to install your module even without Rainmeter installed, and allows your module to self-update with a single click. This does not require JaxCore to be installed.
This is meant for advanced skin publishers only. If you're new to releasing skins, consider adding this later down your development schedule.
Complete a 3-step process for basic setup, and another 3-step process to allow your module to self-update.
Create a Github Repository with your skin name as the repository name
Clone local skin folder to Github Repository. Have your skin folder as the root folder. (Optional)
Now your skin can be installed via the following command:
Make sure to replace any occurances of MySkin
and MyUser
with your Github Repo's name and your username in the sections following.
Example: If your Github username is timmy
and your repo name is my-first-skin
: MyUser/MySkin --> timmy/my-first-skin
The slash must be forward!
README.md
file so it's easier for users to install your moduleCreate a README.md
file in the root of your skins folder
Complete the following setups to allow your skin to self-update. You'll need the following things in your module for it to work.
A way to allow users to click on something to update
A powershell script located in the resources folder (or anywhere within the skin)
Replace path_to_powershell_script
with corresponding path
The releases section is where you'll upload new versions of your skin. When uploading your .rmskin
file, make sure to give the release a version tag. Documentation on how to compile your rmskin
release can be found
Put the following contents into it. Replace MyX
Replace MyX