description |
---|
How to add custom preview images by using a custom .inkatlas file |
Uploaded: ??? by manavortex
Last documented update: Mar 18 2024 by yellingintothevoid
This guide will teach you how to make custom inventory preview icons.
{% hint style="info" %} Technically, this guide is a subsection of the ArchiveXL item additions guide, but you can use it to make any kind of preview item. {% endhint %}
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!
- 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.md
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).
Okay, you do you. Here's how:
Finding the files by hand
- search in Wolvenkit for
icons > .inkatlas
- Pick one of CDPR's icon files (look inside first, you want the right kind of icon — weapons have different icons than equipment) and add it to your project
- Right-click on the file in the asset browser and select "
find used files
" - Find the
.xbm
file and add it to your project as well - Move both of these files to your custom folder, as you don't want to overwrite game default icons
- Optionally: Re-name them. This guide assumes that they're named
preview_icons.inkatlas
andpreview_icons.xbm
You should now have a structure like this:
tutorial
ops
- my_tshirt_factory.csv
- translation_strings.json
- preview_icons.inkatlas <<<
- preview_icons.xbm <<<
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:
You can export your mesh with all its materials to Blender and take your preview pictures there:
{% hint style="info" %} 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. {% endhint %}
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.
{% hint style="info" %} Using ReShade is, of course, entirely optional, but teaching how to mask out objects in Photoshop is outside the scope of this tutorial. {% endhint %}
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
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:
{% hint style="info" %} Optional: Finding a good spot
If you can't be bothered, you can simply teleport to the window of Saburo's office:
Game.GetTeleportationFacility():Teleport(GetPlayer(), ToVector4{x=-1349.5053710938, y=138.80358886719, z=545.84600830078, w=1}, ToEulerAngles{roll=0, pitch=0, yaw=0})
Make sure to have some decent lighting on your item. {% endhint %}
See the long version
- Enter Photo Mode and build a black photo booth around V that looks like the one in the screenshot above using AMM. The AMM Props - PhotoStudio are very useful for this.
- Save your photo booth as an AMM preset to create similar looking icons across all your mods.
- It's also very useful to make sure the angle of the camera in relation to V remains similar across all your icons:
- Exit photo mode and look at the lower edge of your photo booth.
- Align the edge with the bottom of your screen, to ensure V is positioned parallel to the photo booth (this will make more sense later).
- Enter photo mode again and rotate V to about +15 in the Pose tab.
- Add some area lights to the scene. The goal is to highlight the shape of the item. So aim for deep shadows, lots of contrast, and prominent contours. In the screenshot below, there are four lights: two from each side behind the item as rim lights, one at a roughly 45° angle in front and above the item as key light, and one of very low intensity directly in front of the camera to fill in shadows.
{% hint style="info" %} 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. {% endhint %}
- 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.
{% hint style="info" %} 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).
{% endhint %}
- 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!).
{% hint style="info" %} You can use AppearanceCreatorMod to switch appearances without changing the tab! {% endhint %}
- 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.
{% hint style="info" %} 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. {% endhint %}
Before / After
- 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
.
Adjustment Layers | Converted to Smart Objects |
---|---|
- 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.
- 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:
{% hint style="success" %} Congratulations! You now have preview icons! {% endhint %}
You can now hook up your preview icon(s) to whatever mod you are making.
{% hint style="info" %} If you want to use gendered preview icons, check here. In this case, you do not add an icon record to your item. {% endhint %}
Check the code box below — the last three lines add a preview icon.
Items.my_custom_shirt_redwhite:
$base: Items.GenericInnerChestClothing
entityName: my_custom_shirt_factory_name
appearanceName: appearance_root_entity_white_red
displayName: my_shirt_localization_name_white_red
localizedDescription: my_shirt_localization_desc
quality: Quality.Legendary
appearanceSuffixes: []
icon:
atlasResourcePath: tutorial\torso\my_custom_shirt\ops\preview_icons.inkatlas
atlasPartName: slot_01
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)
{% hint style="warning" %}
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.
{% endhint %}
If you run into any issues with your texture's transparency, please check the textures import/export guide!