News for the Ikemen Go Tag!!
New Patch launched!! 19/06/2024
Version for Nightly Build of Ikemen Go as November 2024.
Fixed by Horse after a new build deprecated an important SCTRL. I appreciate the help.
Added config.ini settings for Nightly Build.
Download it here.
Version for Ikemen Go 0.99 stable.
Download it here.
Patch notes
Added support to Ikemen Go 0.99 and Ikemen Go Nightly Build.
Tag files are contained inside a folder and it is not necessary to overwrite files.
Many bug fixes.
New files to manage sounds, graphic effects and animations added.
How to install and use Orochi Kyo’s tag.
First, use the links shared above this section to download the right TAG version. If you are using Nightly you will have access to some fixes that are not stable. Remember that Nightly is “unstable” and only for enthusiasts who want to test the new features sooner.
Next, unzip the file and copy the folder “tag” to your Ikemen Go’s “data” folder. Go back to the main folder and open the “Save” folder. Open the config.json(0.99) or config.ini(nightly) and edit to look it this way.
Ikemen Go 0.99
“CommonAir”: [
“data/common.air”
],
“CommonCmd”: [
“data/common.cmd”,
“data/tag/orochi_kyo_tag_commands.cmd”
],
“CommonConst”: [
“data/common.const”,
“data/tag/orochi_kyo_tag_constants.const”
],
“CommonFx”: [
“data/tag/orochi_kyo_tag_system.def”
],
“CommonLua”: [
“loop()”
],
“CommonStates”: [
“data/functions.zss”,
“data/action.zss”,
“data/dizzy.zss”,
“data/guardbreak.zss”,
“data/score.zss”,
“data/tag/orochi_kyo_tag_main_wire_attack.zss”,
“data/tag/orochi_kyo_tag_main_file.zss”,
“data/tag/orochi_kyo_tag_sfx.zss”,
“data/training.zss”
],
Ikemen Go Nightly
; -=====================================================-
; Configuration file for Ikemen GO
; -=====================================================-
; ——————————————————————————-
; Common data running on characters, affecting match globally.
; Common parameters support arrays, with values separated by commas.
[Common]
; Common animations using character’s local sprites
Air = data/common.air
; Common commands
Cmd = data/common.cmd, data/tag/orochi_kyo_tag_commands.cmd
; Common constant variables
Const = data/common.const, data/tag/orochi_kyo_tag_constants.const
; Common states (CNS or ZSS)
States = data/functions.zss, data/action.zss, data/dizzy.zss, data/guardbreak.zss, data/score.zss, data/system.zss, data/training.zss, data/tag/orochi_kyo_tag_main_wire_attack.zss, data/tag/orochi_kyo_tag_main_file.zss, data/tag/orochi_kyo_tag_sfx.zss
; Common packs of graphic and/or sound effects called during the match by using
; a specific prefix before animation and sound numbers (like lifebar fightfx)
Fx = data/tag/orochi_kyo_tag_system.def
; External modules (no need to add modules placed in external/mods directory)
Modules =
; Pure Lua code executed on each frame during match
Lua = loop()
After the TAG installation
If you see this text box in the training mode, it means the tag was installed correctly. These are the default commands to use the tag in a match.
Press Forward + Tag Button: Normal Assist.
Press Back + Tag Button: Super Assist. Needs 1000 of power.
Holdown half-second then presses the “Tag” button: Normal Switch.
Press the “Tag” button while performing an air combo: Air Switch. Needs 1000 of power.
Press the “Tag” button while doing ground combo: Combo switch. Needs 1000 of power.
Press down twice then the “Tag” button: Call partner, then you can control both chars on screen. Needs 3000 of power.
Press the Tag button while performing a super/hyper movement: Hyper Switch!! Needs 1000 of power.
Hold back then press the two Tag buttons: Triple Menace!! Needs 3000 of power.
For those people always asking if you can change these commands, check the orochi_kyo_tag_commands.cmd, but maybe you would need to disable some features to not override other commands.
Standard notation for State numbers is like this
200-499: Ground attacks, including stand and crouch.
600-699: Air attacks.
1000-2999: Special Attacks.
3000-4999: Super and Hyper attacks.
Mugen creators did not pay much attention to the importance of this “standardization” so they use whatever state number they had available, not caring about any future implementation of their chars into modules.
Also, maybe you don’t like state 1000 or 3000 to be used as an assist, because state 1000 could be a counter and 3000 could be a grab, not useful as a tag assist.
How to use constants to customize your Tag experience!
Ikemen Go is amazing. A lot of new features and stuff for players plus cool stuff for coders. Constants are great to customize easily any module. I implemented many constants in my TAG system so you can override any setting per character!!
First, let’s learn how to declare constant. Open your char in Fighter Factory and go to the main CNS file of the char.
Below the [Movement] parameters create a new section called [Constants]
Let me explain the most important constants in the Orochi_Kyo’s TAG system (Yes, I am speaking in third person, like that evil guy in Superman 2). As a base I will use some Samurai Shodown 4 Cham Cham character which uses the most weird stateno numeric notation I ever see: 200-229 for normal ground attacks, 230-250 for air attacks, 400-499 for special attacks, 500-599 for super/hyper attacks.
These are the most important constants, these are mandatory to use the Tag System!.
switchAttack = 233 ; Expecting an animation number.
In my Tag system, you can choose between your char entering the screen after switch running or performing an attack(Check the OFF/ON section in the common.const file). The “switchattack” constant defines which animation should be used for the attack if mvc1switch in the common.const is set to “1”.
Air attack animation is preferred.
switchAirAttack = 233; Expecting an animation number.
The animation used in the Air Switch on combo, is a feature that is loosely based on Ultimate Marvel Vs Capcom 3 Air Switch.
snapBackAttack = 209; Expecting an animation number.
The animation used for the snapback attack. Snapback is a feature that forces the enemy player to switch for a partner if got hit. Please, do not use animations that have loops or have -1 as a time in the last frame. It will cause the player to get stuck.
snapBackHit = 5030; Expecting an animation number.
The animation will be used if the player gets hit by a Snapback attack. 5000-5070 states often contain animations fit for this feature.
StateTagAssistSuper = 411; Expecting a state number.
The state number that contains or starts the special attack for normal assist. Sorry for the confusing name. Use a special(not super or hyper) attack for this.
StateTagAssistHyper = 500; Expecting a state number.
The state number containing or starts the super or hyper attack for the “Hyper Assist” and the “Triple Menace” feature.
tauntWhileWaitingForPartners = 195; Expecting an animation number.
The animation used if the “tauntAfterMVC1Switch” constant is set to 1 in the common.const. Also it is used when the team leader calls for a “Triple Menace attack”.
It seems Cham Cham is ready to use the tag. She now can perform normal assist, super assist and Triple Menace. But wait!!
Many features of the Tag system still rely on combo detection.
Air combo switch expects char’s air attacks to be between 600-699.
Switch on Combo expects normal ground attacks to be between 200-499.
Switch on Hyper expects super/hypers states to be between 3000-3999. This is a feature that allows you to switch while on Hyper, the entering partner will automatically execute a hyper attack.
I got you covered there!!
Constants for combo detection
Disclaimer: Only use these if your character is having issues using “while on combo” features like the ones previously mentioned.
normalAttacksStartStateno = 200 ; the stateno that starts ground attacks
normalAttacksEndStateno = 239 ; the stateno that ends ground attacks
airAttacksStartStateno = 230 ; the stateno that starts air attacks
airAttacksEndStateno = 250 ; the stateno that ends air attacks
For stand, crouch and air attacks
specialAttacksStartStateno = 400 ; the stateno that starts special attacks
specialAttacksEndStateno = 499; the stateno that ends special attacks
superAttacksStartStateno = 500 ; the stateno that starts super attacks
superAttacksEndStateno = 599 ; the stateno that ends super attacks
For Super, Hyper and Special Attacks.
With these constants, we are setting a range. The range will include any state number including the “StarStateno” and the “EndStateno. So any state between these values could be used by the TAG system to properly detect combos.
Using the TAG debug mode
I created a debug mode that only shows if you enter the Training Mode and select TAG as the Team Mode. You can turn it off just pressing the start button. With this debug mode you can check many values needed to config the Tag system properly.
Team Leader Stateno
Check the current State number of the team leader
Team Leader Anim and time
Check the current animation and the animation time of the team leader
Partner Stateno
Check the current state number of your current first partner. This is useful if your partner get stuck while assisting, you can more info to debug the issue properly.
Partners Ready
Shows how many partners’ cooldown time is over and ready to assist or switch
Enemynear stateno
Shows the current state number of the enemy team leader, using enemynear,stateno. Since it is using “teamleader = playerno” as a trigger, enemy team partners could not affect the value of this item.
Enemynear Partnerstateno
Shows the current state number of the enemy team’s first partner.
Use this debug mode to get the info necessary for the character constants.
Helpers!!!
Helpers are the devil. Most of them are used in Mugen as a workaround for the variable limitation. But Mugen developers never thought we would need to detect when the helper hits the opponent or other helpers. So literally, projectile helpers just break “projhit”, “projhittime”, “projcancel”, etc. To be honest, it is not all Elecbyte fault. Some creators used helpers for projectiles just because they wanted to do so.
There is a way to detect when a helper is hit or is being hit, but you need the exact helper number. This is almost impossible to get when you are facing dozens of different characters ported to Mugen by many creators.
So if your char is not switching on combo while using a “projectile”, it is highly probable because we are dealing with a helper.
This could be useful too for movements that put the opponent in a custom state
Dealing with a helper
I created some code that would allow you to use the TAG combo features with helpers. Using the current state number and a custom time set by you, you can personalize a chain that uses a helper.
StateTagAssistSpecialCustom1 = 1000
This is the current state number the character(not the helper) must be.
specialTimeStartCustom1 = 20
This is the time from which the “switch in combo” can be activated.
specialTimeEndCustom1 = 40
This is the time from which the “switch in combo” can NOT be activated anymore.
StateTagAssistHyperCustom1 = 3000
This is the current state number the character(not the helper) must be.
hyperTimeStartCustom1 = 20
This is the time from which the “Hyper Switch” can be activated
hyperTimeEndCustom1 = 40
This is the time from which the “Hyper Switch” can NOT be activated anymore.
To put in “CNS words” this is like declaring a trigger to create combos in command.cmd file.
trigger1 = stateno = 1000 && time = [20,40]
You can declare up to five of these for each “Switch on Combo” and “Hyper Switch”. For example:
Does this really work or I just bluffing?
Take Rugal Bernstein by Vans for example. Vans didn’t use the normal projective sctrl because he made his character compatible with his own projectile mirroring. So Rugal’s Repukken fireball is a helper. None of the TAG combo features will work with that helper, because projhittime, the trigger I am using for projectile detection, doesn’t works with it.
StateTagAssistSpecialCustom1 = 1000
specialTimeStartCustom1 = 20
specialTimeEndCustom1 = 50
I inserted these inside Rugal’s [Constants] block.
Now Rugal can use his Repukken fireball(helper) on combo and activate “switch on combo” feature!!
Why you should stop being lazy and use constants
Constants works this way. If the constant is not declared anywhere in the char files, Ikemen Go will use the one declared in the common.const. This way you can create a common value between all the characters in your Ikemen build or full game.
But if the same constant is declared in the char files, Ikemen Go will completely ignore the constant value declared in common.const.
This is very useful for my tag system! Let’s say you have a Marvel vs Capcom Ryu and Kyo Kusanagi from KOF 2002. You can copy some of the TAG constants and use them to personalize the tag for each of them.
MVC Ryu constants to make him like MVC
mvc1switch = 1;
airSwitch = 1;
switchOnNormalOrSpecial = 0;
variableCross = 1;
tripleMenace = 1;
partnerAssistOn = 1;
partnerSuperAssistOn = 0;
superpauseForAirSwitch = 1;
superpauseForComboSwitch = 1;
tauntAfterMVC1Switch = 1;
reverseSnapBack = 0;
superSwitch = 1;
fallOnMVC1Switch = 1;
tauntAfterMVC1Switch = 1;
superSwitch = 0;
showPartnersAtIntro = 1;
assistCallWhileGuarding = 1;
instaSwitch = 0;
KOF Kyo Kusanagi constants to make him like KOF 2003/XI
mvc1switch = 1;
airSwitch = 0;
switchOnNormalOrSpecial = 1; KOF XI
variableCross = 0;
tripleMenace = 0;
partnerAssistOn = 0;
partnerSuperAssistOn = 0;
superpauseForAirSwitch = 0;
superpauseForComboSwitch = 0;
tauntAfterMVC1Switch = 0;
reverseSnapBack = 1; KOF 2003
superSwitch = 0;
fallOnMVC1Switch = 0;
tauntAfterMVC1Switch = 0;
superSwitch = 0;
showPartnersAtIntro = 0;
assistCallWhileGuarding = 0;
instaSwitch = 0;
This way you can have two characters using the same TAG system in completely different ways!!
Another example is to imagine you have a character and you consider its assist be very powerful. So you want this char to have a higher cooldown time for balance purposes.
TagAssistCooldown = 500; the default time is 200 ticks
Declare this inside the character [Constants] block and this char will have a higher cooldown time than the rest of the cast!
Hide partner’s custom health and power bars
Maybe you’ll run into this situation where you have many chars with custom health and power bars, and these are stacked one over another.
There is an option that is turned off by default in the constants configuration file
HidePartnerHelpersExplods = 0;
Setting this option to 1 will hide most of these bars but some of them will remain on stage due to poor coding or other reasons.
So what to do? In this case, you need to have some experience in Mugen CNS coding, locate the explodes used to show these bars on screen, and add this trigger
triggerall = root, playerno = root,team leader
This will help the “HidePartnerHelpersExplods” to hide those bars while the character that owns them is offscreen.
Troubleshooting
Let’s talk about most of the common problems I have run into with the TAG system. Maybe one of these could help you to solve your issues.
The main character went off screen but partner never came in when switching
Many circumstances could cause this but the 3 most common ones so far have been these:
1- Altered “localcoord”. The tag is ready to work out of the box with 240P and 720P characters. Altering the original “localcoord” will cause issues with the tag and the char’s code. If you want bigger or smaller characters in your Ikemen Go build use “zoomin” and “zoomout” in the [camera] stage settings or the “forcestagezoomin” and “forcestagezoomout” config.json in the save folder.
2-Taunt Animation. The constant “taunt While Waiting For Partners” is more important than the tag files describe. These constant expects an animation, not a state. Use an animation that has no -1 time at the end and no loops. Animations larger than 30 frames are recommended.
3-Do not use highly zoomed-out stages. Down to 0.7 for zoom-out is ok but below this value, the tag could have issues. I added some compatibility with zoomed-out stages but it is not complete.
Can you make the tag like this [insert game name here]?
Check the off/on settings in the orochi_kyo_tag_constants.const file. You will see a lot of options and customize the tag to your heart’s content.
Holding down time to switch is too long. Can you make it a press button only?
Because I want users to have the most features possible at once as some sort of feature showcase. With so many features, I can’t just have “switch character” on a single button press.
If you know a bit of CNS/CSS coding you can modify the tag commands and the part of the code where these commands are used. But if you do want to mess with code just edit the “holdDownForSwitch” constant to “5”, and you can easily use the “down + tag” button to switch, no more holding down for half a second.
The in-game and the debug text are out of place.
The “tag” system text placement comes for 4:3 and 16:9 aspect ratio but it is not set automatically, sorry.
Look for “text for Orochi Kyo TAG” in the orochi_kyo_tag_constants.const file and comment or uncomment the lines according to your aspect ratio. If you are 1280×720 use the 720p lines, for example.
Just down you will find the lines used for the few backgrounds. Use the same method, comment, and uncomment.
If you are using a custom aspect ratio other than 4:3 or 16:9, sorry but I cannot offer support. You are on your own.
I call assist and super assist attacks, partners enter the screen but then they leave immediately.
Check the instructions and see if you installed the minimal required constants in the chair’s main cns file.
If you did, then check the state you choose for the attack. If the state needs player interaction to go into another state it won’t work. For example, movements known as rekkas are not suitable for a stable tag experience.
Try another state with a simpler attack.
I am running into other issues not described here.
If you are having troubles or bugs with the my tag system there is a dedicated channel for my work in this DISCORD SERVER(click here). Please, if your intentions are asking me to personalize the “tag for your game” or add “more features”, please don’t. I am planning to add more features but at my own pace. I have to work in real life so I do not have time for personal full game projects.
Conclusion
I have put sweat, blood, and a lot of time and effort into making this TAG system totally configurable. Mostly for full game creators but also for casual players. What do you need to make it work properly? Just some little time and effort so your roster can communicate properly with my code.
Check the common.const file for more constants, recently I added some constants that would allow you to add different sounds and animations for every TAG feature. Use them to “spruce” Snapback, Switch on Combo, Air Switch, and Variable Cross.
Thanks to…
Lasombra Demon: For having patience and listening to me when someone got on my nerves.
K4thos: The original creator of the Tag system for Ikemen Go, Its been a long way since then.
Gacel: For working on the Ikemen Go code and keeping the flame alive.
Beta Testers in Spanish Ikemen discord server: Jefinho, Splash, Lasombra, Horse, etc. I’m very sure I forgot some people who have been helping, SORRY GUYS!!
No thanks to…
People who do not read the README files. If you reached this part of the post, you are not one of those!!
People who vaguely report “Your fucking TAG does not work bruh” without adding any more evidence or details than their word. 😛