Modeling props with Blender: Difference between revisions

From Valve Developer Community
Jump to navigation Jump to search
No edit summary
m (SubCategory set)
Line 1: Line 1:
[[Category:Modeling]] [[Category:Tutorials]]
[[Category:Modeling]] [[Category:Tutorials]][[Category:Blender]]
{{stub}}
{{stub}}
It is possible to create static, non-animated props in [[Blender]], along with appropriate physics collision data, in case Softimage is too much. This requires use of the [http://asrc.pjohnsen.com/downloads/smd_export.py SMD Exporter] by [http://asrc.pjohnsen.com/ Pelle Johnsen].  This exporter does not support skeletons, multiple materials, or animations, but it does support hard/soft edges.
It is possible to create static, non-animated props in [[Blender]], along with appropriate physics collision data, in case Softimage is too much. This requires use of the [http://asrc.pjohnsen.com/downloads/smd_export.py SMD Exporter] by [http://asrc.pjohnsen.com/ Pelle Johnsen].  This exporter does not support skeletons, multiple materials, or animations, but it does support hard/soft edges.

Revision as of 06:01, 11 January 2006

Stub

This article or section is a stub. You can help by expanding it.

It is possible to create static, non-animated props in Blender, along with appropriate physics collision data, in case Softimage is too much. This requires use of the SMD Exporter by Pelle Johnsen. This exporter does not support skeletons, multiple materials, or animations, but it does support hard/soft edges.

It is assumed that the reader knows the basic functions of Blender. At the very least you must be comfortable with creating simple models, applying UV texture mapping, and installing plugins. A working knowledge of how to compile models is a significant help.

Creating a basic non-solid prop

  1. Create your model and texture it via UV mapping. The result should be a .blend file, plus all the TGA files you used as textures. The example used here is the PC Gamer UK mag I secreted all around de_dust_pcg (so I have pcgmag.blend and pcgmag.tga)
  2. Having installed the SMD exporter plugin (http://asrc.pjohnsen.com/downloads/smd_export.py), export your model to a Half-Life 2 SMD file. In this example, I now have pcgmag.smd and pcgmag.tga - these are the files needed by the model compiling tools.
    Model blender export.png
  3. For a CS:S model, copy the SMD file into SteamApps/username/sourcesdk_content/cstrike/modelsrc and the TGA file(s) into SteamApps/username/sourcesdk_content/cstrike/materialsrc/models
  4. The SMD we have already is just the reference model. We also need an additional SMD to declare the 'idle' animation. So, in a text-editor, create a file called 'pcgmag_idle.smd' (or some other name ending in SMD) and enter this as its contents:

    version 1
    nodes
    0 "joint0" -1
    end
    skeleton
    time 0
    0 0.000000 0.000000 0.000000 0 0.000000 0.000000
    end

  5. The compile tools need a QC file containing model information. This is the file I used for pcgmag.smd:

    $modelname pcgmag.mdl
    $cdmaterials "models"
    $scale 3.5
    $surfaceprop "paper"
    $staticprop
    $body studio "pcgmag.smd"
    $sequence idle "pcgmag_idle" fps 1

    Note the scale factor, which I tweaked to get the magazine to appear at the right size in-game.
  6. The texture must also be converted into a VTF file just like any normal texture. However, it must include the 'model' declaration. This was the VMT file used for pcgmag.tga:

    "VertexLitGeneric"
    {
    "$baseTexture" "models/pcgmag"
    "$model" 1
    }

  7. Finally, change to the SourceSDK bin folder containing studiomdl.exe, and compile the model using a command like this:
    studiomdl.exe "..\..\sourcesdk_content\cstrike\modelsrc\pcgmag.qc"
  8. If everything went right, you'll get some nice output from studiomdl (look carefully for any errors), and you can now find the model in Hammer's model browser for use in-game.

---

For more information: First post on johnstoblog Second post on johnstoblog


Click here for a message board discussion about an almost-complete Blender script with animation capabilities.