City Bus Manager

City Bus Manager

45 个评价
Bus Modding
由 [PeDePe] Niklas 和其他 1 人合作完成
This guide describes how to create and add new buses to City Bus Manager. Players who do not want to create their own buses can also download shared buses directly from the Steam Workshop.
3
3
3
3
2
   
奖励
收藏
已收藏
取消收藏
Video Guide
General



Articulated bus
I. Create the bus model
This section deals with the creation of a bus model in the 3D program and the required textures.

1. Modeling
For the dimensions of the respective bus types, use the parking space references from the modding plugin.

The bus model must consist of the following separate objects:
  • Bus Body Object (Name: "Model")
  • Wheels front
  • (Wheels middle, for articulated buses)
  • Wheels back
  • Front door



Recommended polygon count for optimal performance: <10,000

2. Texturing
General Information & UV Structure
Only the bus body object will be paintable ingame in the paint shop.
Each side of the bus or each surface that should be paintable must be unwrapped on a common UV map (2048x2048px) and have a common material.
The front door, wheels, mirrors and other extra objects can have different materials and textures.

The following textures are needed for all modding buses:

Repaint Template
This texture will be downloadable ingame in the paint shop and will serve as a reference for external repaints. All surfaces and details of the bus must be completely mapped on it. The areas with the base color or the areas that should be paintable must be white. The background must be transparent.



Details texture
This texture must contain all surfaces and details that are not to be painted over in the paint shop. For example, windows, lights or vents. The background must be transparent.



Emission texture
This texture must contain all the surfaces that should be visible and glow at night as lights. The background must be black.



Roof Alpha texture
This texture must contain the silhouette of the roof surfaces with 100% black fill. The background must be transparent.


3. Rig / Animations

Front door
  • Must be a separate object to the bus body.
  • For double door: Each door must be linked to a bone (e.g. Door.L, Door.R)
  • Idle state must be closed
  • Export one animation to open the door and one to close it with your model

Articulated bus
  • Create the bones in the same skeleton/armature as the front door bones.
  • Create two linked bones: one for the front, one for the rear bus part. The intersection point is the center of the joint.
  • Apply Weight Paint to the Bus Body object and make sure the transition at the joint is smooth (see pictures below).
  • Set the Armature as parent for all objects of the bus model that should move with the joint (e.g. wheels).


II. Setup Unity
This section is about installing Unity, creating a new project and setting up our modding plugin.

1. Installation of Unity
Unity can be downloaded here[unity.com]. We recommend using Unity 2022.3.44.

2. Create a new project
  1. Click on "New project" in the Unity Hub.
  2. Select the 3D (URP) Core Template as the template. This may have to be downloaded first. Then choose a project name (e.g. name of the bus). The configuration should look like this:

  3. Click on "Create project" and wait until Unity has opened.
  4. If a TMP Importer window opens, click on "Import TMP Essentials".
  5. The Unity Plugin TextMeshPro must be installed in the version 3.2.0-pre.10. Therefore click in the top bar on "Window" => "Package Manager". Now click on the plus icon and select "Add package by name".

    Now enter as name "com.unity.textmeshpro" and as version "3.2.0-pre.10" (without quotation marks) and click on Add.

3a. Install the CBM modding plugin
  1. Download the latest Modding Plugin here[download.pedepe.de] (Version 1.0.8).
  2. Double-click on the downloaded .unitypackage file. The following window then opens in the Unity Editor:

  3. Click on "Import" at the bottom right. If everything has worked correctly, the "Mod Editor" should now be available in Unity at the top of the bar under "City Bus Manager".

3b. Update the CBM modding plugin
Just follow the instructions from 3a. The plugin will automatically be overwritten.

Changelog:
1.0.8:
- Added support for sightseeing buses and coaches
Hint: In existing projects, we recommend to update Unity to version 2022.3.44. Additionally, please update TextMeshPro to version 3.2.0-pre.10 in the Unity Package Manager before installing the new plugin update.

1.0.7:
- Added charging ports for e-buses (see section III.4 E-Bus only: Add charging port)

