Configuring the part in Unity: Difference between revisions

From KSP 2 Modding Wiki
(Page creation)
 
No edit summary
 
(10 intermediate revisions by 2 users not shown)
Line 1: Line 1:
This page is only for part mod. If your mod don't include parts, you can skip what follows.
The following page will guide you through setting up a new part inside Unity.


= Configuring the part in Unity =
= Configuring the part in Unity =
<blockquote>Prerequisites
'''Prerequisites'''
[[Setting up Unity]]
[[Modeling the mesh in Blender]]
[[Texturing the mesh in Substance 3D Painter]]
[[Preparing the mesh for Unity]]


* Having installed Unity
'''Useful links (may contain outdated information)'''
* Having initialized the Unity project
Tutorial for creating a part in Unity: https://luxstice.notion.site/Tutorial-My-First-Part-5f0cf456d7f4443d8c92658c7cc58314
</blockquote><blockquote>More resources
Tutorial for configuring a part in Unity: https://www.youtube.com/watch?v=9fQg-oMqcH8
 
* Tutorial for creating a part in Unity : Tutorial: My First Part
* Tutorial for configuring a part in Unity : How to create parts for KSP2
</blockquote>


== Setting up the scene ==
== Setting up the scene ==
Line 17: Line 17:
# Open the Unity project.
# Open the Unity project.
# Click on the three dots in the Hierarchy menu then “Add a new scene”.
# Click on the three dots in the Hierarchy menu then “Add a new scene”.
# Right-click on the scene > Save Scene.
# Right-click on the scene > '''Save Scene'''.
# Save the scene in the Asset folder of the Unity project.
# Save the scene in the Asset folder of the Unity project.
# In the Asset folder, create a folder for the mod.
# In the Asset folder, create a folder for the mod.
# In this folder, create the “Materials” and “Parts” folders. This is just to keep the folder well organized.
# In this folder, create the “Materials” and “Parts” folders. This is just to keep the folder well organized.
# Delete the camera and light and import the meshes and textures into the corresponding folders.
# Delete the camera and light and import the meshes and textures into the corresponding folders.
'''Good practice for organizing the Assets folder'''
Assets
|
\-Modname
  |
  \-Parts
    |
    \-(separate folders for the type of parts)
      |
      \-Folder for each part
  |
  \-Materials


== Associating textures to the meshes ==
== Associating textures to the meshes ==


# Create a material in Unity for each material in Substance Painter (right-click on the project window > Create > Material)
# Create a material in Unity for each material in Substance Painter (right-click on the project window > '''Create > Material''')
# Select all materials. In the Inspector window, in Shader, select KSP > Parts > Paintable.
# Select all materials. In the Inspector window, in Shader, select '''KSP > Parts > Paintable'''.
# For each material, assign the textures to the Albedo, Metallic, Normal, Emissive and Paintable channels.
# For each material, assign the textures to the Albedo, Metallic, Normal, Emissive and Paintable channels.
# For Normal channels, click the “Fix Now” button.
# For Normal channels, click the “Fix Now” button.
Line 42: Line 54:
# In the Inspector window:
# In the Inspector window:
#* Delete the “Mesh Renderer” component.
#* Delete the “Mesh Renderer” component.
#* Click on “Add Component” > “Mesh Collider”.
#* Click on '''Add Component > Mesh Collider'''.
#* Check “Convex”.
#* Check “Convex”.
# Repeat the operation for all meshes.
# Repeat the operation for all meshes.


<blockquote>Note
<blockquote>Note: Materials should not have shaders.</blockquote>
 
Materials should not have shaders.</blockquote>


== Configuring the mesh ==
== Configuring the part data ==
Follow this instructions: [[Configuring the mesh]].
Follow these instructions: [[Configuring the core part data]].


== Configuring the addressables ==
== Configuring the addressables ==
Line 57: Line 67:
=== Creating the addressables ===
=== Creating the addressables ===


# Select all prefabs in the Asset folder and check “Addressable” in the Inspector window.
# If you followed the "Configuring the core part data" instructions linked above, you should have an addressables group set up for your mod with your prefab and JSON files already added.
# Select all JSON in the Asset folder and check “Addressable” in the Inspector window.
# Next, select all icon images in the Asset folder and check "Addressable" in the Inspector window.
# Select all icon images in the Asset folder and check “Addressable” in the Inspector window.
[[Category:Parts and modules]]
 
