4,400
edits
(→A note to those who wish to make a livery: Typo fix s/ysers/users/) |
m (Robot: Cosmetic changes) |
||
Line 1: | Line 1: | ||
[[ | [[File:Livery_selection_dialog.jpg|thumb|270px|The livery selection dialog of the [[Sikorsky S76C]].]] | ||
On this page we describe how you make use of a script to get a '''livery selection dialog''' for an [[aircraft]] or [[vehicle]] in [[FlightGear]]. To get new liveries, you need to have them available with this script. | On this page we describe how you make use of a script to get a '''livery selection dialog''' for an [[aircraft]] or [[vehicle]] in [[FlightGear]]. To get new liveries, you need to have them available with this script. | ||
'''If you want to add a new livery to a plane that already makes use of the livery select system, you'll only have to follow the steps under [[#Models/Liveries|Models/Liveries]].''' | '''If you want to add a new livery to a plane that already makes use of the livery select system, you'll only have to follow the steps under [[#Models/Liveries|Models/Liveries]].''' | ||
==A note to those who wish to make a livery== | == A note to those who wish to make a livery == | ||
If your livery is likely to be edited by other users, consider making a paintkit in addition to your livery. | If your livery is likely to be edited by other users, consider making a paintkit in addition to your livery. | ||
Line 11: | Line 11: | ||
Paintkits are usually provided within the aircraft's <tt>Models/</tt> directory and/or at [http://liveries.flightgear.org/paintkits.php the livery database]. | Paintkits are usually provided within the aircraft's <tt>Models/</tt> directory and/or at [http://liveries.flightgear.org/paintkits.php the livery database]. | ||
==Files to edit== | == Files to edit == | ||
There are a few files we need to make (or edit), namely: | There are a few files we need to make (or edit), namely: | ||
* <tt>...-set.xml</tt> | * <tt>...-set.xml</tt> | ||
Line 18: | Line 18: | ||
We also have to make a new directory to store our liveries in. Let's make it <tt>Aircraft/.../Models/Liveries</tt>. | We also have to make a new directory to store our liveries in. Let's make it <tt>Aircraft/.../Models/Liveries</tt>. | ||
===Models/Liveries=== | === Models/Liveries === | ||
For every livery we need to make a file. Let's say we got a KLM livery, we then need to make a file called <tt>KLM.xml</tt> in our <tt>Models/Liveries</tt> directory. When a particular livery is selected, its XML file is copied to the aircraft's property tree. On the pilot's side this is the main property tree <tt>/</tt>, and on all remote machines on the MP network it's one of the multiplayer branches in <tt>/ai/models/multiplayer[]</tt>. The structure of livery XML files is completely free. There just has to be a property containing a name for the selection dialog, and <tt>aircraft.livery.init()</tt> must be told which it is. By default it is <tt>sim/model/livery/name</tt>. | For every livery we need to make a file. Let's say we got a KLM livery, we then need to make a file called <tt>KLM.xml</tt> in our <tt>Models/Liveries</tt> directory. When a particular livery is selected, its XML file is copied to the aircraft's property tree. On the pilot's side this is the main property tree <tt>/</tt>, and on all remote machines on the MP network it's one of the multiplayer branches in <tt>/ai/models/multiplayer[]</tt>. The structure of livery XML files is completely free. There just has to be a property containing a name for the selection dialog, and <tt>aircraft.livery.init()</tt> must be told which it is. By default it is <tt>sim/model/livery/name</tt>. | ||
Line 36: | Line 36: | ||
In the example above, the texture files are also stored in the <tt>Models/Liveries/</tt> directory of the aircraft. | In the example above, the texture files are also stored in the <tt>Models/Liveries/</tt> directory of the aircraft. | ||
===Models/....xml=== | === Models/....xml === | ||
The first part is related to the nasal script. <tt>("Aircraft/DR400/Models/Liveries");</tt> points FlightGear to the directory where we store our liveries. This is a different directory for every plane, but there should be only one folder for one plane, containing all the liveries for that plane. Add the following code to your models .xml file: | The first part is related to the nasal script. <tt>("Aircraft/DR400/Models/Liveries");</tt> points FlightGear to the directory where we store our liveries. This is a different directory for every plane, but there should be only one folder for one plane, containing all the liveries for that plane. Add the following code to your models .xml file: | ||
Line 63: | Line 63: | ||
</animation> | </animation> | ||
===Nasal/liveries.nas=== | === Nasal/liveries.nas === | ||
The only thing you might change in the nasal file is the directory of the liveries. If you don't have the livery name in <tt>sim/model/livery/name</tt>, then you have to add this as second function argument. | The only thing you might change in the nasal file is the directory of the liveries. If you don't have the livery name in <tt>sim/model/livery/name</tt>, then you have to add this as second function argument. | ||
aircraft.livery.init("Aircraft/.../Models/Liveries"); | aircraft.livery.init("Aircraft/.../Models/Liveries"); | ||
===...-set.xml=== | === ...-set.xml === | ||
The follow part is really important. If this is not included, the livery changes will not be visible over MP! | The follow part is really important. If this is not included, the livery changes will not be visible over MP! | ||
Line 100: | Line 100: | ||
</menubar> | </menubar> | ||
==Multiple texture files per livery== | == Multiple texture files per livery == | ||
Some models use multiple textures file (eg. seperate files for wings and fuselage). Every texture needs it own property. You can add as many textures as you like. | Some models use multiple textures file (eg. seperate files for wings and fuselage). Every texture needs it own property. You can add as many textures as you like. | ||
===Nasal/liveries.nas=== | === Nasal/liveries.nas === | ||
Is the same as "ordinary" aircraft with just one texture. You will find the content of this file earlier in this article. | Is the same as "ordinary" aircraft with just one texture. You will find the content of this file earlier in this article. | ||
===Models/Liveries=== | === Models/Liveries === | ||
Instead of just one texture we have to deal with multiple ones now. | Instead of just one texture we have to deal with multiple ones now. | ||
Line 125: | Line 125: | ||
Remember the names (<texture> and <lights>), as you will need them in the model file in the next step. | Remember the names (<texture> and <lights>), as you will need them in the model file in the next step. | ||
===Models/....xml=== | === Models/....xml === | ||
<animation> | <animation> | ||
<type>material</type> | <type>material</type> | ||
Line 144: | Line 144: | ||
Note that the texture-prop in both animations are different. They should match the tags around the textures in your <tt>Models/Liveries/</tt> files. | Note that the texture-prop in both animations are different. They should match the tags around the textures in your <tt>Models/Liveries/</tt> files. | ||
===...-set.xml=== | === ...-set.xml === | ||
Is the same as "ordinary" aircraft with just one texture. You will find the content of this file earlier in this article. | Is the same as "ordinary" aircraft with just one texture. You will find the content of this file earlier in this article. | ||
==Performance Improvements== | == Performance Improvements == | ||
For livery changing it seems to be | For livery changing it seems to be important to parent all objects with the same texture. In Blender select all objects and press "ctr-p" to make it parent to the last selected. E.g.: fuselage and doors with the same texture: select at first the doors and then at last the fuselage and press "ctr-p". | ||
Also prevent transparency where possible- it will prevent lags during switching the views. See also the f14b as an very good example! | Also prevent transparency where possible- it will prevent lags during switching the views. See also the f14b as an very good example! | ||
==Testing== | == Testing == | ||
To ensure that your livery setup works correctly over MP, start two instances of FlightGear locally, one with | To ensure that your livery setup works correctly over MP, start two instances of FlightGear locally, one with | ||
Line 161: | Line 161: | ||
fgfs --multiplay=out,10,localhost,5701 --multiplay=in,10,localhost,5702 | fgfs --multiplay=out,10,localhost,5701 --multiplay=in,10,localhost,5702 | ||
==Sharing your liveries== | == Sharing your liveries == | ||
Ofcourse you want other people to use and enjoy your liveries as much as you do. Therefore, other users should be able to download them. | Ofcourse you want other people to use and enjoy your liveries as much as you do. Therefore, other users should be able to download them. | ||