1.0.6:
- Added support for e-buses
- Added destination displays, fleet numbers and license plates
Hint: Please make sure that TextMeshPro version 3.2.0-pre.6 is installed. You can find more details in section 2 (Create a new project), just above.

1.0.4:
- Material Texture Index is now set automatically and was removed from the UI
- Repaint texture compression is now automatically set to "None", to fix repaint export issues in the paint shop

1.0.3:
- Added some export checks and error messages if something is wrong

1.0.2:
- Fixed export error on Windows

1.0.1:
- Fixed "washed-out" bus colors when using an internal repaint
III. Importing the bus into Unity
The following describes how a created bus can be imported into Unity and how the bus is correctly configured for the City Bus Manager. This is shown using the example of a CapaCity L articulated bus.

1. Import the bus model
  1. Textures: Drag the four textures (+ extra textures for separate objects) into the Unity Texture folder and setup the import settings as follows and then click on "Apply" for each texture in the inspector:

    Overview:


    Details:


    Emission:


    Repaint:

    It is important that Compression is set to "None".

    Roof:


  2. Material: Go to the Materials folder and create a copy of the material "M_Template". In the material, select the previously imported textures for
    • "Roof Alpha Texture" => "CapaCity L roof"
    • "Unpaintable Details Texture" => "CapaCity L details"
    • "Emission Texture" => "CapaCity L emission"
    Paintjob can be left empty.


  3. Model: Drag the created bus (e.g. fbx file) into the Models folder. Set the model and materials tab as follows and confirm the settings again with "Apply":

    Model:

    Tip: Depending on the export settings of the 3D program, uncheck "Bake Axis Conversion" if necessary.

    Materials:


  4. Animations: Create a copy of the Animator controller "Animation/AnimatorTemplate" and open it. Then set the OpenDoor and CloseDoor animation to the imported animation from the model.

The bus is now completely imported and can subsequently be placed in the scene.

2. Place and scale the bus in the scene
  1. Drag the bus model into the Unity Scene and set the position coordinates to X=0, Y=0, Z=0.

  2. In order to scale and position the bus correctly, the parking space objects are provided. The Prefabs folder contains the "Bus Space Large" for articulated buses, the "Bus Space Medium" for solo buses and the "Bus Space Small" for small buses (e.g. Cito, Sprinter). Drag the appropriate bus space from the Prefabs folder into the scene and set the coordinates to X=0, Y=0, Z=0.
    The scene should now look like this:


  3. Now change the position of the bus object in the scene and scale it so that the bus stands correctly on the parking space and does not look beyond it. In addition, the front of the bus on the parking space should also look forward, as shown in the picture above. If the bus is faceing the wrong way, the Y rotation can be set to 180.

  4. In the hierarchy, make sure that the objects are named correctly. It is important that the main mesh GameObject is called "Model" and the rear joint "Articulation". This can still be renamed at this point if the names are wrong.


  5. Add a MeshCollider to the "Model" GameObject. Select the same mesh as in the existing Skinned Mesh Renderer.


  6. Add an animator to the parent GameObject of the bus and select the previously created animator controller as the controller.

3. Add license plate, destination displays and fleet number
  1. Just drag and drop the prefabs from "Prefabs/Additions" into the Unity Scene as child of your bus model GameObject. In the hierachy on the left, the prefabs must be a child of your bus model. For articulated buses, you must place the prefabs, which are at the articulation of the bus (e.g. back license plate), as a child of the "Articulation" GameObject.
  2. Now you can set them to the correct position and rotation.
  3. You can place as many of these prefabs as you like. Just make sure that the GameObjects in the scene still contain the names "FleetNumber", "LicensePlate", "LineDestination", "LineNumber".

4. E-Bus only: Add charging port
  1. Just drag and drop the prefab from "Prefabs/Additions/ChargingPort" into the Unity Scene as child of your bus model GameObject. In the hierachy on the left, the prefab must be a child of your bus model.
  2. Now you can set it to the correct position and rotation. The preview is very small, to see it better, you can set the scale to e.g. 100. After setting it correctly, set the scale back to 0.95.
  3. If the charger is put into the bus in the game and the charging port isn't visible, you have to add 180 degrees to the y-rotation. So if it is e.g. 90, you have to set it to 270.