=== Creating a group of addressables ===
 
# Go to Window > Asset Management > Addressables > Groups.
# Click Create > Group > Packed Asset.
# Rename the group and move the mod elements into it.
# Rename each addressable name to remove the path. The final name must be the same as the part name + extension.
# Add the <code>parts_data</code> label to the JSON. If it does not exist, create it with “Manage labels” > “+”.
 
== Creating a build profile ==
 
# Go to Window > Asset Management > Addressables > Groups.
# Click on Profile > Manage Profiles.
# Click on Create > Profile.
# Rename the new profile.
# For a mod with code, enter the values as follows, where XXX = the namespace of the .NET project previously configured.
 
{| class="wikitable"
!Field name
!Value
|-
|LocalBuildPath
|Library/com.unity.addressables/aa/Windows/StandaloneWindows64
|-
|LocalLoadedPath
|{XXX.XXXPlugin.Path}/addressables/StandaloneWindows64
|}
For a codeless mod, enter the values as follows, where XXX = the mod's name.
{| class="wikitable"
!Field name
!Value
|-
|LocalBuildPath
|Library/com.unity.addressables/aa/Windows/StandaloneWindows64
|-
|LocalLoadedPath
|{SpaceWarpPaths.XXX}/addressables/StandaloneWindows64
|}

Latest revision as of 02:09, 15 January 2024

The following page will guide you through setting up a new part inside Unity.

Configuring the part in Unity

Prerequisites
Setting up Unity
Modeling the mesh in Blender
Texturing the mesh in Substance 3D Painter
Preparing the mesh for Unity
Useful links (may contain outdated information)
Tutorial for creating a part in Unity: https://luxstice.notion.site/Tutorial-My-First-Part-5f0cf456d7f4443d8c92658c7cc58314
Tutorial for configuring a part in Unity: https://www.youtube.com/watch?v=9fQg-oMqcH8

Setting up the scene

  1. Open Unity Hub.
  2. Open the Unity project.
  3. Click on the three dots in the Hierarchy menu then “Add a new scene”.
  4. Right-click on the scene > Save Scene.
  5. Save the scene in the Asset folder of the Unity project.
  6. In the Asset folder, create a folder for the mod.
  7. In this folder, create the “Materials” and “Parts” folders. This is just to keep the folder well organized.
  8. Delete the camera and light and import the meshes and textures into the corresponding folders.
Good practice for organizing the Assets folder
Assets
|
\-Modname
  |
  \-Parts
    |
    \-(separate folders for the type of parts)
      |
      \-Folder for each part
  |
  \-Materials

Associating textures to the meshes

  1. Create a material in Unity for each material in Substance Painter (right-click on the project window > Create > Material)
  2. Select all materials. In the Inspector window, in Shader, select KSP > Parts > Paintable.
  3. For each material, assign the textures to the Albedo, Metallic, Normal, Emissive and Paintable channels.
  4. For Normal channels, click the “Fix Now” button.
  5. For each mesh, assign the materials to the corresponding locations. Click on “Apply”.

Adding meshes to the scene

  1. Create an Empty GameObject. Let's name it myMod_myPart. The name must be unique to any part in KSP2, including other mods.
  2. Set its position to 0;0;0.
  3. Create another empty object as a child of this object and call it model.
  4. Drop the mesh as a child of model.
  5. Use the “Transform” panel to optionally modify the position, rotation and size of the mesh.
  6. Right click on the mesh > Prefab > Unpack completely.
  7. Select all colliders.
  8. In the Inspector window:
    • Delete the “Mesh Renderer” component.
    • Click on Add Component > Mesh Collider.
    • Check “Convex”.
  9. Repeat the operation for all meshes.

Note: Materials should not have shaders.

Configuring the part data

Follow these instructions: Configuring the core part data.

Configuring the addressables

Creating the addressables

  1. If you followed the "Configuring the core part data" instructions linked above, you should have an addressables group set up for your mod with your prefab and JSON files already added.
  2. Next, select all icon images in the Asset folder and check "Addressable" in the Inspector window.