[How-To] Stream clothes and props as addons, for MP Freemode models

Hello, please read the whole topic, don’t skip steps, and read carefully.

In this tutorial it will be explained how to do addon clothes at the end of current clothes.
Before I start explaining how to do anything, let me explain how i’m gonna call everything in this tutorial:
  • Component - There are 12 different components, each corresponds to a different number and a “slot” on our ped model. (head, berd, hair, uppr, lowr, hand, feet, teef, accs, task, decl, jbib)

  • Prop - There are 13 different prop slots, but only 5 are used in GTA (p_head, p_eyes, p_ears, p_lwrist, p_rwrist)

  • Drawable - Each .ydd is a different drawable, for example we are using one component with three drawables (jbib_000_u*, jbib_001_u* and jbib_002_u*), each drawable has a different number, starting at 0.

  • Texture - Each drawable can have up to 26 textures (a-z). Components and props have different structure how texture is named:

    • Component texture name: xxxx_diff_###_(a-z)_uni*, for example: “jbib_diff_005_g_uni”
    • Prop texture name: p_xxxx_diff_###_(a-z), for example: “p_head_diff_010_h”
  • .YMT - Extension of file which corresponds to how many components, drawables and textures the game will use.

*Each drawable can have suffix _u or _r, which stands for:
_u = universal
_r = race

It is important how we name our drawable, because we have to name texture properly too.
Each texture can have suffix _uni or _whi (or few different, most used is _whi)
_u = _uni
_r = _whi (or different one)
It will be explained later how to know if our drawable supports race.

Step 1

What will be needed?

YMTEditor https://github.com/grzybeek/YMTEditor/releases
OpenIV https://openiv.com
Few clothes which we want to use as add-ons

In tutorial i will use these three different mods:

Step 2

Prepare files and YMTEditor

In YMTEditor you can create a new .ymt file, or open an already existing one to edit it, in the tutorial I will cover only creating new from scratch.

Open/Save (YMT) - opens a file with extension .ymt
Open/Save (XML) - opens a file with extension .ymt.xml (It can be exported/imported by Codewalker RPF Explorer)

In the tutorial, we are going to click on New.

After clicking “New”, another window will pop up and we have to select for which MP character our .ymt will be done, for this tutorial I will choose female. Also, we have to type the name of our .ymt file, it can be whatever you want, and click submit.
Important: Your ymt name should be all lowercase!

After that, we have to unpack our downloaded clothes, if downloaded files contains files for SP(Singleplayer) it will be easier to use them (we don’t have to delete prefix)

Let’s prepare our files completely and move them to one folder

I’ve removed the “mp_f_freemode_01^” prefix from pants(lowr), and changed their number from 011 to 000 - because we don’t have anything in our addon .ymt yet.

And changed from jbib_003 to jbib_000 and jbib_007 to jbib_001 - because we don’t have anything in our addon .ymt yet, those are the first two.

The next step is adding our own prefix, it will be the full YMT name from YMTEditor, in my case it will be mp_f_freemode_01_tutorial_clothes, and that is how our files should look like:

Step 3

Adding new entries in YMTEditor

Let’s go back to our YMTEditor and enable the components that we are using.
(In our folder there are models named jbib and lowr only, so enable it)

Now expand LOWR, you can see that we have already drawable number 000 added in the editor, but it says “Textures: 1”, expand the “view textures” button, and let’s add 24 more (there is 25 in total, the last letter is y)

But there is another thing, we have to do for our pants to work properly, at the beginning of tutorial i’ve mentioned that drawables can be either with suffix _u or _r, and our lowr(pants) are ending with _r and textures with _whi

To check if the person that did this mod, did this properly, we have to use OpenIV, simply just drag .ydd and one texture to the “mods” folder in OpenIV (if you don’t have it, just create it) and double click them.

If our model contains this part of model (it can be bigger, if pants were shorter), and our texture contains piece of skin texture in left-bottom corner, so we can use suffix _r and _whi in our .ymt

(Note that im showing only lowr, each different component that uses skin, could have it in different position, lowr = always left bottom corner. For other components, check original r* component and check where is their skin texture located on texture!)

Simply, to enable that so “game knows” we are adding model that contains skin data, change propMask value in YMTEditor to 17/19/21 (usage of different numbers is unknown, i’m gonna use 17)

Now collapse LOWR and expand JBIB

Since we are going to add two jbib drawables, we need to click button “Add new drawable”

Now add textures to each drawable, 000 has 14 textures (a-n)
And 001 model has 12 textures (a-l)

Step 4

Saving and preparing other files

To save, just click File > Save (YMT) and keep name of our file(don’t change it!, it is important to keep all same names)

Now navigate to your resources folder on your server, and create a folder with the name of your choice, i’m gonna name it “tutorial_clothes” to keep names the same.

In folder “tutorial_clothes” create another folder called “stream”

Now open text editor of your choice (i’m using notepad++)

And put that inside, and edit it with your YMT names!

<?xml version="1.0" encoding="UTF-8"?>



pedName = name of ped our ymt is for, we did for female so it is “mp_f_freemode_01”

dlcName = name of our ymt, we named it “tutorial_clothes”

fullDlcName = pedName + dlcName, so it will be our YMT name as well “mp_f_freemode_01_tutorial_clothes”

eCharacter = i don’t know usage of it, we are using female ped so put “SCR_CHAR_MULTIPLAYER_F”, male uses: “SCR_CHAR_MULTIPLAYER”

