User:Qazaaq/NIF Format Notes

These are some notes I took while looking at the NIF files and info I got from others. Feel free to comment, discuss and add your own.

GeneralEdit

  • All NIFs start with a BSFadeNode block, very similar to NiNodes. Exceptions:
    • cameras
    • master particle systems
    • lod meshes
  • All block Values strings (Value column in Block List view) are stored in a Strings array in the header and are referred to with an integer.

TexturesEdit

LocationEdit

BSFadeNode
+- NiTriStrips
   +- BSShaderPPLightingProperty
      +- BSShaderTextureSet

NotesEdit

  • BSShaderTexturesSet contains the textures (color-, normal- and glowmap) in the Textures array. Size is controlled by the Num Textures variable, this is always 6 even when the last ones aren't used.
  • Texture order:
  1. color map
  2. normal map + specular map in alpha
  3. glow map
  4. parallax map
  5. reflection/environment map
  6. environment map mask
  • Sometimes, for simple/small objects or animated textures, the old/Oblivion method is used (NiTexturingProperty + NiSourceTexture).


CollisionEdit

All collisionEdit

  • Layer and Response(always(?) set to RESPONSE_SIMPLE_CONTACT) is controlled by bhkRigidBody.
  • Use bhkRigidBodyT instead of bhkRididBody to apply a transformation to a collision object.
  • Use bhkTransformShape to apply a transformation to a collision shape

Primitive collision shapesEdit

  • Hardly ever used. Convex and Mopp shapes are much more common even for shapes like boxes.

LocationEdit

BSFadeNode
+- bhkCollisionObject
   +- bhkRigidBody
      +- bhkXXXShape

NotesEdit

  • Used shapes (should be possible to use it with all shapes):
    • Box
  • Shape contains shape and material data.

Simple collision shapesEdit

These are used for items.

LocationEdit

BSFadeNode
+- bhkCollisionObject
   +- bhkRigidBody
      +- bhkConvexVerticesShape

NotesEdit

  • Both shape data and material are controlled by the bhkConvexVerticesShape.

Complex collision shapesEdit

Buildings and other large static objects.

LocationEdit

BSFadeNode
+- bhkCollisionObject
   +- bhkRigidBody
   |  +- bhkMoppBvTreeShape
   |     +- bhkPackedNiTriStripsShape
   |        +- hkPackedNiTriStripsData
   +- BSFadeNode

NotesEdit

  • Material is controlled by the bhkMoppBvTreeShape block.
  • bhkPackedNiTriStripsShape and bhkPackedNiTriStripsData only contain data about the collision shape.
  • bhkPackedNiTriStripsData contains layer and material' of subshapes.

Uncompressed collision shapesEdit

Used in the following NIFs:

  • meshes\clutter\displaycase\displaycase.nif

LocationEdit

BSFadeNode
+- bhkCollisionObject
   +- bhkRigidBody
      +- bhkNiTriStripsShape
         +- NiTriStripsData

NotesEdit

  • NiTriStripsShape contains material data.

Other collision shapesEdit

LocationEdit

BSFadeNode
+- bhkSPCollisionObject
   +- bhkSimpleShapePhantom
      +- [bhkXXXShape, bhkConvexVerticesShape]

NotesEdit

  • bhkSimpleShapePhantom controls the layer:
    • OL_WATER
    • OL_TRIGGER
  • last unkown float in bhkSimpleShapePhantom
    • -204.0184 in all water NIFs
    • 0.0 in all triggers