IV. Configuration of the bus with the Mod Editor
1. Create a new mod
In Unity, click on "City Bus Manager" -> "Mod Editor" at the top. A new window will open. Click on "New mod", select a mod name and click on "Create".



2. Configuration
The mod editor for configuring the bus will now open. This looks like this:


The various settings that can be set are explained below:

Mod settings:
  • Name: Name of the mod. This is displayed in the Steam Workshop and in the mod overview.
  • Description: Description of the mod. This is displayed in the Steam Workshop and in the Mod overview.
  • Type: Mod Type. Currently only bus mods are supported.
  • Version: Version number of the mod. This can be increased for updates.

Settings of the bus:
  • Ingame bus name: The name displayed in-game for the bus.
  • Total capacity: The maximum number of passengers allowed on the bus.
  • Seating capacity: The number of seats.
  • Max fuel / battery: The size of the fuel tank in litres / the battery in kWh.
  • Fuel consumption: The fuel consumption of the bus in litres per 100km / the battery consumption in kWh/100km.
  • Charging speed (only for e-buses): Maximum CCS charging speed in kW.
  • Propulsion type: The game handles the bus as Diesel or Electric bus.
  • Construction year: Year of release of the bus.
  • Size: Size of the bus. Large for articulated buses, Medium for solo buses and Small for small buses (e.g. Cito, Sprinter).
  • Type: Type of bus. Double Decker for double deckers and normal for all other buses.
  • Category: Category of bus. "City Bus" or "Coach And Sightseeing". Decides in which category the bus can be unlocked in the research in the game.
  • Number of preferred countries: Number of countries in which the buses are preferentially unlocked. Afterwards, the English names of the countries can be entered in the list of "preferred countries". This way it can be made possible that e.g. German buses are activated preferentially if you play in a German city and British buses if you play in a city in Great Britain.

Technical configuration of the bus:
  • Preview image: The preview image is displayed in the marketplace and is used by default as the image for the Steam Workshop. The image or Photoshop template in "Resources/Preview Image/bus-preview-template" can be used as a template for the preview image. The necessary texture import settings can also be taken from the image.

  • Repaint template: Reference to the repaint texture (in this example "Assets/Texture/CapaCityL/CapaCity L repaint").

  • Original details: Reference to the details texture (in this example "Assets/Texture/CapaCityL/CapaCity L details").

  • Bus GameObject: Reference to the GameObject in the scene. Here it is important that the GameObject was correctly positioned, rotated and scaled in the previous step.

  • Repaint material index: Each bus has several materials. Here, the index of the material that was previously created and uses the "Paint Overlay" shader (in this example Assets/Materials/M_CapaCityL) must be specified. The index can be seen in the Import Settings of the model in the tab "Materials" (see picture from section 1). The first material listed has index 0 and the second index 1. In this example, index 1 is correct.
    If the index is set incorrectly, painting in the paint shop will not work. In this case, the index must be corrected.

  • Edit access point position: This sets the point to which employees walk to board the bus. The point should be directly in front of the animated front door and the Y-coordinate must be 0. After clicking on the button, the position can be set directly in the scene or the coordinates can be entered manually.


  • Edit in bus point position: This sets the point where the staff spawns before they get off the bus. The point should be directly behind the animated front door in the bus and Y should be set to the height of the floor of the bus. After clicking on the button, the position can be set directly in the scene or the coordinates can be entered manually.


  • Edit front light left / right: This sets the positions for the front lights. In addition to the position, a rotation is also required here in which direction the light shines. The dotted line visually indicates the direction in the scene. After clicking on the button, the position and rotation can be set directly in the scene or the coordinates can be entered manually.


  • Edit damage particles: When a bus is damaged in the game, a particle effect is displayed. Here the position of the particle effect and the rotation can be set. After clicking on the button, the position can be set directly in the scene or the coordinates can be entered manually. The rotation can be selected between 0°, 90°, 180° or 270°. The visual dotted line shows the direction of the particles.


  • Number of doors / Edit doors : The number of doors is specified here. For each door, the position of the top centre of the door must be specified. This is needed for the particle effects when the bus is dirty inside. After clicking on the button, the position can be set directly in the scene or the coordinates can be entered manually. The rotation can be selected between 0°, 90°, 180° or 270°. The visual dotted line shows the direction of the particles.


  • Edit bus collider : This sets a bounding box that serves as a collider. The box should just contain the entire bus. The In Bus Point that was previously set should be outside the collider. After clicking on the button, the center point and the size of the collider can be set directly in the scene or the coordinates can be entered manually.

