Your own inventory preview icons
How to add custom preview images by using a custom .inkatlas file
Summary
Uploaded: ??? by manavortex Last documented update: Mar 18 2024 by yellingintothevoid
This guide will teach you how to make custom inventory preview icons.
Technically, this guide is a subsection of the ArchiveXL item additions guide, but you can use it to make any kind of preview item.
The guide below will teach you how to make preview icons. While it's a technically a subsection of the ArchiveXL item additions guide, you can use the steps below to make any kind of preview item.
Difficulty Level: You know how to read and can either edit images or make use of the corresponding guide. While the process is easy, it also is, unfortunately, quite tedious!
Wait, this is not what I want!
If you want to have gendered preview icons, check here.
For a script to generate inkatlas files, check The Magnificent Doctor Presto's github
To learn more about the files involved, check Game icons: The inkatlas file
The required files
If you downloaded the example project (Getting the files), the preview is already hooked up. Otherwise, download the template archive for your kind of template (kindly provided by Apart).
Go away with your examples, I'll do everything by hand!
Okay, you do you. Here's how:
You should now have a structure like this:
Taking preview pictures
You have two options on taking preview pictures. Both are relatively tedious, since you have to do it by hand. This is not a step-by-step, but you can find a few pointers here:
Blender
You can export your mesh with all its materials to Blender and take your preview pictures there:
In-game
This part of the guide is a bit longer, since it tells you how to get decent-quality preview pictures. If you don't care for that (you should, but we all hate it), you can skip ahead to Hooking up the inkatlas.
Overview of the Process
The idea is to combine mods that make V invisible and a ReShade filter called DepthAlpha.fx to create in-game screenshots of your item where the background is transparent. This means you don't have to spend a lot of time painstakingly removing the background manually in Photoshop. The screenshots taken with DepthAlpha.fx only need a little bit of cleanup (Creating The Actual Icon), but can be basically directly imported into the .xbm
file containing your icons.
Using ReShade is, of course, entirely optional, but teaching how to mask out objects in Photoshop is outside the scope of this tutorial.
Prerequisites
Invisible V by manavortex or the Invisibility Cap and Shoes by PinkyDude
Optional, but highly recommended:
DepthAlpha.fx (make sure to set up the depth buffer properly)
AppearanceCreatorMod or Equipment-EX
The Process
Preparation:
Start the game
Equip the invisibility garment and the item you want to create icons for.
To switch through appearances on-the-fly, you can use AppearanceCreatorMod while V is in the center of the camera.
Alternatively, you can save outfits for all colour variations of your outfit In Equipment-EX:
Lighting:
Optional: Finding a good spot
If you can't be bothered, you can simply teleport to the window of Saburo's office:
Make sure to have some decent lighting on your item.
Sometimes, it can be helpful to disable RTX to create icons. The screenshot of item on the left in the image below was taken using Path Tracing and DLSS, the one on the right using rasterised lighting without DLSS:
If your item is a jacket, the shadows on the inside can look broken with RTX.
If your item is jewellery made from glossy metal, you might get unwanted reflections with RTX.
If your item features fine textures, you might want to disable RTX, so that you can also disable DLSS/FSR without burning up your graphics card.
If your item is a piece of clothing made from glossy material, you might want RTX reflections.
Taking the screenshots
To actually take the screenshot, position the Photo Mode camera so that it is rougly parallel to the bottom edge of your photo booth.
Set the Field of View to about 30 to prevent distortion when taking a closeup.
Move the camera so that the item fills the entirety of your screen without cutting off a part of it.
If you're using ReShade:
3.1 Enable DepthAlpha.fx in ReShade. Check Colorize Transparency
and adjust the Range
until your item is the only visible object in the scene.
3.2 Disable Colorize Transparency
and take the screenshot using ReShade (not the built-in Photo Mode).
Switch to the pose tab and cycle through all appearances of your item and take a screenshot of each one (make sure you haven't skipped any!).
You can use AppearanceCreatorMod to switch appearances without changing the tab!
Photoshop
Fixing Jaggy Edges Left By DepthAlpha.fx
Open the first of your screenshots in Photoshop and drop all other screenshots of the item onto the one you've just opened.
Select the newly created Smart Objects, right click them and select "Rasterize Layers".
Select the first layer and hide all other layers.
Go to "Layer" in the menubar at the top of your screen on the left and select "Layer Mask" → "From Transparency".
Create a new colour fill layer and choose a colour that contrasts with your item.
Double click the layer mask on your first layer in the layers window to enter Select and Mask mode.
Make sure your View Mode is set to "On Layers" and play around with the "Global Refinements" until the outline of your item looks smooth.
Smooth <5, Feather <1, Contrast 30-50, and Shift Edge of around -30% works quite well usually. Highly depends on how intricate your item is.
Duplicate the Layer Mask onto your other layers.
From here on out, you can play around with a bunch of Adjustment Layers with Clipping Masks for each of your layers/appearances. I recommend some Levels Adjustments to set proper black and white points, as well as Black & White Adjustment Layers for items that are black, grey, silver or white and so on.
Once you're done with that, select each layer and its Adjustment Layers, right click them, and select "Convert to Smart Object".
Give each layer a meaningful name and save your image as a
.psd
.
Creating The Actual Icon
Open this
.psd
and import the Smart Objects of your icons into it. The.psd
is based on thepreview_icons.xbm
found in manavortex's Archive XL item additions and guide and can be easily used with projects based on the guide.With all layers selected in Photoshop, transform them so that the longest side is 158px.
Align each item to the centre of each grey square.
Hide all other layers except your icons.
Now save the image as a
.png
in the raw folder of your WolvenKit project.Import the
.png
into your WolvenKit project with theTEXG_Generic_UI
TextureGroup
setting and make sure that "Transparency from alpha channel" is enabled.
Hooking up the inkatlas
Open the file in WolvenKit.
Open the list
slots
.For the first two
inkTextureSlot
items, set the value forDepotPath
to the relative path of your xbm (tutorial\torso\my_custom_shirt\ops\preview_icons.xbm
):
Save the file. If it doesn't update, reload it (Hotkey:
Ctrl+R
)You now have a tab "PartMapping", where you can see which texture corresponds to which slot: select it on the left and check the
partsName
, which corresponds to the entry in the slot'sparts
array:
Congratulations! You now have preview icons!
Using it
You can now hook up your preview icon(s) to whatever mod you are making.
If you want to use gendered preview icons, check here. In this case, you do not add an icon record to your item.
ArchiveXL: Add it to the .yaml
Check the code box below — the last three lines add a preview icon.
Please refer to the ArchiveXL guide for an explanation of the other properties, as this page will only hold information about preview icons.
atlasResourcePath
: relative path to your .inkatlas fileatlasPartName
: slot name in your .inkatlas file (which you can see in thePartsMapping
tab)
Again, please note that indent is crucial here, as it determines the node structure. The first line needs to have an indent of 0, the lines from $base
to icon
need to have two spaces, and the lines atlasResourcePath
and atlasPartName
need to have four.
That's it! Time to test!
If you run into any issues with your texture's transparency, please check the textures import/export guide!
Last updated