Panorama Creation
In this tutorial you will learn how to create your own panoramic views using the Source engine. It will assume that you know how to use the console and the source engine in general.
I am not a English speaker (or writer), so forgive any bad English writing.
What is a Panoramic View?
A panoramic view is, basically, allot of images stitch together to create a single image. Stitching is the process where you stitch/join all the screenshots to make one unique image.
That image after being transformed can be viewed using a viewer that creates the illusion that we are inside the image.
There are several viewers to view panoramas (and several format). With this tutorial you will learn how to create panoramas that use the QTVR format (QuickTime Virtual Reality).
You need QuickTime to view the samples.
Creating Panoramic Views
Creating a panorama using the Source engine is very similar to when creating them in real live but instead of taking pictures using a real camera, you take screenshots using the engine.
There are allot of panorama creation tools so fell free to find one to your taste and use this tutorial as a base only.
This tutorial shows two ways of creating panoramic views. The GoCubic way is simple but the results are not so good while the Realviz Stitcher way gives allot more work but the results are allot better.
Preparing to make the panoramic view
Before you start taking the screenshots that will be used to make the panoramic view you should choose the area from witch you are going to make the panoramic view.
It should be a interesting area with good lighting (no one will want to see a boring area or a area that is too dark to see).
Creating panoramic views using GoCubic
By David Johnson: original posted here. Used with the authors permission.
Briefly it requires the console commands mat_envmaptgasize 512, envmap and the GoCubic tool.
Pros:
- very easy to use
Cons:
- Water doesn't show up correctly (no reflections)
- Low resolution (512x512 maximum)
- Shiny textures appear as not shiny
Preparing the Source engine to take the screenshots
You need to increase the envmap tga size to the max supported using the console command:
- mat_envmaptgasize 512
Taking the screenshots
Simply type the following command using the console:
- envmap
This will create 6 screenshots in the cubemap_screenshots directory that will be named 'XX.tga', where XX is coded as ft (front), lf (left), rt (right), bk (back/behind), up (up) and dn (down).
Setting the screenshots
GoCubic expects to be given 6 images named in sequence, i.e. 'shot1.tga', 'shot2.tga', 'shot3.tga', 'shot4.tga', 'shot5.tga' and 'shot6.tga'. These map to the front, right, back, left, up and down images.
Naturally, Source naming differs. So, we need to rename the images we've already got to match, for example:
- d1_trainstation_01rt.tga » d1_trainstation_1.tga
- d1_trainstation_01ft.tga » d1_trainstation_2.tga
- d1_trainstation_01lf.tga » d1_trainstation_3.tga
- d1_trainstation_01bk.tga » d1_trainstation_4.tga
- d1_trainstation_01up.tga » d1_trainstation_5.tga
- d1_trainstation_01dn.tga » d1_trainstation_6.tga
All the screenshots are now ready to make the panoramic view.
Making the Panoramic View
To do the stitching you need to do this:
- Load up GoCubic
- Go to the Make Pano menu and select the Make Pano Movie... item
- Browse to the location where you renamed the files, and select the first one (e.g. d1_trainstation_1.tga), and hit Open
- Another window will pop up asking where you want to save the generated panorama, so specify a filename or accept the default default.mov
It'll do a little crunching and within seconds you have your QTVR panorama.
Creating panoramic views using Realviz Stitcher
Briefly it requires allot of screenshots, allot of stitching, and Realviz Stitcher. I used Realviz Stitcher 3.5, it is not the latest version but the newer version should be similar. Realviz Stitcher Express should work also.
Pros:
- Higher quality Panoramic Views
- Water shown correctly
- Textures shown as in game (with reflections)
Cons:
- allot of work to take the screenshots
- Requires allot of work to stitch the screenshots
Preparing the Source engine to take the screenshots
Since the only goal is to take screenshots, you should raise all Video settings to the maximum allowed by your system, including the game resolution. Source may turn into a slide show but don't worry about that because you are only going to take screenshots and not to play.
You need to hide the gun model and the hud:
- r_drawviewmodel 0 - hides the gun model (0: hide; 1: show, impulse 200 also works)
- cl_drawhud 0 - hides the hud (0: hide; 1: show)
And change the fov (field of view) to 90 degrees:
- fov 90 - game default: 75
Also, if the area where the screenshots are going to be taken haves enemies, water or some moving parts you need to freeze Source (if you don't freeze it the moving content will appear blurred in the panorama).
For the moving parts simply change the map to make them stop.
For the rest, the normal pause doesn't work (at least, I failed to make it work as needed) but, there are some console commands that can help:
- host_timescale - slows down the host (1: normal speed; 0.1 - 10% of normal speed; 0.01 - 1% of normal speed; 0 - doesn't work)
- phys_timescale - stops the physics where they are (1: normal speed; 0 - freezes physics)
- ai_disable - should be used with npc_freeze, disable the ai of all npc (1: disabled; 0: enabled)
- npc_freeze - should be used with ai_disable, freezes the npc (it will freeze/unfreeze the npc in the crosshair, check npc_select to change targeted npc)
Use the console commands above as you need, for example, if you want to make a panoramic view where you will see allot of barrels in the air enter phys_timescale 0 when the barrels are in the air and they will stay there.
Taking the screenshots
You need to take allot of screenshots in different angles to make the panoramic view.
There are two ways to take the screenshots in the Source Engine:
- jpeg - jpeg console command (jpeg_quality changes the quality)
- tga - screenshot console command
Bind a key to the way you want to take the screenshot (later, you will need just to press that key to take the screenshot).
The screenshots will have to be made using the same origin using different angles (you cant move the player while taking the screenshots).
Instead of just moving the players view in different angles by hand, a good way to make sure you got all the needed screenshots is to use the setang command to set the angle.
The setang command will change the players view to the entered angle:
- setang X Y Z - X: look left-right (horizontal); Y: look up-down (vertical); Z: pitch (not needed, always 0)
You should take a screenshot every 30 degree, both in the X and Y axis. But, in the 60/-60 Y degrees a screenshot every 45 degree is enough for the X axis and, in the 90/-90 Y degrees one single screenshot is enough.
And so, you need to keep setting the angle and take the screenshot using the console (ESC will close the console):
setang 0 0 0 screenshot setang 0 30 0 screenshot (...) setang 0 300 0 screenshot setang 0 330 0 screenshot setang -30 0 0 screenshot setang -30 30 0 screenshot (...) setang -30 300 0 screenshot setang -30 330 0 screenshot setang -60 0 0 screenshot setang -60 45 0 screenshot (...) setang -30 270 0 screenshot setang -30 315 0 screenshot setang -90 0 0 screenshot (...) setang 30 0 0 screenshot setang 30 30 0 screenshot (...) setang 30 300 0 screenshot setang 30 330 0 screenshot setang 60 0 0 screenshot setang 60 45 0 screenshot (...) setang 30 270 0 screenshot setang 30 315 0 screenshot setang 90 0 0 screenshot
Probably, you will take more screenshots then needed (specially on the higher/lower Y axis) but no problem there.
If you still have moving parts that you didn't manage to stop, take a screenshot of those moving parts and then use them in the stitching (it helps to reduce the bluring).
Some screenshots samples from above:
 
Stitching
To do the stitching you need to do this:
- Start Realviz Stitcher 3.5
- It will open the default new project, you can keep it or go to the File Menu and select the New Item
- Load all the screenshots you have taken before using the toolbar button or going to the File Menu and selecting the Load Images Item
- Drag the first screenshot to the main area. This will be the screenshot that all other screenshots will use to be stitch, so pick the screenshot that was taken from the angle 0 0 0 (should be the first).
- Now keep dragging the screenshots until you get a 360 angle image and a closed panorama. To do this, you need to drag the screenshots near the already dragged ones and press enter. Realviz Stitcher will then stitch the screenshots or ask you to readjust (or force it).
When you end the stitching you will have something like this:
 
Making the Panoramic View
With all the screenshots stitch and with a closed panorama you can now make the panoramic view.
Go to the Render Menu and select the Render Item and set the settings you want for the panoramic view. Try different values as you want/need.
I use this settings when making my panoramas:
- For low quality panoramic views but smaller files: type QTVR (JPEG, High Quality, Motion 75%, Static 75%, default for the rest); Image Quality Method 1; Sharpen normal; Resolution 768x768. Sample here.
- For high quality panoramic views but bigger files: type QTVR (JPEG, High Quality, Motion 75%, Static 75%, default for the rest); Image Quality Method 1; Sharpen normal; Resolution 3072x3072. Sample here (FilePlanet download).
It'll take some time to create the panorama but at the end you will have your QTVR panorama created.
Samples