creatureMetaData = i’ve named it with the name of our chosen name (we are not using this file anyway, it can be left empty. This file “tells the game” that we are using “expressionMods” field in our .ymt - it is used to do heels shoes, or hide hair with hats - it is complicated, maybe i will explain it in other tutorial Explained here: [How-To] Create addon heels OR hide hair with addon hat)

Save it as “mp_f_freemode_01_tutorial_clothes.meta” (it can be any name, i kept it the same like names before)

And create another file with this inside, of course edit it with your names!

fx_version 'cerulean'
game 'gta5'

files {

data_file 'SHOP_PED_APPAREL_META_FILE' 'mp_f_freemode_01_tutorial_clothes.meta'

In “files” section, we have to type the name of our .meta file we just did before, I have to put: “mp_f_freemode_01_tutorial_clothes.meta

Under files section, we have to specify data_file that our .meta file is using, in our case it is “data_file ‘SHOP_PED_APPAREL_META_FILE’ ‘mp_f_freemode_01_tutorial_clothes.meta

And save that file as “fxmanifest.lua

Step 5

Copy our YMT, model and textures

And the last step before going into the game, we have to put our .ymt file we saved before, and our .ydd/.ytd files we prepared before into the “stream” folder.

Simply just put everything into it, if you want to, you can segregate them by your choice, you can create infinite amount of folders inside “stream” folder

Next step is to add starting line to our server.cfg (or any other place you are starting all your resources)
Add this line, it can be either start or ensure: “start tutorial_clothes” (If you used different name for your resource folder, change it!)

Step 6

Testing in game

Simply just go in game, and change your skin/components (with any script, in the section where you have pants and tops) to the last number, since we did addon, it will be at the end.

You can manipulate order of your addons by adding “dependency [scriptname]" in fxmanifest.lua,

for example: “dependency clothes_1”, so resource called “clothes_1” will be started before our resource “tutorial_clothes”

And…. our clothes work!

And skin tone color does change in our pants!

A few words at the end

I hope I wrote this tutorial quite understandably, if you have any questions, feel free to ask!

Also, I didn’t say how to add props, it’s simply same way as everything else, but the name will be for example for p_head:

  • ydd: “mp_f_freemode_01_p_tutorial_clothes^p_head_000”
  • ytd: “mp_f_freemode_01_p_tutorial_clothes^p_head_diff_000_a”

Second tutorial about making high heels for females, and hiding hair with addon hat


Solid tutorial :+1:


Excellent and comprehensible tutorial ! This is what i was waiting for so long :smiley:

Can’t wait for the little update when it come to boots/heels, and how it’s managed.


the YMT editor is amazing :smiley: Great tutorial too!


Amazing editor! Motivated me to start creating a whole new themed clothing pack. I’m also awaiting the heels and boots updatel or tutorial.




Great tutorial. I had one question regarding the props, such as head and eyes. Do I have to do anything different to get them working within the same YMT?


@cptskeezo Thanks! It’s said at the bottom of tutorial, just add with editor and names for example will be:

  • ydd: “mp_f_freemode_01_p_tutorial_clothes^p_head_000”
  • ytd: “mp_f_freemode_01_p_tutorial_clothes^p_head_diff_000_a”

Apologies! I did see it :slight_smile: Shortly after I asked the questions I realized I made a punctuation error when renaming files. Thanks again for the tutorial!


and what about the high heels? does it also work with this method?


@Mdurazno Doing addon heels requires one additional file, I might do a small tutorial in near future about it


that’d be very helpful

1 Like

do you know how to fix hair to use masks correctly?

1 Like

@Sta.Quinzel Uh yeah, I know, but that’s complicated process and there is a little catch.

First of all, there is difference between doing “addon hair + addon/default gta masks” and “default gta hair + addon masks”.
Addon hair requires to have specific bone applied and rigged properly, which 95% of custom made hair doesn’t have, and then if you want to use addon hair with addon mask, it require additional file (same as for the heels).

But if you want to your addon masks work with gta hair, you are going to need just that additional file. I’ll probably cover that in my next tutorial regarding heels/masks/hair


First of all i love you for that Tutorial <3
Literally one of the best tutorials i have ever read.

But i still have a question:

U mentioned the part with the priorities of our created DLC Clothings…
Is there a way that i force the server to load all R* clothes before the DLC clothes ?

I could be wrong but im pretty sure that it is all over the place on my server …

Thanks again for ur tutorial and ur help


@AndrewJackson Thanks!

All R* clothes should load at first, then your all resources that contain clothes. Maybe you have some replacements streamed and that’s why you think it is all over the place?



k thanks then i have to look back into it…
Changed from a selfmade GTAUtil pack to ur version and im pretty sure that i dont have any replacements…

Maybe Serverside or Client side Cache fked me over…

Thanks for the Help my friend

1 Like

Hey Grzy, so I’ve managed to get my stuff halfway working, and renamed, but it’s not showing up as the models I put them in as when I stream them to the server, am I missing something, or is it just an issue with the server? Attached below is what I’m referring to, i’ve selected a few of the ones I just installed. Please let me know when you can.


@Strict What? I don’t understand what you mean. If you followed my whole tutorial then it should work properly, if it doesn’t then it means you did something wrong.

Stuff on your screen loads, so I don’t understand what exactly is your problem

1 Like

It has the slot and texture counts correct, however, it doesn’t load the Corresponding YDDs and YTDs that are in there with it. like it’s loading base game stuff. Maybe I’ve messed up somewhere, or something, idk, I’ll reread, cause I found my main mistake I had from before, which is good, so I’ll redo it again, see if I can’t get it to work.

Thanks for any assistance you can give.

1 Like