3. Export
The bus can now be exported using the "Export" button. This is automatically saved in the City Bus Manager Modding directory.

Windows: ...AppData\LocalLow\PeDePe GbR\City Bus Manager\Mods\Buses
MacOS: /Users/*Username*/Library/Application Support/PeDePe GbR/City Bus Manager/Mods/Buses/

Now the creation of the bus is complete and can be tested and shared in the next step.
V: Testing and sharing the bus in the Steam Workshop
1. Activate bus in the modding menu
In the City Bus Manager main menu, the bus should now be displayed in the modding form:



Make sure the mod has been activated with the tick on the left. The bus should now be available in the game. In sandbox mode the bus is available immediately and in normal mode the bus is unlocked via research.

2. Test bus
To ensure that the bus is working correctly, the following should be checked:
  • Is the position of the bus on the bus space correct?
  • Does the animation of the doors work?
  • Are the employees getting on and off the bus correctly?
  • Are the lights on the bus working at night and are they in the correct position?
  • If applicable, does the articulation of the bus work?
  • If the bus is damaged, is the smoke particle displayed in the correct position?
  • If the bus is dirty inside, are the particles on the doors displayed correctly?
  • Does the bus get dirty on the outside?
  • Do both in-game paint jobs in the paint shop and external repaints work?

3. Share the bus
If everything is working correctly, the bus can be shared in the Steam Workshop via the modding form in the main menu. Just click on the blue upload button.

If you have made a change to the bus, the bus can be updated in the same form with the orange update button.
VI: FAQ
The painting of the bus is not working.
Please check the following:
  • Have you installed the latest CBM modding plugin (step II.3)?
  • Have you added the Mesh Collider (step III.2.5)?
  • Have you checked "Read/Write" in the model import settings (step III.1.3)?

The export of the repaint in the paint shop is not working.
Please make sure that you have installed the latest modding plugin version. If you have an older version and don't want to update, you have to set the compression of the Repaint texture to "None" (step III.1.1).
13 条留言
mrmx5 9 月 2 日 上午 3:19 
How can I upload a Bus created by someone else into my Collection?
idanmund 2024 年 11 月 6 日 下午 9:53 
I wounder if there is a way to do a reverse guide. Meaning how to export and edit a model already in the game. Maybe you can do something like that? Thanks :)
timothy 2024 年 9 月 26 日 下午 4:04 
how do you make the model
Дѣдъ Aнтуанъ-Cержъ 2024 年 9 月 9 日 上午 6:03 
so i have a problems i for example have modded buses, i dont see them in mods tab in game, but i have subscribed to them on steam workshop what i need to do to see them in game?
RandomKentGuy 2024 年 6 月 29 日 上午 4:22 
is there a way to use vanilla buses as a base for models?
robWolvesfan1 2024 年 6 月 14 日 上午 1:10 
Can this be used to edit buses downloaded from the workshop to add the destination blinds to them?
Egli.ger 2024 年 3 月 8 日 下午 10:23 
Cheats will be great!
gx7767 2024 年 2 月 22 日 上午 7:32 
How can I setup the moving object(door) can be reprint?
Harry 2024 年 1 月 13 日 下午 12:01 
How do you export a bus into the editor? I've done all the steps till Step 3 then 3 after the paint
Harry 2024 年 1 月 13 日 上午 7:10 
If I have a bus model and just want to add a livery on it, will I have to make the bus all over or can I do different steps l, and if so what ones?