Difference between revisions of "Add A New Class Tutorial"

From Dragon Age Toolset Wiki
Jump to: navigation, search
(open up abi_base.xls)
m (Adding languages bar)
 
(46 intermediate revisions by 9 users not shown)
Line 1: Line 1:
[[zh:建立新職業]]
+
== Introduction ==
== New class starter kit ==
+
Creating a new class in Dragon Age is a fairly complicated process, compounded by the fact that currently there are bugs in the 2DA handling which we must work around till they are fixed by Bioware.
  
'''IMPORTANT:'''  ''You will need some version of Microsoft Excel to edit the relevant .xls files in this tutorial!''
+
Before going in and editing the files, make sure you know at least the following details for your class
 +
* Class Name
 +
* Will it be a magic- or a stamina-based character?
 +
* Will the new class reuse existing abilities/spells or new ones?
 +
* What backgrounds will be available for this new class?
  
This kit has all the .xls spreadsheets you need to add a new class.
+
For the purpose of the basic tutorial, we will create a new class called Shaman that will be a copy of the Mage and will be available for the Noble origins.
  
These have been pre-programmed to follow the tutorial I wrote so you can see how it is done. It also contains the converter and the GDA as well.
+
== Create the module ==
 +
Fire up the toolset and create a new module. Let's call it New_Class for this tutorial. Since we want to test this class in the single player campaign, make sure that '''Single Player''' is selected in the Extended Module drop-down under Module Properties and the Module Hierarchy includes '''Single Player''' as well.
  
You still need to edit the scripts in the toolkit and add the UTC model.
+
Go to Tools -> String Editor and create the following strings:
 +
(for the purposes of this tutorial, I am using stringIDs starting at 15000000. Use whatever stringID is generated in your module)
 +
{| rules="all" style="border: 1pt solid black"
 +
|-
 +
|'''String ID'''  ||'''Text'''  ||'''Description'''
 +
|-
 +
|15000000 || Shaman || Class Name (Singular)
 +
|-
 +
|15000001 || Shamans || Class Name (Plural)
 +
|-
 +
|15000002 || Shaman is a new class || Class Description
 +
|-
 +
|15000003 || Shaman || Class Tooltip
 +
|-
 +
|15000004 || JohnD || Default first name for male character (dwarf)
 +
|-
 +
|15000005 || JaneD || Default first name for female character (dwarf)
 +
|-
 +
|15000006 || JohnH || Default first name for male character (human)
 +
|-
 +
|15000007 || JaneH || Default first name for female character (human)
 +
|}
  
YOU STILL NEED TO ADD THESE GDA TO YOUR MODULE
+
{{TutorialRef|String editor}}
  
look in name/mydocuments/bioware/dragonage/addins/modulename
+
== Editing 2das ==
 +
NOTE: '''DO NOT''' edit the .xls files present under <Dragon Age install>\tools\source\2DA directly and generate the GDA. Bioware has given us the power of M2DA precisely for this purpose.
  
Put these GDA files in: name/mydocuments/bioware/dragonage/addins/modulename/core/override directory
+
* Create a new empty workbook or copy or rename one of the workbooks from the 2DA folder and delete the existing worksheets. Lets call this New_Class.xls
 +
* Copy the following worksheets into the the new workbook. Rename all worksheets!!
 +
  CLA_base.xls\CLA_data                ->  New_Class.xls\CLA_data_nc
 +
  2da_base.xls\M2DA_base                ->  New_Class.xls\M2DA_base_nc
 +
  background.xls\Backgrounds            ->  New_Class.xls\Backgrounds_nc
 +
  background.xls\background_defaults    ->  New_Class.xls\background_defaults_nc
 +
  background.xls\chargen_preload        ->  New_Class.xls\chargen_preload_nc
 +
  ALWizard_default.xls\ALWizard_default ->  New_Class.xls\ALShaman_default
 +
  Achievements.xls\Achievements        ->  New_Class.xls\Achievements_nc
 +
* Save the workbook New_Class.xls
 +
<br/>
 +
==== Edit CLA_data_nc ====
 +
In the New_Class.xls workbook, navigate to the CLA_data_nc worksheet.
 +
NOTE: The procedure below has to be done because this 2DA is read sequentially and
 +
adding a class at the end (ID:26 using standard resources) does not generate a unique
 +
background ID. This section will be modified when Bioware fixes these bugs.
 +
Copy line #4 (Wizard Class with ID:2) and paste it below the Rogue class, moving the subsequent lines one down. Te
 +
The important columns to change are:
 +
* '''Label''': Shaman
 +
* '''NameStrref''': 15000000 (''String ID referencing the class name'')
 +
* '''PluralStrref''': 15000001 (''String ID referencing the class in plural'')
 +
* '''DescStrref''': 15000002 (''String ID referencing the class description'')
 +
* '''TooltipStrref''': 15000003 (''String ID referencing the class description'')
 +
* '''Icon''': classico_spirithealer (''You can create a new icon and put that icon's name in here too. For this tutorial, we are reusing the Spirithealer specialization icon'')
 +
* '''Constant''': CLASS_Shaman
 +
* '''StartingAbility1''': ID of the ability assigned during chargen. We will keep this the same as Mage for now (4023).
 +
* '''CharGenLabel''': Shaman
  
You can download the starter kit [http://www.damods.com/forums/index.php?action=downloads;sa=view;down=131 here] (you will need to register)
+
{{TutorialRef||CLA base.xls}}
  
== Editing the 2das ==
+
==== Edit M2DA_base_nc ====
You will need to edit the following 2DA's.
+
In the New_Class.xls workbook, navigate to the M2DA_base_nc worksheet.<br/>
*[[2da_base.xls]]
+
Remove all lines except the first 2 lines.<br/>
*[[abi_base.xls]]
+
Add the following:
*[[ALclassname_default.xls]] (ex ALshaman_default.xls) Copy from ALWizard_default.xls
+
{| rules="all" cellpadding="2" style="border: 1pt solid black"
*[[background.xls]]
+
|-
*[[cla_base.xls]]
+
|ID above 1000000 ||ALShaman_default  ||ALShaman_default
*[[guitypes.xls]]
+
|-
 +
|}
  
=== Open up 2da_base.xls ===
+
<br/>
  
Add the following to the end of M2DA_base TAB
+
==== Edit backgrounds_nc ====
 +
In the New_Class.xls workbook, navigate to the backgrounds_nc worksheet.<br/>
 +
Insert a new column after the Mage column and name it Shaman. Since we want to use this class for the Noble Origins, put a '''1''' against the Noble row. Refer the image below.
 +
[[File:Backgrounds.jpg]]
 +
<br/>The current design of the backgrounds tab makes it difficult to assign different classes to different races for the Mage and Noble origins. Independent modules can override this backgrounds worksheet completely though they would still have to work within the current GUI limitation of 6 backgrounds.
 +
<br/><br/>
 +
==== Edit background_defaults_nc ====
 +
In the New_Class.xls workbook, navigate to the background_defaults_nc worksheet.<br/>
 +
The ID column in this worksheet is populated according to the following formula:
 +
(1000 * Race ID) + (100 * Class ID) + Background ID
  
ID above 100000 ALShaman_default ALShaman_default
+
  Currently, this formula has also been reported to Bioware since this allows for 99 backgrounds
 +
  and requires the Class ID to be in multiples of 100 to yield unique results.
 +
In this tutorial,
 +
* Dwarf Noble Shaman = (1000 * 1) + (100 * 4) + 5 = 1405
 +
* Human Noble Shaman = (1000 * 3) + (100 * 4) + 5 = 3405
  
Now SAVE your file
+
Change the DefaultNameMale and DefaultNameFemale stringID references to the strings created earlier. The result should look like the image below. We will create the default_shaman.utc and the Ability referenced by the ID 5000000 later in the tutorial.
 +
[[File:Background_defaults_nc.jpg]]
 +
<br/><br/>
 +
==== Edit chargen_preload_nc ====
  
=== Open up guitypes.xls ===
+
In the New_Class.xls workbook, navigate to the chargen_preload_nc worksheet.<br/>
At bottom of list paste this:
+
This sheet lists the character templates to load before the chargen so that the model corresponding to the race/class/origin is shown.
 +
<br/>
 +
Copy the ID and Template for the new character templates from the background_defaults_nc worksheet.
 +
{| rules="all" style="border: 1pt solid black"
 +
|-
 +
|'''ID'''  ||'''Template'''
 +
|-
 +
|1405|| default_shaman.utc
 +
|-
 +
|3405 || default_shaman.utc
 +
|}
 +
<br/>
  
ID Label StringId Ability ProgressBar CombatTraining SpecialGraphic TintColor Orphanage Flags BlendTree
+
== Generate the .GDA file ==
500 Class: Shaman 8000000 5000 0 0 1 0x9B0F00 0 0 ****
+
  
Now SAVE your file
+
Open a command prompt and navigate to the <Dragon Age install directory>\tools\ResourceBuild\Processors
 
+
Execute the following command: '''excelprocessor.exe New_Class.xls -outdir="<My Documents path>\Bioware\Dragon Age\AddIns\New_Class\module\override"'''
=== Open up CLA_base.xls ===
+
<br/>
Paste this AFTER line 3: (Move all down 1)
+
 
+
4 Shaman 8000000 8000001 **** 8000002 8000003 classico_spirithealer CLASS_Shaman 2 95 1 100 5 2 2 2 2 2 0 0 0 55 50 1 5 1 3 0.3 4035 **** 1 Shaman ****
+
 
+
Now SAVE your file
+
 
+
=== Open up background.xls ===
+
On backgrounds tab:  You need to insert a section between mage and skill 1, see screenshot
+
 
+
[[Image:Background.jpg]]
+
 
+
 
+
On background_defaults there are several section you need to note here regarding the screenshot:
+
 
+
[[Image:Class tut bgdef.jpg]]
+
 
+
How the ID's work, 1 = dwarf, 4 = shaman, 5 = noble, the rest of the pattern is easy.
+
 
+
On lines 12,15,17,19 you need to add these in.  What I recommend is just copying these lines
+
 
+
:10 ==> 12
+
:13 ==> 15
+
:16 ==> 17
+
:18 ==> 19
+
 
+
The template string is the default_shaman.utc you will need to create in the toolset later on for these to have a base model
+
The Ability is the starting ability tied to this class, in my case it just references a different one then what you will have
+
 
+
On chargen_preload there are several section you need to note here regarding the screenshot:
+
 
+
[[Image:Class tut chardef.jpg]]
+
 
+
These ID's must match what is on the background_defaults otherwise the game WILL crash.
+
 
+
Now SAVE your file
+
 
+
=== Open up abi_base.xls ===
+
 
+
in the ABI_Base tab add the following to the bottom of the list
+
 
+
There are several columns that very are important
+
 
+
abilitytype - define what type of ability. melee, spell, skill etc..---> links with abilitytype.xls
+
 
+
prereqability - defines what is needed to have this ability.  To add a new class these need to be changed on existing classes.
+
 
+
guitypes - referenced what class this links too ---> links with guitypes.xls
+
 
+
 
+
AFTER LINE 119 ==> 4034 HIDDEN_DOG insert a new row and put in the following
+
 
+
5000 HIDDEN_SHAMAN 0 0 380405 330716 hidden 2 0 0 0 0 0 0 0 1 0 0 12 0 0 0 0 3 1.5 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1 7 0 2 33 0 0 0 0
+
 
+
 
+
 
+
Add the bottom paste these
+
 
+
 
+
300000 HEROIC_OFFENSE2 380003 379523 367458 379231 spl_ico_heroic_offense 2 1 0 0 0 20 0 5000 0 0 0 500 3 0 3 1 4 spell_singletarget.ncs 5 90215 244 247 0 0 2 0 0 0 0 0 0 90109 128 1 7 0 2 33 0 0 0 0
+
 
+
300001 HEROIC_AURA2 380000 379520 367458 379214 spl_ico_heroic_aura 2 1 0 0 0 30 0 300000 0 4 15 500 3 0 3 1 4 spell_singletarget.ncs 5 90213 244 247 0 0 0 0 0 0 0 0 0 90110 128 1 7 0 2 33 0 0 0 0
+
 
+
300002 HEROIC_DEFENSE2 380001 379521 367458 379256 spl_ico_heroic_defense 2 1 0 0 0 40 0 300001 0 4 20 500 3 0 3 1 4 spell_singletarget.ncs 10 90214 244 247 0 0 2 0 0 0 0 0 0 90111 128 1 7 0 2 33 0 0 0 0
+
 
+
300003 HASTE2 380005 379525 398957 379229 spl_ico_agility 2 0 0 0 0 0 60 300002 0 4 30 500 1 1 18 1 2 spell_modal.ncs 30 90216 244 247 0 0 2 0 0 0 0 0 0 90112 192 1 7 0 2 33 0 0 0 10
+
 
+
-------------------------------------------------
+
 
+
NOW HERE IS THE TRICKY PART, MAKE SURE YOU DO THIS RIGHT OR KISS YOUR MODULE GOODBYE
+
 
+
HIGHLIGHT LINE 3 ALL THE WAY DOWN TO 558 (BOTTOM OF THE WORKSHEET)
+
 
+
NOW GOTO DATA --> SORT BY COLUMN S (guitypes)  Now they should all be sorted by guitype
+
 
+
Now we need to seperate the mage spells from our new shaman spells.
+
 
+
For guitype spells 1-4, you need to look at the prereqability section for these spells, for those that have 0, replace with 4023
+
This will make these appear only on the mage from now on. (Which means we need to make seperate skills for our new class)
+
Ok this will now prevent duplicate of skills
+
 
+
HIGHLIGHT LINE 3 ALL THE WAY DOWN TO 558 (BOTTOM OF THE WORKSHEET)
+
 
+
NOW GOTO DATA --> SORT BY COLUMN A (ID)  Now we are back to normal
+
 
+
-------------------------------------------------
+
Now goto passive_abilities
+
 
+
Paste the following at the bottom of the list
+
 
+
9000 HIDDEN_SHAMAN 1 2 4 2 6 1 str +2,mag +2,con +1
+
 
+
Now SAVE your file :)
+
 
+
=== open up ALShaman_default.xls ===
+
 
+
Should look like this
+
 
+
[[Image:Class tut alshaman.jpg]]
+
 
+
== Converting the files from 2DA to GDA ==
+
 
+
Create a directory called '''2DA''' on C:, inside that dir create one called override.
+
 
+
In your C:\2da put the following files:
+
 
+
* [[2da_base.xls]]
+
* [[abi_base.xls]]
+
* [[background.xls]]
+
* [[cla_base.xls]]
+
* [[guitypes.xls]]
+
* [[ALShaman_default.xls]]
+
 
+
Also: ExcelProcessor.exe from the tool converter in your toolset section.
+
 
+
Next you need to make a batch file to run to convert these.
+
Simply open notepad, copy and paste below and save as convert.bat
+
 
+
:C:\2DA\ExcelProcessor.exe 2DA_base.xls -outdir=C:\2DA\override\  
+
:C:\2DA\ExcelProcessor.exe background.xls -outdir=C:\2DA\override\
+
:C:\2DA\ExcelProcessor.exe CLA_base.xls -outdir=C:\2DA\override\
+
:C:\2DA\ExcelProcessor.exe ALShaman_Default.xls -outdir=C:\2DA\override\
+
:C:\2DA\ExcelProcessor.exe guitypes.xls -outdir=C:\2DA\override\
+
:C:\2DA\ExcelProcessor.exe ABI_base.xls -outdir=C:\2DA\override\
+
 
+
NOTE: YOU MAY NEED TO "RUN AS ADMINISTRATOR" CONVERT.BAT IN VISTA / W7
+
 
+
VOILA YOU NOW HAVE YOUR GDA FILES FOR THE MODULE
+
 
+
== Creating a module ==
+
Now we begin editing inside the toolset
+
 
+
Create a new module, similiar to the picture below
+
 
+
'''MAKE SURE YOUR STRING SETS GO FROM IN BETWEEN 8,000,000 - 8,300,000 IF IT GOES ABOVE THAT RANGE THE STRINGS WILL NOT WORK.BIOWARE HAS ALREADY POSTED ABOUT THIS SQL PROBLEM'''
+
 
+
[[Image:Class tut module1.jpg]]
+
 
+
After making it go back to the module screen and select heirarchy and make sure single player is checked
+
 
+
[[Image:Class tut hier.jpg]]
+
 
+
Now that your module is created we need to add the appropriate GDA to the override section.
+
 
+
look in name/mydocuments/bioware/dragonage/addins/modulename
+
 
+
Put these GDA files in: name/mydocuments/bioware/dragonage/addins/modulename/core/override directory
+
  
 
== Editing the scripts==  
 
== Editing the scripts==  
 
You now need to edit some scripts.
 
You now need to edit some scripts.
 
 
=== Edit the 2da_constants_h file ===
 
=== Edit the 2da_constants_h file ===
 
 
find the 2da_constants_h file under Core scripts
 
find the 2da_constants_h file under Core scripts
  
Line 210: Line 142:
 
const int ABILITY_TALENT_HIDDEN_TEMPLAR = 4021;
 
const int ABILITY_TALENT_HIDDEN_TEMPLAR = 4021;
 
const int ABILITY_TALENT_HIDDEN_WARRIOR = 4022;
 
const int ABILITY_TALENT_HIDDEN_WARRIOR = 4022;
const int ABILITY_TALENT_HIDDEN_WARRIOR = 5000;
+
const int ABILITY_TALENT_HIDDEN_SHAMAN = 5000;
 
const int ABILITY_TALENT_HURLOCK_PROPERTIES = 90080;
 
const int ABILITY_TALENT_HURLOCK_PROPERTIES = 90080;
 
const int ABILITY_TALENT_INDOMITABLE = 28;
 
const int ABILITY_TALENT_INDOMITABLE = 28;
Line 223: Line 155:
 
const int CLASS_ROGUE = 3;
 
const int CLASS_ROGUE = 3;
 
const int CLASS_SHAMAN = 4;
 
const int CLASS_SHAMAN = 4;
const int CLASS_SHAPESHIFTER = 5;
+
const int CLASS_SHAPESHIFTER = 30;
const int CLASS_SPIRITHEALER = 6;
+
const int CLASS_SPIRITHEALER = 31;
const int CLASS_CHAMPION = 7;
+
const int CLASS_CHAMPION = 32;
const int CLASS_TEMPLAR = 8;
+
const int CLASS_TEMPLAR = 33;
const int CLASS_BERSERKER = 9;
+
const int CLASS_BERSERKER = 34;
const int CLASS_REAVER = 10;
+
const int CLASS_REAVER = 35;
const int CLASS_ARCANE_WARRIOR = 11;
+
const int CLASS_ARCANE_WARRIOR = 36;
const int CLASS_ASSASSIN = 12;
+
const int CLASS_ASSASSIN = 37;
const int CLASS_BLOOD_MAGE = 13;
+
const int CLASS_BLOOD_MAGE = 38;
const int CLASS_BARD = 14;
+
const int CLASS_BARD = 39;
const int CLASS_RANGER = 15;
+
const int CLASS_RANGER = 40;
const int CLASS_DUELIST = 16;
+
const int CLASS_DUELIST = 41;
 
const int CLASS_SHALE = 17;
 
const int CLASS_SHALE = 17;
 
const int CLASS_DOG = 18;
 
const int CLASS_DOG = 18;
Line 240: Line 172:
 
</dascript>
 
</dascript>
  
Afterwards on top select SAVE then CHECK IN
+
Please note that the constants for the specializations have been changed; this will require editing of the Achievements gda via an M2DA to correct the displayed data when unlocking specializations. You may also have to recompile one or more of the plot scripts, but I have not been able to test this personally.
 
+
Now at the top and click "EXPORT WITHOUT DEPENDENT RESOURCES"
+
 
+
=== Edit the gen00pt_class_race_gend file ===
+
under _Global ==> plot scripts find the gen00pt_class_race_gend file.  
+
 
+
right click on gen00pt_class_race_gend, select CHECK OUT
+
 
+
Go down and you'll see the following and edit it like below:
+
<dascript>
+
            case GEN_CLASS_MAGE:
+
            {
+
                nResult =  ( GetCreatureCoreClass(oListener) == CLASS_WIZARD );
+
                break;
+
            }
+
            case GEN_CLASS_WARRIOR:
+
            {
+
                // DEBUG START
+
                nResult =  ( GetCreatureCoreClass(oListener) == CLASS_WARRIOR );
+
                break;
+
            }
+
            case GEN_CLASS_ROGUE:
+
            {
+
                nResult =  ( GetCreatureCoreClass(oListener) == CLASS_ROGUE );
+
                break;
+
            }
+
            case GEN_CLASS_SHAMAN:
+
            {
+
                nResult =  ( GetCreatureCoreClass(oListener) == CLASS_SHAMAN );
+
                break;
+
            }
+
</dascript>
+
  
 
Afterwards on top select SAVE then CHECK IN
 
Afterwards on top select SAVE then CHECK IN
Line 316: Line 216:
 
         int nAbility = GetM2DAInt(TABLE_STARTING_EQUIPMENT,"Ability", nIdx);
 
         int nAbility = GetM2DAInt(TABLE_STARTING_EQUIPMENT,"Ability", nIdx);
 
         _AddAbility(oCreature, nAbility);
 
         _AddAbility(oCreature, nAbility);
 
 
     }
 
     }
 
     else
 
     else
Line 332: Line 231:
 
                 break;
 
                 break;
 
         }
 
         }
 
 
         LoadItemsFromTemplate(oCreature, sTemplate, TRUE);
 
         LoadItemsFromTemplate(oCreature, sTemplate, TRUE);
 
     }
 
     }
 
}
 
}
</dascript>
 
 
Next goto  "// Undo Class and Race selection" and add the 4th CharGen_ClearAbilityList
 
 
<dascript>
 
            // Note: This wipes the ability list clear
 
            CharGen_ClearAbilityList(oChar,1);
 
            CharGen_ClearAbilityList(oChar,2);
 
            CharGen_ClearAbilityList(oChar,3);
 
            CharGen_ClearAbilityList(oChar,4);
 
</dascript>
 
 
Next goto "// enabling proper tactics presets" and add the ValidForClass4 parts
 
 
<dascript>
 
            nForClass1 = GetM2DAInt(TABLE_TACTICS_USER_PRESETS, "ValidForClass1", nCurrentRow);
 
            nForClass2 = GetM2DAInt(TABLE_TACTICS_USER_PRESETS, "ValidForClass2", nCurrentRow);
 
            nForClass3 = GetM2DAInt(TABLE_TACTICS_USER_PRESETS, "ValidForClass3", nCurrentRow);
 
            nForClass4 = GetM2DAInt(TABLE_TACTICS_USER_PRESETS, "ValidForClass4", nCurrentRow);
 
            if(nCoreClass == nForClass1 || nCoreClass == nForClass2 || nCoreClass == nForClass3 || nCoreClass == nForClass4)
 
                AddTacticPresetID(oCreature, nCurrentRow);
 
 
</dascript>
 
</dascript>
  
Line 362: Line 239:
  
 
Now at the top and click "EXPORT WITHOUT DEPENDENT RESOURCES"
 
Now at the top and click "EXPORT WITHOUT DEPENDENT RESOURCES"
 +
=== Edit the sys_chargen file ===
 +
Find the sys_chargen ==> under _Systems
  
=== Edit the sys_rewards_h file ===
+
right click on sys_chargen, select Duplicate; name the file something like wd_sys_chargen.
Find the sys_rewards_h file under _Systems ==> _Includes
+
  
right click on sys_rewards_h, select CHECK OUT
+
Change this line:
 
+
Go down to the following section (~line 500) and edit it like below:
+
  
 
<dascript>
 
<dascript>
const int SPEC_WIZARD_SHAPESHIFTER = 5;
+
const int MAX_CLASS_INDEX = 4; // Last index of available base classes in cla_base.
const int SPEC_WIZARD_SPIRITHEALER = 6;
+
const int SPEC_WIZARD_ARCANE_WARRIOR = 11;
+
const int SPEC_WIZARD_BLOOD_MAGE    = 13;
+
 
+
const int SPEC_WARRIOR_CHAMPION = 7;
+
const int SPEC_WARRIOR_TEMPLAR = 8;
+
const int SPEC_WARRIOR_BERSERKER = 9;
+
const int SPEC_WARRIOR_REAVER = 10;
+
 
+
const int SPEC_ROGUE_ASSASSIN = 12;
+
const int SPEC_ROGUE_BARD = 14;
+
const int SPEC_ROGUE_RANGER  = 15;
+
const int SPEC_ROGUE_DUELIST  = 16;
+
 
</dascript>
 
</dascript>
 +
This value does not have to be limited to the minimum number of base classes in the file; it simply has to be higher than the default value of 3.
  
Afterwards on top select SAVE then CHECK IN
+
Go down to the following section and either comment it out as I show it, or delete it; if it is left in place without being commented out, it will cause your class to provide double the attribute points at character creation or level up.
  
Now at the top and click "EXPORT WITHOUT DEPENDENT RESOURCES"
+
<dascript>
 +
        // ---------------------------------------------------------------------
 +
        // This fires whenever the player presses + or - on an attribute to spend
 +
        // points on the attribute screen of character generation
 +
        //
 +
        // int(0) - Constant PROPERTY_* integer
 +
        // int(1) - # of points spent
 +
        // ---------------------------------------------------------------------
 +
        /*case EVENT_TYPE_CHARGEN_ASSIGN_ATTRIBUTES:
 +
        {
 +
            int nAttribute = GetEventInteger(ev,0);
 +
            int nPoints    = GetEventInteger(ev,1);
  
=== Edit the sys_chargen file ===
+
            // -----------------------------------------------------------------
Find the sys_chargen ==> under _Systems
+
            // Subtract from available points to spend
 +
            // -----------------------------------------------------------------
 +
            Chargen_ModifyCreaturePropertyBase(oChar, PROPERTY_SIMPLE_ATTRIBUTE_POINTS, IntToFloat(nPoints*-1));
  
right click on sys_chargen, select CHECK OUT
 
  
Change this line:
+
            // -----------------------------------------------------------------
 
+
            // Spend it.
<dascript>
+
            // -----------------------------------------------------------------
const int MAX_CLASS_INDEX = 4; // Last index of available base classes in cla_base.
+
            Chargen_SpendAttributePoints(oChar,nAttribute,nPoints,FALSE);
 +
            break;
 +
        }*/
 
</dascript>
 
</dascript>
  
Line 409: Line 287:
 
                 {
 
                 {
 
                     Log_Trace(LOG_CHANNEL_CHARACTER,"sys_chargen","Setting default values for player character");
 
                     Log_Trace(LOG_CHANNEL_CHARACTER,"sys_chargen","Setting default values for player character");
 
 
                     int nRandClass = abs((GetLowResTimer()%3)+1);
 
                     int nRandClass = abs((GetLowResTimer()%3)+1);
 
 
                     if(nRandClass == CLASS_ROGUE || nRandClass == CLASS_WARRIOR || nRandClass == CLASS_SHAMAN)
 
                     if(nRandClass == CLASS_ROGUE || nRandClass == CLASS_WARRIOR || nRandClass == CLASS_SHAMAN)
 
                     {
 
                     {
Line 422: Line 298:
 
                         WR_SetPlotFlag(PLT_GEN00PT_BACKGROUNDS, GEN_BACK_CIRCLE, TRUE);
 
                         WR_SetPlotFlag(PLT_GEN00PT_BACKGROUNDS, GEN_BACK_CIRCLE, TRUE);
 
                     }
 
                     }
 
 
 
                     Chargen_SetNumTactics(oChar);
 
                     Chargen_SetNumTactics(oChar);
 
                     SetCanLevelUp(oChar,Chargen_HasPointsToSpend(oChar));
 
                     SetCanLevelUp(oChar,Chargen_HasPointsToSpend(oChar));
  
 
                     SendEventModuleChargenDone("", "");
 
                     SendEventModuleChargenDone("", "");
 
 
                 }
 
                 }
 
</dascript>
 
</dascript>
Line 449: Line 322:
  
 
Now at the top and click "EXPORT WITHOUT DEPENDENT RESOURCES"
 
Now at the top and click "EXPORT WITHOUT DEPENDENT RESOURCES"
 +
 +
=== Create the module script ===
 +
Create a new script and give it a descriptive name like "loadscript". This script will intercept the Chargen events and redirect them to the custom version of the sys_chargen script you just created. It can also be used to intercept other events if you want to alter other things or add items to a newly created character's inventory. This is a good example of how to use it to add custom items and redirect the chargen to the custom script.
 +
 +
<dascript>
 +
#include "utility_h"
 +
#include "wrappers_h"
 +
#include "events_h"
 +
void main()
 +
{
 +
  event ev  = GetCurrentEvent();
 +
    int nEvent = GetEventType(ev);
 +
    Log_Events("", ev);
 +
    switch (nEvent)
 +
    {
 +
        ////////////////////////////////////////////////////////////////////////
 +
        // Sent by: The engine
 +
        // When: The module loads from a save game, or for the first time. This event can fire more than
 +
        //      once for a single module or game instance.
 +
        ////////////////////////////////////////////////////////////////////////
 +
        case EVENT_TYPE_MODULE_LOAD:
 +
        {
 +
          //Nothing is needed here, unless you are doing other things with your module.
 +
        }
 +
        default:
 +
        {
 +
            // -----------------------------------------------------------------
 +
            // Handle character generation events sent by the engine.
 +
            // -----------------------------------------------------------------
 +
            if ((nEvent >= EVENT_TYPE_CHARGEN_START && nEvent <= EVENT_TYPE_CHARGEN_END) || nEvent == EVENT_TYPE_PLAYERLEVELUP )
 +
            {
 +
                HandleEvent(ev, R"ld_sys_chargen.ncs");
 +
            }
 +
            else
 +
            {
 +
                Log_Trace(LOG_CHANNEL_EVENTS, GetCurrentScriptName(), Log_GetEventNameById(nEvent) + " (" + ToString(nEvent) + ") *** Unhandled event ***");
 +
            }
 +
            break;
 +
        }
 +
    }
 +
}
 +
</dascript>
 +
 +
Afterwards on top select SAVE then CHECK IN
 +
 +
Now at the top and click "EXPORT WITHOUT DEPENDENT RESOURCES"
 +
{{TutorialRef|Script}}
  
 
== Creating the UTC template file==
 
== Creating the UTC template file==
Line 455: Line 375:
 
Click on the "creature tab" (red head icon)
 
Click on the "creature tab" (red head icon)
  
Right click on default_mage ==> duplicate
+
Right click on default_player ==> duplicate
 
Do like the following:
 
Do like the following:
  
Line 467: Line 387:
 
[[Image:Class tut dfs2.jpg]]
 
[[Image:Class tut dfs2.jpg]]
  
Now at the top and click SAVE ==> CHECK IN
+
Now, you need to make one for each race and origin that you wish for the class to be available to (this is how Bioware does it, if you look carefully at the various entries in the backgrounds.xls worksheets); name each one with the following abbreviations for race or origin: hm_noble, hm_mage, dw_comm, dw_noble, elf_city, elf_mage, or elf_dalish (gender is handled automatically by the game, based on race). Making different versions of the template allows each version to have different armor and weapons available to them, which helps them blend into the base game (if you are using it in a module that extends Single Player). Be sure to use the proper names in each location in the backgrounds.xls worksheets or the template will not be displayed when you select the background in the game.
  
Now at the top and click "EXPORT WITHOUT DEPENDENT RESOURCES"
+
Now at the top and click SAVE ==> CHECK IN for each template.
  
== Creating some strings ==
+
Now at the top and click "EXPORT WITHOUT DEPENDENT RESOURCES" for each template.
 +
{{TutorialRef|Designer Resources#Creating new resources|Creature|Exporting a module}}
  
Start the String editor and right click and insert.
 
  
You will be setting up like this
 
 
:Table = module talk base
 
:Owner = module name
 
:TYPE = GUI
 
 
:8000000 - Shaman
 
:8000001 - Shamans
 
:8000002 - Shamans commune with spirits to get thier other worldly powers.
 
:8000004 - Shaman
 
:8000005 - Shaman Male Name
 
:8000006 - Shaman Female Name
 
 
When all is said close string editor
 
  
 
== Putting it all together ==
 
== Putting it all together ==
 
 
Up on top ON THE EXPORT TAB  
 
Up on top ON THE EXPORT TAB  
  
Line 501: Line 406:
  
 
"EXPORT TALK TABLE"
 
"EXPORT TALK TABLE"
 
+
{{TutorialRef|Exporting a module}}
 
== Cleaning up ==
 
== Cleaning up ==
 
 
DON'T SKIP THIS PART
 
DON'T SKIP THIS PART
  
goto name/mydocuments/bioware/dragonage/packages/core/override/toolset
+
Delete all files in the name/mydocuments/bioware/dragonage/packages/core/override/toolset; these are not needed.
 
+
COPY THE FOLLOWING FILES OVER TO YOUR
+
 
+
name/mydocuments/bioware/dragonage/addins/modulename/core/override/toolset
+
 
+
:2da_constant_h.nss
+
:gen00pt_class_race_gend.nss
+
:sys_chargen_h.nss
+
:sys_rewards_h.nss
+
:sys_chargen.nss
+
:sys_chargen.ncs
+
 
+
Delete the rest in the name/mydocuments/bioware/dragonage/packages/core/override/toolset
+
 
+
 
== Trying it out ==
 
== Trying it out ==
 
 
Start up your game (It may take a min) and start a new game.
 
Start up your game (It may take a min) and start a new game.
  
Line 534: Line 423:
  
 
Make sure you did not miss ANY ";" or "{ }" as a single one of these missed can destroy the game.
 
Make sure you did not miss ANY ";" or "{ }" as a single one of these missed can destroy the game.
 
 
== Troubleshooting ==
 
== Troubleshooting ==
 
 
MY SPELLS ARE NOT SHOWING UP IN THE CREATION SCREEN, HELP!!
 
MY SPELLS ARE NOT SHOWING UP IN THE CREATION SCREEN, HELP!!
  
Line 548: Line 435:
 
* Try rebooting your computer.
 
* Try rebooting your computer.
  
 +
{{Languages}}
 
[[Category:Character generation]]
 
[[Category:Character generation]]
 
[[Category:Tutorials]]
 
[[Category:Tutorials]]

Latest revision as of 12:52, 11 June 2011

Introduction

Creating a new class in Dragon Age is a fairly complicated process, compounded by the fact that currently there are bugs in the 2DA handling which we must work around till they are fixed by Bioware.

Before going in and editing the files, make sure you know at least the following details for your class

  • Class Name
  • Will it be a magic- or a stamina-based character?
  • Will the new class reuse existing abilities/spells or new ones?
  • What backgrounds will be available for this new class?

For the purpose of the basic tutorial, we will create a new class called Shaman that will be a copy of the Mage and will be available for the Noble origins.

Create the module

Fire up the toolset and create a new module. Let's call it New_Class for this tutorial. Since we want to test this class in the single player campaign, make sure that Single Player is selected in the Extended Module drop-down under Module Properties and the Module Hierarchy includes Single Player as well.

Go to Tools -> String Editor and create the following strings: (for the purposes of this tutorial, I am using stringIDs starting at 15000000. Use whatever stringID is generated in your module)

String ID Text Description
15000000 Shaman Class Name (Singular)
15000001 Shamans Class Name (Plural)
15000002 Shaman is a new class Class Description
15000003 Shaman Class Tooltip
15000004 JohnD Default first name for male character (dwarf)
15000005 JaneD Default first name for female character (dwarf)
15000006 JohnH Default first name for male character (human)
15000007 JaneH Default first name for female character (human)
Arrowblue.png - String editor

Editing 2das

NOTE: DO NOT edit the .xls files present under <Dragon Age install>\tools\source\2DA directly and generate the GDA. Bioware has given us the power of M2DA precisely for this purpose.

  • Create a new empty workbook or copy or rename one of the workbooks from the 2DA folder and delete the existing worksheets. Lets call this New_Class.xls
  • Copy the following worksheets into the the new workbook. Rename all worksheets!!
 CLA_base.xls\CLA_data                 ->   New_Class.xls\CLA_data_nc
 2da_base.xls\M2DA_base                ->   New_Class.xls\M2DA_base_nc
 background.xls\Backgrounds            ->   New_Class.xls\Backgrounds_nc
 background.xls\background_defaults    ->   New_Class.xls\background_defaults_nc
 background.xls\chargen_preload        ->   New_Class.xls\chargen_preload_nc
 ALWizard_default.xls\ALWizard_default ->   New_Class.xls\ALShaman_default
 Achievements.xls\Achievements         ->   New_Class.xls\Achievements_nc
  • Save the workbook New_Class.xls


Edit CLA_data_nc

In the New_Class.xls workbook, navigate to the CLA_data_nc worksheet.

NOTE: The procedure below has to be done because this 2DA is read sequentially and 
adding a class at the end (ID:26 using standard resources) does not generate a unique 
background ID. This section will be modified when Bioware fixes these bugs.

Copy line #4 (Wizard Class with ID:2) and paste it below the Rogue class, moving the subsequent lines one down. Te The important columns to change are:

  • Label: Shaman
  • NameStrref: 15000000 (String ID referencing the class name)
  • PluralStrref: 15000001 (String ID referencing the class in plural)
  • DescStrref: 15000002 (String ID referencing the class description)
  • TooltipStrref: 15000003 (String ID referencing the class description)
  • Icon: classico_spirithealer (You can create a new icon and put that icon's name in here too. For this tutorial, we are reusing the Spirithealer specialization icon)
  • Constant: CLASS_Shaman
  • StartingAbility1: ID of the ability assigned during chargen. We will keep this the same as Mage for now (4023).
  • CharGenLabel: Shaman
Arrowblue.png
- CLA base.xls

Edit M2DA_base_nc

In the New_Class.xls workbook, navigate to the M2DA_base_nc worksheet.
Remove all lines except the first 2 lines.
Add the following:

ID above 1000000 ALShaman_default ALShaman_default


Edit backgrounds_nc

In the New_Class.xls workbook, navigate to the backgrounds_nc worksheet.
Insert a new column after the Mage column and name it Shaman. Since we want to use this class for the Noble Origins, put a 1 against the Noble row. Refer the image below. Backgrounds.jpg
The current design of the backgrounds tab makes it difficult to assign different classes to different races for the Mage and Noble origins. Independent modules can override this backgrounds worksheet completely though they would still have to work within the current GUI limitation of 6 backgrounds.

Edit background_defaults_nc

In the New_Class.xls workbook, navigate to the background_defaults_nc worksheet.
The ID column in this worksheet is populated according to the following formula:

(1000 * Race ID) + (100 * Class ID) + Background ID
Currently, this formula has also been reported to Bioware since this allows for 99 backgrounds 
and requires the Class ID to be in multiples of 100 to yield unique results.

In this tutorial,

  • Dwarf Noble Shaman = (1000 * 1) + (100 * 4) + 5 = 1405
  • Human Noble Shaman = (1000 * 3) + (100 * 4) + 5 = 3405

Change the DefaultNameMale and DefaultNameFemale stringID references to the strings created earlier. The result should look like the image below. We will create the default_shaman.utc and the Ability referenced by the ID 5000000 later in the tutorial. Background defaults nc.jpg

Edit chargen_preload_nc

In the New_Class.xls workbook, navigate to the chargen_preload_nc worksheet.
This sheet lists the character templates to load before the chargen so that the model corresponding to the race/class/origin is shown.
Copy the ID and Template for the new character templates from the background_defaults_nc worksheet.

ID Template
1405 default_shaman.utc
3405 default_shaman.utc


Generate the .GDA file

Open a command prompt and navigate to the <Dragon Age install directory>\tools\ResourceBuild\Processors Execute the following command: excelprocessor.exe New_Class.xls -outdir="<My Documents path>\Bioware\Dragon Age\AddIns\New_Class\module\override"

Editing the scripts

You now need to edit some scripts.

Edit the 2da_constants_h file

find the 2da_constants_h file under Core scripts

right click on 2DA_CONSTANTS_H, select CHECK OUT

Go down to the following sections and edit it like below:

const int ABILITY_TALENT_HIDDEN_DUELIST = 4030;
const int ABILITY_TALENT_HIDDEN_RANGER = 4029;
const int ABILITY_TALENT_HIDDEN_REAVER = 4019;
const int ABILITY_TALENT_HIDDEN_ROGUE = 4020;
const int ABILITY_TALENT_HIDDEN_SHALE = 4033;
const int ABILITY_TALENT_HIDDEN_TEMPLAR = 4021;
const int ABILITY_TALENT_HIDDEN_WARRIOR = 4022;
const int ABILITY_TALENT_HIDDEN_SHAMAN = 5000;
const int ABILITY_TALENT_HURLOCK_PROPERTIES = 90080;
const int ABILITY_TALENT_INDOMITABLE = 28;

and

//Class Constants
const int CLASS_WARRIOR = 1;
const int CLASS_WIZARD = 2;
const int CLASS_ROGUE = 3;
const int CLASS_SHAMAN = 4;
const int CLASS_SHAPESHIFTER = 30;
const int CLASS_SPIRITHEALER = 31;
const int CLASS_CHAMPION = 32;
const int CLASS_TEMPLAR = 33;
const int CLASS_BERSERKER = 34;
const int CLASS_REAVER = 35;
const int CLASS_ARCANE_WARRIOR = 36;
const int CLASS_ASSASSIN = 37;
const int CLASS_BLOOD_MAGE = 38;
const int CLASS_BARD = 39;
const int CLASS_RANGER = 40;
const int CLASS_DUELIST = 41;
const int CLASS_SHALE = 17;
const int CLASS_DOG = 18;
const int CLASS_MONSTER_ANIMAL = 19;

Please note that the constants for the specializations have been changed; this will require editing of the Achievements gda via an M2DA to correct the displayed data when unlocking specializations. You may also have to recompile one or more of the plot scripts, but I have not been able to test this personally.

Afterwards on top select SAVE then CHECK IN

Now at the top and click "EXPORT WITHOUT DEPENDENT RESOURCES"

Edit the sys_chargen_h file

Find the sys_chargen_h file under _Systems ==> _Includes

right click on sys_chargen_h, select CHECK OUT

Go down to the starting skills section and edit it like below:

    // -------------------------------------------------------------------------
    // Starting Skills
    // -------------------------------------------------------------------------
    if (nClass == CLASS_WARRIOR)
    {
        _AddAbility(oChar, 100100);
    }
    else if (nClass == CLASS_ROGUE)
    {
        _AddAbility(oChar, ABILITY_SKILL_POISON_1);
    }
    else if (nClass == CLASS_WIZARD)
    {
        _AddAbility(oChar, ABILITY_SKILL_HERBALISM_1);
    }
    else if (nClass == CLASS_SHAMAN)
    {
        _AddAbility(oChar, ABILITY_SKILL_HERBALISM_1);
    }
}

Next goto starting ability

        // ---------------------------------------------------------------------
        // Load the starting ability for the background
        // ---------------------------------------------------------------------
        int nAbility = GetM2DAInt(TABLE_STARTING_EQUIPMENT,"Ability", nIdx);
        _AddAbility(oCreature, nAbility);
    }
    else
    {
        string sTemplate = "default_player.utc";
        switch (nClass)
        {
            case CLASS_WARRIOR: sTemplate = "default_warrior.utc";
                break;
            case CLASS_ROGUE:   sTemplate = "default_rogue.utc";
                break;
            case CLASS_WIZARD:  sTemplate = "default_wizard.utc";
                break;
            case CLASS_SHAMAN:  sTemplate = "default_shaman.utc";
                break;
        }
        LoadItemsFromTemplate(oCreature, sTemplate, TRUE);
    }
}

Afterwards on top select SAVE then CHECK IN

Now at the top and click "EXPORT WITHOUT DEPENDENT RESOURCES"

Edit the sys_chargen file

Find the sys_chargen ==> under _Systems

right click on sys_chargen, select Duplicate; name the file something like wd_sys_chargen.

Change this line:

const int MAX_CLASS_INDEX = 4; // Last index of available base classes in cla_base.

This value does not have to be limited to the minimum number of base classes in the file; it simply has to be higher than the default value of 3.

Go down to the following section and either comment it out as I show it, or delete it; if it is left in place without being commented out, it will cause your class to provide double the attribute points at character creation or level up.

        // ---------------------------------------------------------------------
        // This fires whenever the player presses + or - on an attribute to spend
        // points on the attribute screen of character generation
        //
        // int(0) - Constant PROPERTY_* integer
        // int(1) - # of points spent
        // ---------------------------------------------------------------------
        /*case EVENT_TYPE_CHARGEN_ASSIGN_ATTRIBUTES:
        {
            int nAttribute = GetEventInteger(ev,0);
            int nPoints    = GetEventInteger(ev,1);
 
            // -----------------------------------------------------------------
            // Subtract from available points to spend
            // -----------------------------------------------------------------
            Chargen_ModifyCreaturePropertyBase(oChar, PROPERTY_SIMPLE_ATTRIBUTE_POINTS, IntToFloat(nPoints*-1));
 
 
            // -----------------------------------------------------------------
            // Spend it.
            // -----------------------------------------------------------------
            Chargen_SpendAttributePoints(oChar,nAttribute,nPoints,FALSE);
            break;
        }*/

Go down to the special handling section and edit it like below:

// special handling for aluvian
                if (nQuickStart == 0 )
                {
                    Log_Trace(LOG_CHANNEL_CHARACTER,"sys_chargen","Setting default values for player character");
                    int nRandClass = abs((GetLowResTimer()%3)+1);
                    if(nRandClass == CLASS_ROGUE || nRandClass == CLASS_WARRIOR || nRandClass == CLASS_SHAMAN)
                    {
                        _RunChargen(RACE_HUMAN, nRandClass, oChar, BACKGROUND_NOBLE );
                        WR_SetPlotFlag(PLT_GEN00PT_BACKGROUNDS, GEN_BACK_HUMAN_NOBLE, TRUE);
                    }
                    else // mage
                    {
                        _RunChargen(RACE_HUMAN, nRandClass, oChar, BACKGROUND_MAGI );
                        WR_SetPlotFlag(PLT_GEN00PT_BACKGROUNDS, GEN_BACK_CIRCLE, TRUE);
                    }
                    Chargen_SetNumTactics(oChar);
                    SetCanLevelUp(oChar,Chargen_HasPointsToSpend(oChar));
 
                    SendEventModuleChargenDone("", "");
                }

next go down to the tactics sections and add the following:

                // associate some tactics preset table
                int nPresetTable;
                if(GetCreatureCoreClass(oChar) == CLASS_WARRIOR)
                    nPresetTable = 1; // tank
                else if(GetCreatureCoreClass(oChar) == CLASS_ROGUE)
                    nPresetTable = 2; // damage dealer
                else if(GetCreatureCoreClass(oChar) == CLASS_SHAMAN)
                    nPresetTable = 1; // damage dealer
                else // mage
                    nPresetTable = 5; // nuker

Afterwards on top select SAVE then CHECK IN

Now at the top and click "EXPORT WITHOUT DEPENDENT RESOURCES"

Create the module script

Create a new script and give it a descriptive name like "loadscript". This script will intercept the Chargen events and redirect them to the custom version of the sys_chargen script you just created. It can also be used to intercept other events if you want to alter other things or add items to a newly created character's inventory. This is a good example of how to use it to add custom items and redirect the chargen to the custom script.

#include "utility_h"
#include "wrappers_h"
#include "events_h"
void main()
{
   event ev   = GetCurrentEvent();
    int nEvent = GetEventType(ev);
    Log_Events("", ev);
    switch (nEvent)
    {
        ////////////////////////////////////////////////////////////////////////
        // Sent by: The engine
        // When: The module loads from a save game, or for the first time. This event can fire more than
        //       once for a single module or game instance.
        ////////////////////////////////////////////////////////////////////////
        case EVENT_TYPE_MODULE_LOAD:
        {
           //Nothing is needed here, unless you are doing other things with your module.
        }
        default:
        {
            // -----------------------------------------------------------------
            // Handle character generation events sent by the engine.
            // -----------------------------------------------------------------
            if ((nEvent >= EVENT_TYPE_CHARGEN_START && nEvent <= EVENT_TYPE_CHARGEN_END) || nEvent == EVENT_TYPE_PLAYERLEVELUP )
            {
                HandleEvent(ev, R"ld_sys_chargen.ncs");
            }
            else
            {
                Log_Trace(LOG_CHANNEL_EVENTS, GetCurrentScriptName(), Log_GetEventNameById(nEvent) + " (" + ToString(nEvent) + ") *** Unhandled event ***");
            }
            break;
        }
    }
}

Afterwards on top select SAVE then CHECK IN

Now at the top and click "EXPORT WITHOUT DEPENDENT RESOURCES"

Arrowblue.png - Script

Creating the UTC template file

Back in the toolset we need to do the following:

Click on the "creature tab" (red head icon)

Right click on default_player ==> duplicate Do like the following:

Class tut dfs1.jpg

Now we need to edit the values and give them some armor and weapons, like so:

Class: Shaman (from dropdown) Name: Default Male Shaman

Class tut dfs2.jpg

Now, you need to make one for each race and origin that you wish for the class to be available to (this is how Bioware does it, if you look carefully at the various entries in the backgrounds.xls worksheets); name each one with the following abbreviations for race or origin: hm_noble, hm_mage, dw_comm, dw_noble, elf_city, elf_mage, or elf_dalish (gender is handled automatically by the game, based on race). Making different versions of the template allows each version to have different armor and weapons available to them, which helps them blend into the base game (if you are using it in a module that extends Single Player). Be sure to use the proper names in each location in the backgrounds.xls worksheets or the template will not be displayed when you select the background in the game.

Now at the top and click SAVE ==> CHECK IN for each template.

Now at the top and click "EXPORT WITHOUT DEPENDENT RESOURCES" for each template.

Arrowblue.png - Designer Resources#Creating new resources
- Creature
- Exporting a module


Putting it all together

Up on top ON THE EXPORT TAB

"EXPORT WITHOUT DEPENDENT RESOURCES"

"GENERATE MODULE XML"

"GENERATE MANIFEST XML"

"EXPORT TALK TABLE"

Arrowblue.png - Exporting a module

Cleaning up

DON'T SKIP THIS PART

Delete all files in the name/mydocuments/bioware/dragonage/packages/core/override/toolset; these are not needed.

Trying it out

Start up your game (It may take a min) and start a new game.

  • WARNING* IF ANYTHING HAS GONE WRONG HERE YOUR GAME WILL BE SEVERELY DAMAGED

Select MALE ==> HUMAN ==> SHAMAN ==> MAGI

YOU SHOULD SEE YOUR NEW CHARACTER

IF SOMETHING HAPPENED QUIT AND DOUBLE CHECK YOUR STEPS

Make sure you did not miss ANY ";" or "{ }" as a single one of these missed can destroy the game.

Troubleshooting

MY SPELLS ARE NOT SHOWING UP IN THE CREATION SCREEN, HELP!!

  • You may not have sort your ability file back to ID. It has to be sorted by ID in order to show up.
  • You may not have assigned the new abilities to your new class "5000" in the prereqability column

MY MODEL IS NOT SHOWING UP WHEN I GOTO MALE ==> HUMAN ==> SHAMAN ==> MAGI

  • It is very likely you did not EXPORT your default_shaman.utc model
  • Double check the background file to make sure you are using default_shaman.utc for the template
  • Try rebooting your computer.


Language: English  • 中文