• Stars
    star
    858
  • Rank 52,814 (Top 2 %)
  • Language
    C
  • License
    GNU General Publi...
  • Created about 6 years ago
  • Updated 11 months ago

Reviews

There are no reviews yet. Be the first to send feedback to the community and the maintainers!

Repository Details

Create custom themes for the nintendo switch !

Switch theme injector

Discord Latest release Download ko-fi

ThemeScreenshot

The Switch theme injector project is split into three parts:

  • Switch theme injector (Windows app): An app to create and edit custom themes
  • NXThemes installer: An homebrew app that runs on the switch itself and can be used to install and manage themes.
  • Switch theme injector online (also called WebInjector): A port of the windows injector as a web app, it lacks some features like custom applet icons and common.szs layouts support.

The main objective is to develop a complete toolset to create and install custom themes on the switch. As the console os doesn't implement custom themes natively most of this is done by patching system SZS files to get the desidered aspect.

Unfortunately SZS files from the switch os contain copyrighted data and can't be shared online that's why the nxtheme format has been developed, it contains only differential info and can be freely shared. Unless you're dealing with making your own patches and custom layouts you should only use nxtheme files.

Getting started

To use custom themes you need an hacked switch that's at least on firmware 5.0

Installing themes

This is the most common scenario, you just need the theme installer homebrew.
Make a folder called themes in the root of your sd card and copy your themes in either nxtheme or szs format in it. Then launch the theme installer and you should be able to select and install them.
Reboot and your theme should be applied.

Note that each file is a single home menu part (eg just the lockscreen or just the main menu), a full home menu theme is composed by multiple nxtheme files.

To remove a theme just select uninstall in the theme installer. You can just install a different theme to overwrite the currently installed one.

When a new firmware comes out before upgrading (or downgrading) remember to uninstall any theme you have installed to avoid compatibility issues, if you forget your console may not boot untill the theme is removed as explained next.

In case your console doesn't boot anymore due to a bad theme (mostly with szs themes) delete the \atmosphere\contents\01000000001000 folder from your sd (it's \<cfw name>\titles\01000000001000 for old atmosphere and other CFWs), now your console should be booting, launch the theme installer and select uninstall theme to finish the cleanup process.

Making themes

To make themes you need either the Theme injector application or the web version.

Format differences

In the past themes have been distributed as szs files, this is not supported anymore as these szs files also contain copyrighted data, now you should only use the nxtheme format.

Making an nxtheme

Open the injector and go to the NXThemes builder tab, open any 720p JPG image (1280x720 pixels), select a custom layout and click on build nxtheme.

For making themes you can only use JPG images or DXT1-encoded DDS images. For best quality it's better to manually encode the image to DDS so you can have a preview of how will it look like with the compression applied.

Linux Support

The GUI only works on windows, on linux you can use the CLI through mono, you will need the mono-complete package.
Then you should be able to launch the app by running mono SwitchThemes.exe help.

Command line usage (CLI)

Building nxthemes

SwitchThemes.exe buildNX home "<your image.png/jpg/dds>" "<json layout file, optional>" "name=<theme name>" "author=<author name>"  "out=<OutputPath>.nxtheme"

this will build a theme for the home menu, instead of home you can use: lock for lockscreen, apps for the all apps screen, set for the settings applet, user for the user page applet and news for the news applet. Only the image and out file args are needed.
Other options specific to the theme target such as applet icons are availbale as well, run SwitchThemes.exe help for more info

Remote install

Launch the theme installer and select remote install, then run the following command:

SwitchThemes.exe install 192.168.X.Y "<nxtheme/szs file>"

Where 192.168.X.Y is your console IP address.

Custom layouts

Custom layouts are JSON files that allow changing the appearence of the home menu by moving the UI components.
To create a custom layout you will need the original home menu szs files found in /themes/systemData on your sd (if you ever used the theme installer) and a tool capable of editing them like the switch layout editor.

Here you can find more info about layouts and the supported properties.

For layout editing read the Layout editor wiki to get started, parts of the main home menu layout are documented in this repo wiki.

More Repositories

1

SysDVR

Stream switch games to your PC via USB or network
C++
1,196
star
2

dvr-patches

System patches to stream most switch games with sysdvr
125
star
3

OdysseyEditor

Experimental level editor for Super Mario Odyssey (EditorCore plugin)
C#
77
star
4

TheFourthDimension

A super mario 3d land level editor
C#
43
star
5

theme-patches

Qlaunch patches needed for custom themes but hosted on another repo
42
star
6

EditorCore

Extensible 3D level editor
C#
39
star
7

LocalDns

A local dns server, implemented in c#
C#
16
star
8

MakeEmu

A simple tool to flash sd cards for Atmosphรจre's emummc on windows
C#
14
star
9

Chip8CIL

Barebones C# Chip8 emulator with dynamic CIL recompilation, and benchmarks
C#
10
star
10

SysThemeSwitcher

Custom sysmodule for the switch to automatically change the theme on boot
C++
5
star
11

Windows-shit

Windows registry keys and scripts to quickly bring fresh installs up to speed
Batchfile
4
star
12

Yata-online

In-browser 3ds theme editor
C#
3
star
13

3DS-js-interpreter-with-Bridge.NET

Js and C# homebrews on 3DS
C
3
star
14

EditorCore-Examples

[POC] Mario kart 8 deluxe and Captain Toad level editor (EditorCore plugins)
C#
3
star
15

Uvc_dev

C
1
star
16

libusb-builds

Libusb builds for mac os. Used as binary dependency in other projects
1
star
17

yi-streamer

Parses and streams to a browser the content of the /tmp/view ring buffer used on certain yi ip cameras. May work only on specific models, tested only on dome1080p.
C
1
star
18

Amiigo

Backup/Restore Amiibo(s) with your windows phone
C#
1
star
19

XHideBatterySaver

Hide the annoying battery saver color from the status bar
Java
1
star
20

nxIpc

Simple C++ lib to create an IPC service on switch
Makefile
1
star