VRC to CVR
Note: This is an extremely rushed first draft. This is a wiki so feel free to polish up a bit, and I'll be changing this as I do more testing and get sick of how awful this is laid out. However, I have tested everything here on an example kikyo so it should all work for most people.
Converison Process
Have VRC asset, want to convert to CVR.
First consult these resources:
CVR dev kit (CCK). Make account, goes through generic avatar upload process in brief: (Note you should use unity 2019.4.31f1 (same as vrc))
- https://developers.abinteractive.net/cck/setup/
- https://forums.abinteractive.net/d/93-uploading-your-first-chilloutvr-avatar/7 (Unity version quoted is out of date)
VRC to CVR conversion tools:
- https://fluffs.gumroad.com/l/sdk3-to-cck
- https://github.com/imagitama/vrc3cvr
- https://github.com/Narazaka/VRC2CVR
- https://github.com/ZettaiVR/VRC2CVR
Physbone Conversion:
- https://booth.pm/ja/items/4032295
- https://github.com/Dreadrith/PhysBone-Converter
- https://fluffs.gumroad.com/l/VRCDynamicBoneToPhysicsBoneConverter
Bonus resources:
- https://forums.abinteractive.net/t/chilloutvr-tutorials (Most are outdated but they contain information!)
- A more manual focused guide by some furry: https://docs.google.com/document/d/1vWB3VN98i7erA8anywUxxGoT39hrh8oHMmU6uaAnGu0/edit
- Basic Avatar tutorial (Import to upload, not a conversion) : https://www.youtube.com/watch?v=qkmRsS9fB1A
- Avatar emulator for local testing: https://booth.pm/en/items/4042017 (Note, builds an avatar then uses a CVR mod to load the bundle into the game)
tl ; dr
- Copy project
- Convert physbones back to dynamic bones (I know) (I suggest Dreadrith's)
- Install CCK (CVR dev sdk)
- Run a conversion tool on your avatar (imagitama works okay which is a shame since I hate furries)
- Delete VRC components on avatar
- Upload to CVR (Tag honestly, you will not get banned for (almost) anything if it's tagged properly)
Starting out
For the below instructions I basically went through converting two avatars: The optimized kikyo from the optimization page (still applies to CVR), and off the shelf dynamic bones kikyo. Both uploaded fine.
FAQ:
If you have any questions and get them answered please add them here, it's a wiki!
- Do I need to remove the VRC SDK and stuff? I didn't remove all VRC shit from my old project. VRC stuff mostly doesn't break anything but large projects can be fragile when copied regardless. There's one script that should be removed (see later in the article)
- Does my <insert shader here> work? All your shaders and stuff will work. That includes DPS.
- Toggles and sliders and stuff? Toggles work with the converter but I'll need to double check the converter tools. Chances are better ones are coming. I don't think it converts submenus, but CVR supports loads of things on the 'main menu'.
Admin
- Make an account on their website ( https://hub.abinteractive.net/ good luck it's overloaded) , download the CCK (their SDK) (https://developers.abinteractive.net/cck/setup/). Or use the account you made a while ago that you reserved your username with. Right?
- Make an API key on the hub (Home -> access key manager) and copy that and keep it somewhere safe, it's basically a password to all the content on your account.
From Existing project
I'm working from the same project I did in [Optimization].
- Copy your existing project and rename it.
- Open project (same unity version!) in unity hub.
Conversion
For this I am converting a kikyo to CVR. I'm using the optimized one but I plan to later port the unoptimised one just to check more complex dynamics and toggles and all that stuff.
Main things to do:
- Convert physbones to Dynamic bones or make dynamic bones from somewhere
- Run a conversion script
- Upload
Physbones to Dynamic bones
You have options:
- Run a converter tool and hope to god it works (will probably not work with godawful nip physbones)
- Copy dynamic bones from an old project
- Make new dynamic bones that are similar enough
None are optimal, but hey ho physbones were actually pretty good. Note that on runtime dynamic bones in CVR are more multithreaded so you don't have to be super strict like yo were back in VRC. Try not to go overboard though please.
- Make sure you have dynamic bones package in your project again! Reinstall that. (not the latest version, the pre-multithread version (1.2), although CVR might support that latest version I haven't checked)
- Download script from : https://booth.pm/ja/items/4032295 (it's free) (tested, janky)
- https://github.com/Dreadrith/PhysBone-Converter (tested, better than the one above)
- Or try https://fluffs.gumroad.com/l/VRCDynamicBoneToPhysicsBoneConverter (also free) (Untested, said to be better, try this one first maybe. Note that 2.0 added the reverse process)
- Run the converter
For me this didn't work so I had to do it manually.
Okay due to extreme laziness I used pumpkin tools to:
- Remove the physbones from my kikyo
- Copy over the dynamic bones from the prefab Kikyo_DB.
- Cleaned them up manually.
However, the default bones are so fucking bad I redid all the bones anyway. I just did quick placeholder ones so for tuning you'd want to put some more effort in.
Yeah I know, put effort into dynamic bones, then put effort into converting to physbones, and now going back again. It took me like 15 minutes though to get them reasonable. Chances are you already are familiar with dynbones.
For multiplayer touching, add radiuses in dynamic bones; you have default colliders in hands in CVR which are like the physbones ones in VRC, so people can touch your boobs in vanilla.
Sidenote about skirts and stuff
CVR supports magia cloth physics: https://assetstore.unity.com/packages/tools/physics/magica-cloth-160144
I haven't tried it but it's worth considering if you're looking at your skirt and going UGH DYNAMIC BONES AGAIN. There's a guide here too: https://forums.abinteractive.net/d/21-magica-cloth-installation-guide-for-cvr
A video says a thousand words 30 times a second:
Magica Cloth copypasta
https://forums.abinteractive.net/d/21-magica-cloth-installation-guide-for-cvr https://magicasoft.jp/en/magicaclothmeshclothstart-2/
Might as well give the settings too.
>Uses a Magica MeshCloth. BoneCloth can be used like Dynamic Bone, but will generally look worse than MeshCloth, and collision is better on MeshCloth too. Select the Skirt preset, many of the these values were unchanged from it, but I did tweak a few. >Mass: 15, 1, -0.4 >Drag: 0.01. Controls amount of movement. Lower numbers leads to more movement as far as I can tell. >World Influence: Hips, Max Speed 3, Movement 0.6, Rotation 0.7. This is basically the opposite of "Inert" from Dynamic Bone. Lowering this will lower how much it moves too. >Reset after teleport on >Clamp rotation: 30-50. This is like max angle from PhysBone as far as I can tell. >Restore distance stiffness: 0.5 >Restore rotation: 0.02-0.005, 0.1 >Collision penetration: Surface, Distance 0.01-0.02, Moving 0.3-1. Making the distance numbers lower seems to make the mesh further away from the collider to prevent clipping more. Deformer settings >Merge vertex distance 0.03 (will vary on how many tris you have on the original and how much you want it decimated to), this is used for the collision mesh Other notes >Make a bit of the top "fixed point" or red when doing point selection, everything below it should be green. Don't forget to press the "create" button. The top moving usually leads to clipping. >Colliders can fit the legs properly. No need for big colliders to stop bone chains from slipping.
VRC to AV3 conversion
There are a number of tools. In order of how well they worked for me try them in this order:
So I would recommend (reluctantly) this one: https://github.com/imagitama/vrc3cvr
- Install tool
- run tool on your avatar
- remove vrc component(s) if not deleted
- set the Eye and voice position (CVR comes with a voice location so sound actually comes from your mouth)
That's all I needed to do on this basic one. TODO is try this process with more complex avatars and make notes of any extra work you need to do but it's not bad.
Main differences to VRC: CVR is basically AV 2.0 but with animation controllers part of 3.0. That means toggles, fun effects, gestures, everything. It's unity. Note that toggles are a TODO for me at the moment, but the converter should have actually given you toggles if you had any. You also get more synced parameters too.
Notes
- This tool dumps the constructed animator controllers into a folder and does not rename them if it generates a new one. Running this tool on multiple avatars in a project can get real messy quickly.
- Also for some reason it turns all your toggles into floats. I'd really recommend just making your toggles manually. In theory it's slapping a default CVR animator controller and your main animator controller (previously FX layer) together and then configuring toggles. It also changes all your transition states into weird float conditions too. Even the bools.
Muh toggles
Toggles are simpler in CVR hilariously enough; the Parameter thing and the Menu thing are combined. The tl;dr is:
- Attach animator controller as Base Animator in "enable advanced settings" (clone it from the provided one lmao)
- Add your animation layers to the animator and params
- In "Inputs" configure that like a combined menu item and parameter menu; basically just put in the parameter there. For toggles you don't need to worry about setting anything other than name, parameter, type and generate type (maybe).
- That's it.
Notes:
- The UI is built to enable people to plug in options and then have CVR generate the animator layer for it. What you want is to name the Input the same as the parameter you already made so it doesn't create anything and just uses your existing animator controllers.
More manual guidance will/is available here: Manual_CVR_Conversion
Muh Gestures
There might be a way to get Combo Gesture Expressions to work since it's essentially all animator controllers but I have no idea how. For now for muh gestures it's simpler to give yourself a set on each hand. That's still 14 or so gestures. Not as diverse as I want either but until CGE gets ported to CVR it'll have to do. The autoconverter tool used above does set gestures even from a CGE made animator controller but they are a bit fucky.
Bugfixing
Ahh my project is such a fucking mess it breaks whenever I try anything and I don't want to keep copying massive backups
I feel you man I'm trying this myself at the moment, stay tuned.
What I tried so far:
- Make a fresh project
- Import most of the things I think I'll need (Shaders mostly)
- On the old project, drag and drop your scene into the project folder somewhere. This will make a .unity file.
- Right click on this file and 'Export'. It should make a massive package of your scene and dependencies.
- Honestly it's best to export without dependencies and then import dependencies from their packages seperately to avoid errors. `
- Import this into your new fresh project and move the scene in.
- Purple materials - Just set them to the same shader they were to 'reset' them. For me this was very tedious but it looked like it worked.
- Compiler errors - Install the things related to the errors as much as you can. Unity does not include dependencies very well.
- Delete that one VRC StripPostProcessing script. (see below)
- Then upload. It kinda worked.
Things probably worth deleting
- AV3 emulator. No good here. (Assets\Lyuma)
- Assets/VRCSDK/Dependencies/VRChat/Scripts/ShaderStripping/StripPostProcessing <- This script cursed my project for a while so delete this. (It breaks shader compiling)
Gestures
Hopefully they work; if not, read https://forums.abinteractive.net/d/656-how-to-add-facial-expressions-hand-gestures-to-your-avatar . If you've ever done 2.0 gestures it's the same - You don't need to fuck around with animator controllers to add gestures, just add face animations to the slots. However if you do want CGE level gestures or custom hand animations, you can do gestures in the animator controllers. I don't know how to though; maybe CGE works?
Log in and upload
Login to https://hub.abinteractive.net (if you can), Get an API key (Home, API Key Management -> ABI content Creation Kit Master Key) and use that with your username to log in to the CCK Control panel
From there just hit upload avatar and it should work.
Tagging:
Tag your shit correctly.
CVR works differently than VRC: They rely on the tagging system to keep content away from minors, and if you mis tag it is treated seriously. The upside is if you DO tag stuff with the right tags, they won't do shit to you if you spoop someone with them, or take your dick out.
Tags are not saved between uploads, make sure you retag each time. (for now, thisis something to raise with CVR devs when they're not drowning in not being on fire.)
Possible problems:
- No rights to upload content ID. This is the generic failed error messages.
- Server just down. Try again later.
- Possible causes: you hit the 10 avatar limit for free users.
- Gets stuck on "being encrypted": This happens when the avatar isn't written to disk; IE the shader compile failed, or out of disk space, or something. Symptoms include not being able to generate file size estimates and an error in the console saying it couldn't write/find the file.
Worlds
https://forums.abinteractive.net/d/43-the-basics-in-how-to-upload-a-world
And some greentext:
>make a copy of your vrc project >remove vrc sdk >make sure you are on their unity version (currently its the same as vrc) >restart (just in case) >import cck: https://developers.abinteractive.net/cck/setup/ >you now have to redo all buttons and teleports etc, so i recommend putting your vrc project on a second monitor as reference >upload form the menu "Alpha Blend Interactive" you find at the top
You can find everything essential by searching components for "CVR". CVR Interactible is the button for example.