WoW:Getting started with writing AddOns: Difference between revisions
Line 2: | Line 2: | ||
{{uiaddon}} | {{uiaddon}} | ||
The idea of picking up any programming language can be daunting, and when you have to tie your program into someone else's APIs it can be nearly overwhelming. Creating your own | The idea of picking up any programming language can be daunting, and when you have to tie your program into someone else's APIs it can be nearly overwhelming. Creating your own AddOn will be a difficult process for novice coders, but the end satisfaction is worth it. | ||
== First Steps == | == First Steps == | ||
Figure out what you want your | Figure out what you want your AddOn to do. Don't try and get into the details too much, just decide what you want the overall goal to be. I usually start by asking myself these questions: | ||
:*What's my end goal? | :*What's my end goal? | ||
:*What information will I need from WoW for my | :*What information will I need from WoW for my AddOn to work? | ||
:*Will I need to make custom frames? | :*Will I need to make custom frames? | ||
:*Will I need to interact with Blizzard's frames? | :*Will I need to interact with Blizzard's frames? | ||
Line 16: | Line 16: | ||
=== Get Your Information: The WoW API === | === Get Your Information: The WoW API === | ||
Getting information from WoW is critical to making your | Getting information from WoW is critical to making your AddOn function. The [[World of Warcraft API]] has a list of functions that will give you that information. These are your building blocks, and if you don't have a block you need (or thought you needed) then you'll have to find another way to get information for your AddOn. Don't be discouraged, as with any programming language there are many different ways to accomplish your goal, so keep looking until you find a way. | ||
You need to extract the Blizzard interface files. This will allow you to view all of the XML and Lua files that make the game's default UI work, as well as provide you with two introductory tutorials. To do this: | You need to extract the Blizzard interface files. This will allow you to view all of the XML and Lua files that make the game's default UI work, as well as provide you with two introductory tutorials. To do this: | ||
====Open WoW with the console flag==== | ==== Open WoW with the console flag ==== | ||
=====For Windows===== | ===== For Windows ===== | ||
:*Navigate to your World of Warcraft directory | :*Navigate to your <tt>World of Warcraft\</tt> directory (usually in <tt>C:\Program Files (x86)\</tt>) | ||
:*Right click the WoW.exe file | :*Right click the <tt>WoW.exe</tt> file | ||
:*Send to | :*'''Send to → Desktop (create shortcut)''' | ||
:*Navigate to your | :*Navigate to your Desktop, right click on your newly created shortcut | ||
:* | :*Select '''Properties''', a new window will pop up | ||
:*In the target line you need to add '-console' to the very end of the line it should look like this: | :*In the target line you need to add '-console' to the very end of the line it should look like this: | ||
"C:\ | ::<tt>"C:\Program Files (x86)\World of Warcraft\Wow.exe" -console</tt> | ||
:*Make sure to hit | :*Make sure to hit '''Apply''', close the window and launch your created shortcut | ||
=====For Mac OS X===== | ===== For Mac OS X ===== | ||
:*Open Terminal.app | :*Open <tt>Terminal.app</tt> (located in <tt>/Applications/Utilities</tt>) | ||
:*Paste the following command and press return: | :*Paste the following command and press return: | ||
:** | :**<tt>Open "/Applications/World of Warcraft/World of Warcraft-64.app" --args -console</tt> | ||
:*WoW will launch | :*WoW will launch | ||
:* Note that the command was tested with WoW 5.0.5 on Mac OS X 10.8 | :* Note that the command was tested with WoW [[Patch 5.0.5|5.0.5]] on Mac OS X 10.8 | ||
====Extract the API==== | ==== Extract the API ==== | ||
:*At the login page ('''before''' logging in) press the tilde | :*At the login page ('''before''' logging in) press the tilde (<tt>~</tt>) key (the key to left of the 1 key, labeled <sub><tt>`</tt></sub><sup><tt>~</tt></sup>) to open the World of Warcraft console | ||
:*Type "exportInterfaceFiles code" or "exportInterfaceFiles art". Code is probably what | :*Type "<tt>exportInterfaceFiles code</tt>" or "<tt>exportInterfaceFiles art</tt>". Code is probably what you're looking for, you will notice the game will lock up as it is exporting the files, this is normal. | ||
:*You can now find the current version of the stock UI files in the BlizzardInterfaceCode folder of your WoW directory. | :*You can now find the current version of the stock UI files in the <tt>BlizzardInterfaceCode</tt> folder of your WoW directory. | ||
== Editing Tools == | == Editing Tools == | ||
Before you can write any sort of code, you'll want to have a tool that lets you edit your | Before you can write any sort of code, you'll want to have a tool that lets you edit your AddOn files. All AddOn files are plain text files, meaning even Notepad will do. You can also get LUA and XML specific text editors, which will highlight syntax for you, in turn making your coding a lot easier. | ||
To review the list of tools and get one you'd like, head to the [[Lua editors]] page. | To review the list of tools and get one you'd like, head to the [[Lua editors]] page. | ||
== File Types == | == File Types == | ||
There are three primary types of files that you'll need to worry about with | There are three primary types of files that you'll need to worry about with AddOn editing: | ||
* TOC File - This file is required for any | * TOC File - This file is required for any AddOn. This is the file that supplies WoW with information about your AddOn and which files are required for your AddOn to work. | ||
* LUA Files - This contains all the programing for your | * LUA Files - This contains all the programing for your AddOn. | ||
* XML Files - This holds the layout of frames you have created for your | * XML Files - This holds the layout of frames you have created for your AddOn. | ||
===TOC File=== | === TOC File === | ||
This is the file that instructs WoW in some basics about your | This is the file that instructs WoW in some basics about your AddOn and what other files you want loaded. Here's a short example of one: | ||
## Interface: 30000 | ## Interface: 30000 | ||
Line 92: | Line 92: | ||
== Start Coding! == | == Start Coding! == | ||
Start with the tutorials extracted by the [http://us.blizzard.com/support/article.xml?locale=en_US&articleId=21466 Interface AddOn Kit]. The [[HOWTOs]] here has a ton of great examples to help you learn. Don't be shy to dig through someone else's | Start with the tutorials extracted by the [http://us.blizzard.com/support/article.xml?locale=en_US&articleId=21466 Interface AddOn Kit]. The [[HOWTOs]] here has a ton of great examples to help you learn. Don't be shy to dig through someone else's AddOn for help, just be sure not steal code and give credit where credit is due. | ||
== Slash Commands == | == Slash Commands == | ||
A slash command is one way for the user to interact with your | A slash command is one way for the user to interact with your AddOn. These will be the easiest way for a beginner to let the user supply command and change options. | ||
The [[HOWTO: Create a Slash Command]] page covers this pretty well. | The [[HOWTO: Create a Slash Command]] page covers this pretty well. | ||
Line 105: | Line 105: | ||
== SavedVariables == | == SavedVariables == | ||
The [[Saving variables between game sessions]] article covers the key points. For folks new to | The [[Saving variables between game sessions]] article covers the key points. For folks new to AddOns but not other programming languages, just bear in mind that: | ||
* The SavedVariables is only read from on UI loading, not real time, and only saved to on UI unloading. This will generally be from a user logging in or logging out. | * The SavedVariables is only read from on UI loading, not real time, and only saved to on UI unloading. This will generally be from a user logging in or logging out. | ||
* Basically, WoW makes a SavedVariables file for you named after your | * Basically, WoW makes a SavedVariables file for you named after your AddOn. You only get to specify in your TOC *which* variables get saved into that file. | ||
== Localization == | == Localization == | ||
It's a good idea to plan from as early as possible to have your | It's a good idea to plan from as early as possible to have your AddOn be localizable, even if you yourself only speak one language. Review this great article for some things to think about: [[HOWTO: Localize an AddOn]]. | ||
[[Category:HOWTOs|Get Started]] | [[Category:HOWTOs|Get Started]] |
Revision as of 18:04, 11 October 2012
This article or section needs to be cleaned up
|
The idea of picking up any programming language can be daunting, and when you have to tie your program into someone else's APIs it can be nearly overwhelming. Creating your own AddOn will be a difficult process for novice coders, but the end satisfaction is worth it.
First Steps
Figure out what you want your AddOn to do. Don't try and get into the details too much, just decide what you want the overall goal to be. I usually start by asking myself these questions:
- What's my end goal?
- What information will I need from WoW for my AddOn to work?
- Will I need to make custom frames?
- Will I need to interact with Blizzard's frames?
- Do I know the functions needed to do everything I want to do?
Get Your Information: The WoW API
Getting information from WoW is critical to making your AddOn function. The World of Warcraft API has a list of functions that will give you that information. These are your building blocks, and if you don't have a block you need (or thought you needed) then you'll have to find another way to get information for your AddOn. Don't be discouraged, as with any programming language there are many different ways to accomplish your goal, so keep looking until you find a way.
You need to extract the Blizzard interface files. This will allow you to view all of the XML and Lua files that make the game's default UI work, as well as provide you with two introductory tutorials. To do this:
Open WoW with the console flag
For Windows
- Navigate to your World of Warcraft\ directory (usually in C:\Program Files (x86)\)
- Right click the WoW.exe file
- Send to → Desktop (create shortcut)
- Navigate to your Desktop, right click on your newly created shortcut
- Select Properties, a new window will pop up
- In the target line you need to add '-console' to the very end of the line it should look like this:
- "C:\Program Files (x86)\World of Warcraft\Wow.exe" -console
- Make sure to hit Apply, close the window and launch your created shortcut
For Mac OS X
- Open Terminal.app (located in /Applications/Utilities)
- Paste the following command and press return:
- Open "/Applications/World of Warcraft/World of Warcraft-64.app" --args -console
- WoW will launch
- Note that the command was tested with WoW 5.0.5 on Mac OS X 10.8
Extract the API
- At the login page (before logging in) press the tilde (~) key (the key to left of the 1 key, labeled `~) to open the World of Warcraft console
- Type "exportInterfaceFiles code" or "exportInterfaceFiles art". Code is probably what you're looking for, you will notice the game will lock up as it is exporting the files, this is normal.
- You can now find the current version of the stock UI files in the BlizzardInterfaceCode folder of your WoW directory.
Editing Tools
Before you can write any sort of code, you'll want to have a tool that lets you edit your AddOn files. All AddOn files are plain text files, meaning even Notepad will do. You can also get LUA and XML specific text editors, which will highlight syntax for you, in turn making your coding a lot easier. To review the list of tools and get one you'd like, head to the Lua editors page.
File Types
There are three primary types of files that you'll need to worry about with AddOn editing:
- TOC File - This file is required for any AddOn. This is the file that supplies WoW with information about your AddOn and which files are required for your AddOn to work.
- LUA Files - This contains all the programing for your AddOn.
- XML Files - This holds the layout of frames you have created for your AddOn.
TOC File
This is the file that instructs WoW in some basics about your AddOn and what other files you want loaded. Here's a short example of one:
## Interface: 30000 ## Title : My AddOn ## Notes: This AddOn does nothing but display a frame with a button ## Author: My Name myAddOn.xml
You can read more about what you need or can put in a TOC over at The TOC Format
LUA Files
Lua files contain functional pieces of code. You may choose to only have one of these or break up your code into multiple files for a specific purpose. Here's a short example of one:
function MyAddon_OnLoad() SlashCmdList["MyAddon"] = MyAddon_SlashCommand; SLASH_MYADDON1= "/myaddon"; this:RegisterEvent("VARIABLES_LOADED") end
XML Files
XML files are used to specify the visual style of your frames. More importantly though a frame allows you to easily pass events to your Lua files. Check out XML User Interface for details. Here's a short example of an XML file:
<Script file="MyAddon.lua"/> <Frame name="MyAddon"> <Scripts> <OnLoad> MyAddon_OnLoad(); </OnLoad> </Scripts> </Frame>
Start Coding!
Start with the tutorials extracted by the Interface AddOn Kit. The HOWTOs here has a ton of great examples to help you learn. Don't be shy to dig through someone else's AddOn for help, just be sure not steal code and give credit where credit is due.
Slash Commands
A slash command is one way for the user to interact with your AddOn. These will be the easiest way for a beginner to let the user supply command and change options. The HOWTO: Create a Slash Command page covers this pretty well.
A Basic UI Frame
The XML User Interface page covers a lot of a great basics.
SavedVariables
The Saving variables between game sessions article covers the key points. For folks new to AddOns but not other programming languages, just bear in mind that:
- The SavedVariables is only read from on UI loading, not real time, and only saved to on UI unloading. This will generally be from a user logging in or logging out.
- Basically, WoW makes a SavedVariables file for you named after your AddOn. You only get to specify in your TOC *which* variables get saved into that file.
Localization
It's a good idea to plan from as early as possible to have your AddOn be localizable, even if you yourself only speak one language. Review this great article for some things to think about: HOWTO: Localize an AddOn.