User Tools

Site Tools


public:t-vien-08-1:lab_3_materials

This is an old revision of the document!


Lab 3 - Camera, Text, Environment and Sound

Before You Start

Under construction, please wait!
  • Download and unzip the Lab 3 Asset File into your working directory (same directory you used last week)

Continuing with your Virtual Room

Improving the Virtual Room

  1. Camera Lens:
    Adjust your camera's field of view (FOV) and near clipping distance so that you see a bit more of the room as you move around in it. A field of view of 50 seems pretty good and a near clipping plane of 0.01.
    base.camLens.setFov(<field of view in degrees>)  
    base.camLens.setNear(<distance of near clipping plane>)
    base.camLens.setFar(<distance to far clipping plane>) 
  2. Onscreen Text:
    Add a dynamic text label on your heads-up-display (HUD) simply by creating an OnscreenText object like this:
    from direct.gui.OnscreenText import OnscreenText
    textobject = OnscreenText(pos = (0, -0.9), fg = (1,1,1,1), bg = (0.3, 0.3, 0.3, 0.5), 
                              align = TextNode.ACenter, scale = 0.07, mayChange = True)   

    You can look up the various creation parameters for OnscreenText. And then any time you want to display some text, just set the text property for this object. The following code sets the text to the current camera location values using a python formatted string

    textobject.setText("Your location is (%2.2f,%2.2f,%2.2f)" % (base.camera.getX(), base.camera.getY(), base.camera.getZ()))
  3. Localized Sound:
    Add some sound to the television broadcast which grows louder as you approach the television set and softer as you move away from it. First you need to create an instance of an Audio3DManager inside the World. You can use the camera object as the reference point for calculating how far the sound is traveling and therefore how much the volume should drop. Set the drop off factor to 10. Then load the sound glenn_launch.wav (from the assets file) and attach it to the television screen. Set the min distance of the sound to 1.2. Make sure to start the sound playing. Play with different drop off factors and min distance values and see how it affects the sound in the room as you move around.
    # HINT - Creating a 3D audio manager
    # Note that 'reference_point' could be the pathnode of a listener's location 
    audio3d = Audio3DManager.Audio3DManager(base.sfxManagerList[0], <reference point>)
    audio3d.setDropOffFactor(<drop off factor>)
     
    # HINT - Loading a 3D sound and attaching it to an object
    sound = audio3d.loadSfx(<filename>)
    sound.setVolume(<volume between 0 and 1>)
    audio3d.attachSoundToObject(sound, <object> )
    audio3d.setSoundMinDistance(sound, <distance>)
    sound.play()
  4. Transparent Windows:
    Some of the wall panels have windows on them (namely the window and door panels). It would be nice to see through those windows to the world outside! To make the glass see-through in your panels, you need to use textures that store a transparency value for each pixel, as well as the Red/Green/Blue (RGB) information. This transparency information is stored in an image layer called an alpha channel. In this layer, the color white (maximum value) means a opaque surface but the color black (minimum value or 0) means fully transparent. Not all image formats can store an alpha channel along with RGB color information. A new version of the wall_tanned_door and wall_tanned_window with an alpha channel, has been created in the tiff format (extension *.tif). Load this version of those textures into your Room instead of the previous *.png ones. One more step is needed though. You will need to enable the transparency effect on the actual model that receives the texture. Call the following method on the wall panel NodePath the first time you load the model:
    <NodePath>.setTransparency(TransparencyAttrib.MAlpha) 
  1. Terrain:
    First
  1. Skybox:
    First let's create an outside view. Surround your entire scene with a box with the textures on the inside. A box like that, with textures depicting mountains and a sky already applied, can be found with the name “Models/skybox.egg”. As you can see, this sort of an object is called a skybox. Just load it as the member variable self.skybox in your World, attach it to render and scale it up 20 times. A skybox represents a horizon that the user should never be able to reach and pass through, and therefore it needs to move with the user, always keeping the user at its center. This is easy to do since World already has a move method that updates the camera position. Once the camera position has been updated in that method, give self.skybox the same position as the camera. Try moving outside of the room and notice how the horizon seems to stay put.
  2. Fog: To add a little bit of an atmosphere, add some fog to your skybox and play with the values. Don't make the fog too dense or you won't see much through the windows in the next step.
    # HINT - Adding fog to a sub-tree starting at 'root' (could also be a node to a single model) 
    fog = Fog("Fog")
    fog.setColor(0.6,0.6,0.8)
    fog.setExpDensity(0.02)
    root.setFog(fog)     
/var/www/cadia.ru.is/wiki/data/attic/public/t-vien-08-1/lab_3_materials.1201132068.txt.gz · Last modified: 2024/04/29 13:33 (external edit)

Donate Powered by PHP Valid HTML5 Valid CSS Driven by DokuWiki