/OreWar/docs/html/_gorilla_8h_source.html
https://github.com/MikeShire/OreWar · HTML · 3034 lines · 3033 code · 0 blank · 1 comment · 0 complexity · 352e4ae3e3c19d0b51a840d39767aab8 MD5 · raw file
Large files are truncated click here to view the full file
- <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
- <html xmlns="http://www.w3.org/1999/xhtml">
- <head>
- <meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/>
- <title>OreWar: C:/Programming/Personal/OreWar/OreWar/Gorilla.h Source File</title>
- <link href="tabs.css" rel="stylesheet" type="text/css"/>
- <link href="doxygen.css" rel="stylesheet" type="text/css"/>
- </head>
- <body>
- <!-- Generated by Doxygen 1.6.3 -->
- <div class="navigation" id="top">
- <div class="tabs">
- <ul>
- <li><a href="main.html"><span>Main Page</span></a></li>
- <li><a href="annotated.html"><span>Classes</span></a></li>
- <li class="current"><a href="files.html"><span>Files</span></a></li>
- </ul>
- </div>
- <div class="tabs">
- <ul>
- <li><a href="files.html"><span>File List</span></a></li>
- </ul>
- </div>
- <h1>C:/Programming/Personal/OreWar/OreWar/Gorilla.h</h1><div class="fragment"><pre class="fragment"><a name="l00001"></a>00001 <span class="comment">/*</span>
- <a name="l00002"></a>00002 <span class="comment"> Gorilla</span>
- <a name="l00003"></a>00003 <span class="comment"> -------</span>
- <a name="l00004"></a>00004 <span class="comment"> </span>
- <a name="l00005"></a>00005 <span class="comment"> Copyright (c) 2010 Robin Southern</span>
- <a name="l00006"></a>00006 <span class="comment"></span>
- <a name="l00007"></a>00007 <span class="comment"> Additional contributions by:</span>
- <a name="l00008"></a>00008 <span class="comment"></span>
- <a name="l00009"></a>00009 <span class="comment"> - Murat Sari</span>
- <a name="l00010"></a>00010 <span class="comment"> - Nigel Atkinson</span>
- <a name="l00011"></a>00011 <span class="comment"> </span>
- <a name="l00012"></a>00012 <span class="comment"> Permission is hereby granted, free of charge, to any person obtaining a copy</span>
- <a name="l00013"></a>00013 <span class="comment"> of this software and associated documentation files (the "Software"), to deal</span>
- <a name="l00014"></a>00014 <span class="comment"> in the Software without restriction, including without limitation the rights</span>
- <a name="l00015"></a>00015 <span class="comment"> to use, copy, modify, merge, publish, distribute, sublicense, and/or sell</span>
- <a name="l00016"></a>00016 <span class="comment"> copies of the Software, and to permit persons to whom the Software is</span>
- <a name="l00017"></a>00017 <span class="comment"> furnished to do so, subject to the following conditions:</span>
- <a name="l00018"></a>00018 <span class="comment"> </span>
- <a name="l00019"></a>00019 <span class="comment"> The above copyright notice and this permission notice shall be included in</span>
- <a name="l00020"></a>00020 <span class="comment"> all copies or substantial portions of the Software.</span>
- <a name="l00021"></a>00021 <span class="comment"> </span>
- <a name="l00022"></a>00022 <span class="comment"> THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR</span>
- <a name="l00023"></a>00023 <span class="comment"> IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,</span>
- <a name="l00024"></a>00024 <span class="comment"> FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE</span>
- <a name="l00025"></a>00025 <span class="comment"> AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER</span>
- <a name="l00026"></a>00026 <span class="comment"> LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,</span>
- <a name="l00027"></a>00027 <span class="comment"> OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN</span>
- <a name="l00028"></a>00028 <span class="comment"> THE SOFTWARE. </span>
- <a name="l00029"></a>00029 <span class="comment"> </span>
- <a name="l00030"></a>00030 <span class="comment">*/</span>
- <a name="l00031"></a>00031
- <a name="l00032"></a>00032 <span class="preprocessor">#ifndef GORILLA_H</span>
- <a name="l00033"></a>00033 <span class="preprocessor"></span><span class="preprocessor">#define GORILLA_H</span>
- <a name="l00034"></a>00034 <span class="preprocessor"></span>
- <a name="l00035"></a>00035 <span class="preprocessor">#include "Ogre.h"</span>
- <a name="l00036"></a>00036
- <a name="l00037"></a>00037 <span class="preprocessor">#ifndef GORILLA_USES_EXCEPTIONS</span>
- <a name="l00038"></a>00038 <span class="preprocessor"></span><span class="preprocessor"># define GORILLA_USES_EXCEPTIONS 0</span>
- <a name="l00039"></a>00039 <span class="preprocessor"></span><span class="preprocessor">#endif</span>
- <a name="l00040"></a>00040 <span class="preprocessor"></span>
- <a name="l00041"></a>00041 <span class="preprocessor">#if OGRE_COMP == OGRE_COMPILER_GNUC</span>
- <a name="l00042"></a>00042 <span class="preprocessor"></span><span class="preprocessor"># define __FUNC__ __PRETTY_FUNCTION__</span>
- <a name="l00043"></a>00043 <span class="preprocessor"></span><span class="preprocessor">#elif OGRE_COMP != OGRE_COMPILER_BORL</span>
- <a name="l00044"></a>00044 <span class="preprocessor"></span><span class="preprocessor"># define __FUNC__ "No function name info"</span>
- <a name="l00045"></a>00045 <span class="preprocessor"></span><span class="preprocessor">#endif</span>
- <a name="l00046"></a>00046 <span class="preprocessor"></span>
- <a name="l00047"></a>00047 <span class="keyword">namespace </span>Gorilla
- <a name="l00048"></a>00048 {
- <a name="l00049"></a>00049
- <a name="l00050"></a>00050 <span class="keyword">class </span>Silverback;
- <a name="l00051"></a>00051 <span class="keyword">class </span>TextureAtlas;
- <a name="l00052"></a>00052 <span class="keyword">class </span>LayerContainer;
- <a name="l00053"></a>00053 <span class="keyword">class </span>Screen;
- <a name="l00054"></a>00054 <span class="keyword">class </span>ScreenRenderable;
- <a name="l00055"></a>00055 <span class="keyword">class </span>Layer;
- <a name="l00056"></a>00056 <span class="keyword">class </span>Rectangle;
- <a name="l00057"></a>00057 <span class="keyword">class </span>Polygon;
- <a name="l00058"></a>00058 <span class="keyword">class </span>LineList;
- <a name="l00059"></a>00059 <span class="keyword">class </span>QuadList;
- <a name="l00060"></a>00060 <span class="keyword">class </span>Caption;
- <a name="l00061"></a>00061 <span class="keyword">class </span>MarkupText;
- <a name="l00062"></a>00062
- <a name="l00063"></a><a class="code" href="struct_gorilla_1_1_vector_type.html">00063</a> <span class="keyword">template</span><<span class="keyword">typename</span> T> <span class="keyword">struct </span><a class="code" href="struct_gorilla_1_1_vector_type.html">VectorType</a>
- <a name="l00064"></a>00064 {
- <a name="l00065"></a>00065 <span class="preprocessor">#if OGRE_VERSION <= 67077 // If the version is less than or equal to 1.6.5</span>
- <a name="l00066"></a>00066 <span class="preprocessor"></span> <span class="keyword">typedef</span> std::vector<T> type;
- <a name="l00067"></a>00067 <span class="preprocessor">#else</span>
- <a name="l00068"></a>00068 <span class="preprocessor"></span> <span class="keyword">typedef</span> <span class="keyword">typename</span> Ogre::vector<T>::type type;
- <a name="l00069"></a>00069 <span class="preprocessor">#endif</span>
- <a name="l00070"></a>00070 <span class="preprocessor"></span> };
- <a name="l00071"></a>00071
- <a name="l00072"></a>00072 <span class="keyword">namespace </span>Colours
- <a name="l00073"></a>00073 {
- <a name="l00074"></a>00074 <span class="keyword">enum</span> Colour
- <a name="l00075"></a>00075 {
- <a name="l00076"></a>00076 None = 0, <span class="comment">// No Colour.</span>
- <a name="l00077"></a>00077 AliceBlue=0xf0f8ff, Gainsboro=0xdcdcdc, MistyRose=0xffe4e1,
- <a name="l00078"></a>00078 AntiqueWhite=0xfaebd7, GhostWhite=0xf8f8ff, Moccasin=0xffe4b5,
- <a name="l00079"></a>00079 Aqua=0x00ffff, Gold=0xffd700, NavajoWhite=0xffdead,
- <a name="l00080"></a>00080 Aquamarine=0x7fffd4, Goldenrod=0xdaa520, Navy=0x000080,
- <a name="l00081"></a>00081 Azure=0xf0ffff, Gray=0x808080, OldLace=0xfdf5e6,
- <a name="l00082"></a>00082 Beige=0xf5f5dc, Green=0x008000, Olive=0x808000,
- <a name="l00083"></a>00083 Bisque=0xffe4c4, GreenYellow=0xadff2f, OliveDrab=0x6b8e23,
- <a name="l00084"></a>00084 Black=0x000000, Grey=0x808080, Orange=0xffa500,
- <a name="l00085"></a>00085 BlanchedAlmond=0xffebcd, Honeydew=0xf0fff0, OrangeRed=0xff4500,
- <a name="l00086"></a>00086 Blue=0x0000ff, HotPink=0xff69b4, Orchid=0xda70d6,
- <a name="l00087"></a>00087 BlueViolet=0x8a2be2, IndianRed=0xcd5c5c, PaleGoldenrod=0xeee8aa,
- <a name="l00088"></a>00088 Brown=0xa52a2a, Indigo=0x4b0082, PaleGreen=0x98fb98,
- <a name="l00089"></a>00089 Burlywood=0xdeb887, Ivory=0xfffff0, PaleTurquoise=0xafeeee,
- <a name="l00090"></a>00090 CadetBlue=0x5f9ea0, Khaki=0xf0e68c, PaleVioletRed=0xdb7093,
- <a name="l00091"></a>00091 Chartreuse=0x7fff00, Lavender=0xe6e6fa, PapayaWhip=0xffefd5,
- <a name="l00092"></a>00092 Chocolate=0xd2691e, LavenderBlush=0xfff0f5, PeachPuff=0xffdab9,
- <a name="l00093"></a>00093 Coral=0xff7f50, LawnGreen=0x7cfc00, Peru=0xcd853f,
- <a name="l00094"></a>00094 CornflowerBlue=0x6495ed, LemonChiffon=0xfffacd, Pink=0xffc0cb,
- <a name="l00095"></a>00095 Cornsilk=0xfff8dc, LightBlue=0xadd8e6, Plum=0xdda0dd,
- <a name="l00096"></a>00096 Crimson=0xdc143c, LightCoral=0xf08080, PowderBlue=0xb0e0e6,
- <a name="l00097"></a>00097 Cyan=0x00ffff, LightCyan=0xe0ffff, Purple=0x800080,
- <a name="l00098"></a>00098 DarkBlue=0x00008b, LightGoldenrodyellow=0xfafad2, Red=0xff0000,
- <a name="l00099"></a>00099 DarkCyan=0x008b8b, LightGray=0xd3d3d3, RosyBrown=0xbc8f8f,
- <a name="l00100"></a>00100 DarkGoldenrod=0xb8860b, LightGreen=0x90ee90, RoyalBlue=0x4169e1,
- <a name="l00101"></a>00101 DarkGray=0xa9a9a9, LightGrey=0xd3d3d3, SaddleBrown=0x8b4513,
- <a name="l00102"></a>00102 DarkGreen=0x006400, LightPink=0xffb6c1, Salmon=0xfa8072,
- <a name="l00103"></a>00103 DarkGrey=0xa9a9a9, LightSalmon=0xffa07a, SandyBrown=0xf4a460,
- <a name="l00104"></a>00104 DarkKhaki=0xbdb76b, LightSeagreen=0x20b2aa, SeaGreen=0x2e8b57,
- <a name="l00105"></a>00105 DarkMagenta=0x8b008b, LightSkyblue=0x87cefa, SeaShell=0xfff5ee,
- <a name="l00106"></a>00106 DarkOlivegreen=0x556b2f, LightSlategray=0x778899, Sienna=0xa0522d,
- <a name="l00107"></a>00107 DarkOrange=0xff8c00, LightSlategrey=0x778899, Silver=0xc0c0c0,
- <a name="l00108"></a>00108 DarkOrchid=0x9932cc, LightSteelblue=0xb0c4de, SkyBlue=0x87ceeb,
- <a name="l00109"></a>00109 DarkRed=0x8b0000, LightYellow=0xffffe0, SlateBlue=0x6a5acd,
- <a name="l00110"></a>00110 DarkSalmon=0xe9967a, Lime=0x00ff00, SlateGray=0x708090,
- <a name="l00111"></a>00111 DarkSeagreen=0x8fbc8f, LimeGreen=0x32cd32, SlateGrey=0x708090,
- <a name="l00112"></a>00112 DarkSlateblue=0x483d8b, Linen=0xfaf0e6, Snow=0xfffafa,
- <a name="l00113"></a>00113 DarkSlategray=0x2f4f4f, Magenta=0xff00ff, SpringGreen=0x00ff7f,
- <a name="l00114"></a>00114 DarkSlategrey=0x2f4f4f, Maroon=0x800000, SteelBlue=0x4682b4,
- <a name="l00115"></a>00115 DarkTurquoise=0x00ced1, MediumAquamarine=0x66cdaa, Tan=0xd2b48c,
- <a name="l00116"></a>00116 DarkViolet=0x9400d3, MediumBlue=0x0000cd, Teal=0x008080,
- <a name="l00117"></a>00117 DeepPink=0xff1493, MediumOrchid=0xba55d3, Thistle=0xd8bfd8,
- <a name="l00118"></a>00118 DeepSkyblue=0x00bfff, MediumPurple=0x9370db, Tomato=0xff6347,
- <a name="l00119"></a>00119 DimGray=0x696969, MediumSeaGreen=0x3cb371, Turquoise=0x40e0d0,
- <a name="l00120"></a>00120 DimGrey=0x696969, MediumSlateBlue=0x7b68ee, Violet=0xee82ee,
- <a name="l00121"></a>00121 DodgerBlue=0x1e90ff, MediumSpringGreen=0x00fa9a, Wheat=0xf5deb3,
- <a name="l00122"></a>00122 FireBrick=0xb22222, MediumTurquoise=0x48d1cc, White=0xffffff,
- <a name="l00123"></a>00123 FloralWhite=0xfffaf0, MediumBioletRed=0xc71585, WhiteSmoke=0xf5f5f5,
- <a name="l00124"></a>00124 ForestGreen=0x228b22, MidnightBlue=0x191970, Yellow=0xffff00,
- <a name="l00125"></a>00125 Fuchsia=0xff00ff, MintCream=0xf5fffa, YellowGreen=0x9acd32
- <a name="l00126"></a>00126 }; <span class="comment">// Colour</span>
- <a name="l00127"></a>00127 } <span class="comment">// namespace Colours</span>
- <a name="l00128"></a>00128 <span class="comment"></span>
- <a name="l00129"></a>00129 <span class="comment"> /*! function. rgb</span>
- <a name="l00130"></a>00130 <span class="comment"> desc.</span>
- <a name="l00131"></a>00131 <span class="comment"> Convert three/four RGBA values into an Ogre::ColourValue</span>
- <a name="l00132"></a>00132 <span class="comment"> */</span>
- <a name="l00133"></a>00133 Ogre::ColourValue rgb(Ogre::uchar r, Ogre::uchar g, Ogre::uchar b, Ogre::uchar a = 255);
- <a name="l00134"></a>00134 <span class="comment"></span>
- <a name="l00135"></a>00135 <span class="comment"> /*! function. webcolour</span>
- <a name="l00136"></a>00136 <span class="comment"> desc.</span>
- <a name="l00137"></a>00137 <span class="comment"> Turn a webcolour from the Gorilla::Colours::Colour enum into an Ogre::ColourValue</span>
- <a name="l00138"></a>00138 <span class="comment"> */</span>
- <a name="l00139"></a>00139 Ogre::ColourValue webcolour(Colours::Colour, Ogre::Real alpha = 1.0);
- <a name="l00140"></a>00140 <span class="comment"></span>
- <a name="l00141"></a>00141 <span class="comment"> /*! enum. Gradient</span>
- <a name="l00142"></a>00142 <span class="comment"> desc.</span>
- <a name="l00143"></a>00143 <span class="comment"> Directions for background gradients</span>
- <a name="l00144"></a>00144 <span class="comment"> */</span>
- <a name="l00145"></a>00145 <span class="keyword">enum</span> Gradient
- <a name="l00146"></a>00146 {
- <a name="l00147"></a>00147 Gradient_NorthSouth,
- <a name="l00148"></a>00148 Gradient_WestEast,
- <a name="l00149"></a>00149 Gradient_Diagonal
- <a name="l00150"></a>00150 };
- <a name="l00151"></a>00151 <span class="comment"></span>
- <a name="l00152"></a>00152 <span class="comment"> /*! enum. Border</span>
- <a name="l00153"></a>00153 <span class="comment"> desc.</span>
- <a name="l00154"></a>00154 <span class="comment"> Border Directions</span>
- <a name="l00155"></a>00155 <span class="comment"> </span>
- <a name="l00156"></a>00156 <span class="comment"> </span>
- <a name="l00157"></a>00157 <span class="comment"> +---------------------+</span>
- <a name="l00158"></a>00158 <span class="comment"> |\ NORTH /|</span>
- <a name="l00159"></a>00159 <span class="comment"> | \ / |</span>
- <a name="l00160"></a>00160 <span class="comment"> | +---------------+ |</span>
- <a name="l00161"></a>00161 <span class="comment"> | | | |</span>
- <a name="l00162"></a>00162 <span class="comment"> | W| |E |</span>
- <a name="l00163"></a>00163 <span class="comment"> | E| |A |</span>
- <a name="l00164"></a>00164 <span class="comment"> | S| |S |</span>
- <a name="l00165"></a>00165 <span class="comment"> | T| |T |</span>
- <a name="l00166"></a>00166 <span class="comment"> | | | |</span>
- <a name="l00167"></a>00167 <span class="comment"> | +---------------+ |</span>
- <a name="l00168"></a>00168 <span class="comment"> | / SOUTH \ |</span>
- <a name="l00169"></a>00169 <span class="comment"> |/ \|</span>
- <a name="l00170"></a>00170 <span class="comment"> +---------------------+</span>
- <a name="l00171"></a>00171 <span class="comment"> */</span>
- <a name="l00172"></a>00172 <span class="keyword">enum</span> Border
- <a name="l00173"></a>00173 {
- <a name="l00174"></a>00174 Border_North = 0,
- <a name="l00175"></a>00175 Border_South = 1,
- <a name="l00176"></a>00176 Border_East = 2,
- <a name="l00177"></a>00177 Border_West = 3
- <a name="l00178"></a>00178 };
- <a name="l00179"></a>00179 <span class="comment"></span>
- <a name="l00180"></a>00180 <span class="comment"> /*! enum. QuadCorner</span>
- <a name="l00181"></a>00181 <span class="comment"> desc.</span>
- <a name="l00182"></a>00182 <span class="comment"> Names of each corner/vertex of a Quad</span>
- <a name="l00183"></a>00183 <span class="comment"> */</span>
- <a name="l00184"></a>00184 <span class="keyword">enum</span> QuadCorner
- <a name="l00185"></a>00185 {
- <a name="l00186"></a>00186 TopLeft = 0,
- <a name="l00187"></a>00187 TopRight = 1,
- <a name="l00188"></a>00188 BottomRight = 2,
- <a name="l00189"></a>00189 BottomLeft = 3
- <a name="l00190"></a>00190 };
- <a name="l00191"></a>00191 <span class="comment"></span>
- <a name="l00192"></a>00192 <span class="comment"> /*! enum. TextAlignment</span>
- <a name="l00193"></a>00193 <span class="comment"> desc.</span>
- <a name="l00194"></a>00194 <span class="comment"> Horizontal text alignment for captions.</span>
- <a name="l00195"></a>00195 <span class="comment"> */</span>
- <a name="l00196"></a>00196 <span class="keyword">enum</span> TextAlignment
- <a name="l00197"></a>00197 {
- <a name="l00198"></a>00198 TextAlign_Left, <span class="comment">// Place the text to where left is (X = left)</span>
- <a name="l00199"></a>00199 TextAlign_Right, <span class="comment">// Place the text to the right of left (X = left - text_width)</span>
- <a name="l00200"></a>00200 TextAlign_Centre, <span class="comment">// Place the text centered at left (X = left - (text_width / 2 ) )</span>
- <a name="l00201"></a>00201 };
- <a name="l00202"></a>00202 <span class="comment"></span>
- <a name="l00203"></a>00203 <span class="comment"> /*! enum. VerticalAlignment</span>
- <a name="l00204"></a>00204 <span class="comment"> desc.</span>
- <a name="l00205"></a>00205 <span class="comment"> Vertical text alignment for captions.</span>
- <a name="l00206"></a>00206 <span class="comment"> */</span>
- <a name="l00207"></a>00207 <span class="keyword">enum</span> VerticalAlignment
- <a name="l00208"></a>00208 {
- <a name="l00209"></a>00209 VerticalAlign_Top,
- <a name="l00210"></a>00210 VerticalAlign_Middle,
- <a name="l00211"></a>00211 VerticalAlign_Bottom
- <a name="l00212"></a>00212 };
- <a name="l00213"></a>00213 <span class="comment"></span>
- <a name="l00214"></a>00214 <span class="comment"> /*! enum. buffer<T></span>
- <a name="l00215"></a>00215 <span class="comment"> desc.</span>
- <a name="l00216"></a>00216 <span class="comment"> Internal container class that is similar to std::vector</span>
- <a name="l00217"></a>00217 <span class="comment"> */</span>
- <a name="l00218"></a><a class="code" href="class_gorilla_1_1buffer.html">00218</a> <span class="keyword">template</span><<span class="keyword">typename</span> T> <span class="keyword">class </span><a class="code" href="class_gorilla_1_1buffer.html">buffer</a>
- <a name="l00219"></a>00219 {
- <a name="l00220"></a>00220
- <a name="l00221"></a>00221 <span class="keyword">public</span>:
- <a name="l00222"></a>00222
- <a name="l00223"></a>00223 <span class="keyword">inline</span> <a class="code" href="class_gorilla_1_1buffer.html">buffer</a>() : mBuffer(0), mUsed(0), mCapacity(0)
- <a name="l00224"></a>00224 { <span class="comment">// no code.</span>
- <a name="l00225"></a>00225 }
- <a name="l00226"></a>00226
- <a name="l00227"></a>00227 <span class="keyword">inline</span> ~<a class="code" href="class_gorilla_1_1buffer.html">buffer</a>()
- <a name="l00228"></a>00228 {
- <a name="l00229"></a>00229 <span class="keywordflow">if</span> (mBuffer && mCapacity)
- <a name="l00230"></a>00230 OGRE_FREE(mBuffer, Ogre::MEMCATEGORY_GEOMETRY);
- <a name="l00231"></a>00231 }
- <a name="l00232"></a>00232
- <a name="l00233"></a>00233 <span class="keyword">inline</span> <span class="keywordtype">size_t</span> size()<span class="keyword"> const</span>
- <a name="l00234"></a>00234 <span class="keyword"> </span>{
- <a name="l00235"></a>00235 <span class="keywordflow">return</span> mUsed;
- <a name="l00236"></a>00236 }
- <a name="l00237"></a>00237
- <a name="l00238"></a>00238 <span class="keyword">inline</span> <span class="keywordtype">size_t</span> capacity()<span class="keyword"> const</span>
- <a name="l00239"></a>00239 <span class="keyword"> </span>{
- <a name="l00240"></a>00240 <span class="keywordflow">return</span> mCapacity;
- <a name="l00241"></a>00241 }
- <a name="l00242"></a>00242
- <a name="l00243"></a>00243 <span class="keyword">inline</span> T& operator[](<span class="keywordtype">size_t</span> index)
- <a name="l00244"></a>00244 {
- <a name="l00245"></a>00245 <span class="keywordflow">return</span> *(mBuffer + index);
- <a name="l00246"></a>00246 }
- <a name="l00247"></a>00247
- <a name="l00248"></a>00248 <span class="keyword">inline</span> <span class="keyword">const</span> T& operator[](<span class="keywordtype">size_t</span> index)<span class="keyword"> const</span>
- <a name="l00249"></a>00249 <span class="keyword"> </span>{
- <a name="l00250"></a>00250 <span class="keywordflow">return</span> *(mBuffer + index);
- <a name="l00251"></a>00251 }
- <a name="l00252"></a>00252
- <a name="l00253"></a>00253 <span class="keyword">inline</span> T& at(<span class="keywordtype">size_t</span> index)
- <a name="l00254"></a>00254 {
- <a name="l00255"></a>00255 <span class="keywordflow">return</span> *(mBuffer + index);
- <a name="l00256"></a>00256 }
- <a name="l00257"></a>00257
- <a name="l00258"></a>00258 <span class="keyword">inline</span> <span class="keyword">const</span> T& at(<span class="keywordtype">size_t</span> index)<span class="keyword"> const</span>
- <a name="l00259"></a>00259 <span class="keyword"> </span>{
- <a name="l00260"></a>00260 <span class="keywordflow">return</span> *(mBuffer + index);
- <a name="l00261"></a>00261 }
- <a name="l00262"></a>00262
- <a name="l00263"></a>00263 <span class="keyword">inline</span> <span class="keywordtype">void</span> remove_all()
- <a name="l00264"></a>00264 {
- <a name="l00265"></a>00265 mUsed = 0;
- <a name="l00266"></a>00266 }
- <a name="l00267"></a>00267
- <a name="l00268"></a>00268 <span class="keyword">inline</span> <span class="keywordtype">void</span> resize(<span class="keywordtype">size_t</span> new_capacity)
- <a name="l00269"></a>00269 {
- <a name="l00270"></a>00270 T* new_buffer = (T*) OGRE_MALLOC(<span class="keyword">sizeof</span>(T) * new_capacity, Ogre::MEMCATEGORY_GEOMETRY);
- <a name="l00271"></a>00271
- <a name="l00272"></a>00272 <span class="keywordflow">if</span> (mUsed != 0)
- <a name="l00273"></a>00273 {
- <a name="l00274"></a>00274 <span class="keywordflow">if</span> (mUsed < new_capacity) <span class="comment">// Copy all</span>
- <a name="l00275"></a>00275 std::copy(mBuffer, mBuffer + mUsed, new_buffer);
- <a name="l00276"></a>00276 <span class="keywordflow">else</span> <span class="keywordflow">if</span> (mUsed >= new_capacity) <span class="comment">// Copy some</span>
- <a name="l00277"></a>00277 std::copy(mBuffer, mBuffer + new_capacity, new_buffer);
- <a name="l00278"></a>00278 }
- <a name="l00279"></a>00279
- <a name="l00280"></a>00280 OGRE_FREE(mBuffer, Ogre::MEMCATEGORY_GEOMETRY);
- <a name="l00281"></a>00281 mCapacity = new_capacity;
- <a name="l00282"></a>00282 mBuffer = new_buffer;
- <a name="l00283"></a>00283 }
- <a name="l00284"></a>00284
- <a name="l00285"></a>00285 <span class="keyword">inline</span> <span class="keywordtype">void</span> push_back(<span class="keyword">const</span> T& value)
- <a name="l00286"></a>00286 {
- <a name="l00287"></a>00287 <span class="keywordflow">if</span> (mUsed == mCapacity)
- <a name="l00288"></a>00288 resize(mUsed == 0 ? 1 : mUsed * 2);
- <a name="l00289"></a>00289 *(mBuffer + mUsed) = value;
- <a name="l00290"></a>00290 mUsed++;
- <a name="l00291"></a>00291 }
- <a name="l00292"></a>00292
- <a name="l00293"></a>00293 <span class="keyword">inline</span> <span class="keywordtype">void</span> pop_back()
- <a name="l00294"></a>00294 {
- <a name="l00295"></a>00295 <span class="keywordflow">if</span> (mUsed != 0)
- <a name="l00296"></a>00296 mUsed--;
- <a name="l00297"></a>00297 }
- <a name="l00298"></a>00298
- <a name="l00299"></a>00299 <span class="keyword">inline</span> <span class="keywordtype">void</span> erase(<span class="keywordtype">size_t</span> index)
- <a name="l00300"></a>00300 {
- <a name="l00301"></a>00301 *(mBuffer + index) = *(mBuffer + mUsed - 1);
- <a name="l00302"></a>00302 mUsed--;
- <a name="l00303"></a>00303 }
- <a name="l00304"></a>00304
- <a name="l00305"></a>00305 <span class="keyword">inline</span> T* first()
- <a name="l00306"></a>00306 {
- <a name="l00307"></a>00307 <span class="keywordflow">return</span> mBuffer;
- <a name="l00308"></a>00308 }
- <a name="l00309"></a>00309
- <a name="l00310"></a>00310 <span class="keyword">inline</span> T* last()
- <a name="l00311"></a>00311 {
- <a name="l00312"></a>00312 <span class="keywordflow">return</span> mBuffer + mUsed;
- <a name="l00313"></a>00313 }
- <a name="l00314"></a>00314
- <a name="l00315"></a>00315 <span class="keyword">protected</span>:
- <a name="l00316"></a>00316
- <a name="l00317"></a>00317 T* mBuffer;
- <a name="l00318"></a>00318 <span class="keywordtype">size_t</span> mUsed, mCapacity;
- <a name="l00319"></a>00319 };
- <a name="l00320"></a>00320 <span class="comment"></span>
- <a name="l00321"></a>00321 <span class="comment"> /*! struct. Vertex</span>
- <a name="l00322"></a>00322 <span class="comment"> desc.</span>
- <a name="l00323"></a>00323 <span class="comment"> Structure for a single vertex.</span>
- <a name="l00324"></a>00324 <span class="comment"> */</span>
- <a name="l00325"></a><a class="code" href="struct_gorilla_1_1_vertex.html">00325</a> <span class="keyword">struct </span><a class="code" href="struct_gorilla_1_1_vertex.html">Vertex</a>
- <a name="l00326"></a>00326 {
- <a name="l00327"></a>00327 Ogre::Vector3 position;
- <a name="l00328"></a>00328 Ogre::ColourValue colour;
- <a name="l00329"></a>00329 Ogre::Vector2 uv;
- <a name="l00330"></a>00330 };
- <a name="l00331"></a>00331 <span class="comment"></span>
- <a name="l00332"></a>00332 <span class="comment"> /*! struct. Kerning</span>
- <a name="l00333"></a>00333 <span class="comment"> desc.</span>
- <a name="l00334"></a>00334 <span class="comment"> Distances between two characters next to each other.</span>
- <a name="l00335"></a>00335 <span class="comment"> */</span>
- <a name="l00336"></a><a class="code" href="struct_gorilla_1_1_kerning.html">00336</a> <span class="keyword">struct </span><a class="code" href="struct_gorilla_1_1_kerning.html">Kerning</a>
- <a name="l00337"></a>00337 {
- <a name="l00338"></a>00338 <a class="code" href="struct_gorilla_1_1_kerning.html">Kerning</a>(Ogre::uint c, Ogre::Real k) : character(c), kerning(k) {}
- <a name="l00339"></a>00339 Ogre::uint character;
- <a name="l00340"></a>00340 Ogre::Real kerning;
- <a name="l00341"></a>00341 };
- <a name="l00342"></a>00342 <span class="comment"></span>
- <a name="l00343"></a>00343 <span class="comment"> /*! struct. Glyph</span>
- <a name="l00344"></a>00344 <span class="comment"> desc.</span>
- <a name="l00345"></a>00345 <span class="comment"> Texture and size information about a single character loaded from a TextureAtlas.</span>
- <a name="l00346"></a>00346 <span class="comment"> */</span>
- <a name="l00347"></a><a class="code" href="class_gorilla_1_1_glyph.html">00347</a> <span class="keyword">class </span><a class="code" href="class_gorilla_1_1_glyph.html">Glyph</a> : <span class="keyword">public</span> Ogre::GeneralAllocatedObject
- <a name="l00348"></a>00348 {
- <a name="l00349"></a>00349
- <a name="l00350"></a>00350 <span class="keyword">public</span>:
- <a name="l00351"></a>00351
- <a name="l00352"></a>00352 <a class="code" href="class_gorilla_1_1_glyph.html">Glyph</a>() : uvTop(0), uvBottom(0), uvWidth(0), uvHeight(0), uvLeft(0), uvRight(0), glyphWidth(0), glyphHeight(0), glyphAdvance(0), verticalOffset(0) {}
- <a name="l00353"></a>00353
- <a name="l00354"></a>00354 ~<a class="code" href="class_gorilla_1_1_glyph.html">Glyph</a>() {}
- <a name="l00355"></a>00355
- <a name="l00356"></a>00356 Ogre::Vector2 texCoords[4];
- <a name="l00357"></a>00357 Ogre::Real uvTop, uvBottom, uvWidth, uvHeight, uvLeft, uvRight,
- <a name="l00358"></a>00358 glyphWidth, glyphHeight, glyphAdvance, verticalOffset;
- <a name="l00359"></a>00359 <a class="code" href="class_gorilla_1_1buffer.html">buffer<Kerning></a> kerning;
- <a name="l00360"></a>00360
- <a name="l00361"></a>00361 <span class="comment">// Get kerning value of a character to the right of another.</span>
- <a name="l00362"></a>00362 <span class="comment">// Ab -- get the kerning value of b, pass on A.</span>
- <a name="l00363"></a>00363 <span class="keyword">inline</span> <span class="keyword">const</span> Ogre::Real getKerning(<span class="keywordtype">char</span> left_of)<span class="keyword"> const</span>
- <a name="l00364"></a>00364 <span class="keyword"> </span>{
- <a name="l00365"></a>00365 <span class="keywordflow">if</span> (kerning.size() == 0)
- <a name="l00366"></a>00366 <span class="keywordflow">return</span> 0;
- <a name="l00367"></a>00367 <span class="keywordflow">for</span> (<span class="keywordtype">size_t</span> i=0;i < kerning.size();i++)
- <a name="l00368"></a>00368 {
- <a name="l00369"></a>00369 <span class="keywordflow">if</span> (kerning[i].character == left_of)
- <a name="l00370"></a>00370 <span class="keywordflow">return</span> kerning[i].kerning;
- <a name="l00371"></a>00371 }
- <a name="l00372"></a>00372 <span class="keywordflow">return</span> 0;
- <a name="l00373"></a>00373 }
- <a name="l00374"></a>00374
- <a name="l00375"></a>00375 };
- <a name="l00376"></a>00376 <span class="comment"></span>
- <a name="l00377"></a>00377 <span class="comment"> /*! class. Sprite</span>
- <a name="l00378"></a>00378 <span class="comment"> desc.</span>
- <a name="l00379"></a>00379 <span class="comment"> Portions of a texture from a TextureAtlas.</span>
- <a name="l00380"></a>00380 <span class="comment"> */</span>
- <a name="l00381"></a><a class="code" href="class_gorilla_1_1_sprite.html">00381</a> <span class="keyword">class </span><a class="code" href="class_gorilla_1_1_sprite.html">Sprite</a> : <span class="keyword">public</span> Ogre::GeneralAllocatedObject
- <a name="l00382"></a>00382 {
- <a name="l00383"></a>00383
- <a name="l00384"></a>00384 <span class="keyword">public</span>:
- <a name="l00385"></a>00385
- <a name="l00386"></a>00386 <a class="code" href="class_gorilla_1_1_sprite.html">Sprite</a>() {}
- <a name="l00387"></a>00387
- <a name="l00388"></a>00388 ~<a class="code" href="class_gorilla_1_1_sprite.html">Sprite</a>() {}
- <a name="l00389"></a>00389
- <a name="l00390"></a>00390 Ogre::Real uvTop, uvLeft, uvRight, uvBottom, spriteWidth, spriteHeight;
- <a name="l00391"></a>00391 Ogre::Vector2 texCoords[4];
- <a name="l00392"></a>00392
- <a name="l00393"></a>00393 };
- <a name="l00394"></a>00394
- <a name="l00395"></a>00395 <span class="comment">/* class. Silverback</span>
- <a name="l00396"></a>00396 <span class="comment"> desc.</span>
- <a name="l00397"></a>00397 <span class="comment"> Main singleton class for Gorilla</span>
- <a name="l00398"></a>00398 <span class="comment"> */</span>
- <a name="l00399"></a><a class="code" href="class_gorilla_1_1_silverback.html">00399</a> <span class="keyword">class </span><a class="code" href="class_gorilla_1_1_silverback.html">Silverback</a> : <span class="keyword">public</span> Ogre::Singleton<Silverback>, <span class="keyword">public</span> Ogre::GeneralAllocatedObject, <span class="keyword">public</span> Ogre::FrameListener
- <a name="l00400"></a>00400 {
- <a name="l00401"></a>00401
- <a name="l00402"></a>00402 <span class="keyword">public</span>:
- <a name="l00403"></a>00403 <span class="comment"></span>
- <a name="l00404"></a>00404 <span class="comment"> /*! constructor. Silverback</span>
- <a name="l00405"></a>00405 <span class="comment"> desc.</span>
- <a name="l00406"></a>00406 <span class="comment"> Silverback constructor.</span>
- <a name="l00407"></a>00407 <span class="comment"> */</span>
- <a name="l00408"></a>00408 <a class="code" href="class_gorilla_1_1_silverback.html#aed881ea7ac9874db9539922ece58632f">Silverback</a>();
- <a name="l00409"></a>00409 <span class="comment"></span>
- <a name="l00410"></a>00410 <span class="comment"> /*! destructor. Silverback</span>
- <a name="l00411"></a>00411 <span class="comment"> desc.</span>
- <a name="l00412"></a>00412 <span class="comment"> Silverback destructor.</span>
- <a name="l00413"></a>00413 <span class="comment"> */</span>
- <a name="l00414"></a>00414 <a class="code" href="class_gorilla_1_1_silverback.html#ab1596997b9b9c384f52395fb0b3324c6">~Silverback</a>();
- <a name="l00415"></a>00415 <span class="comment"></span>
- <a name="l00416"></a>00416 <span class="comment"> /*! function. loadAtlas</span>
- <a name="l00417"></a>00417 <span class="comment"> desc.</span>
- <a name="l00418"></a>00418 <span class="comment"> Create a TextureAtlas from a ".gorilla" file. </span>
- <a name="l00419"></a>00419 <span class="comment"> </span>
- <a name="l00420"></a>00420 <span class="comment"> Name is the name of the TextureAtlas, as well as the first part of the filename</span>
- <a name="l00421"></a>00421 <span class="comment"> of the gorilla file; i.e. name.gorilla, the gorilla file can be loaded from a different</span>
- <a name="l00422"></a>00422 <span class="comment"> resource group if you give that name as the second argument, otherwise it will assume </span>
- <a name="l00423"></a>00423 <span class="comment"> to be "General".</span>
- <a name="l00424"></a>00424 <span class="comment"> */</span>
- <a name="l00425"></a>00425 <span class="keywordtype">void</span> <a class="code" href="class_gorilla_1_1_silverback.html#a702ca7f5a82ea99e7467bba54e6aa3e7">loadAtlas</a>(<span class="keyword">const</span> Ogre::String& name, <span class="keyword">const</span> Ogre::String& group = Ogre::ResourceGroupManager::DEFAULT_RESOURCE_GROUP_NAME);
- <a name="l00426"></a>00426 <span class="comment"></span>
- <a name="l00427"></a>00427 <span class="comment"> /*! function. createScreen</span>
- <a name="l00428"></a>00428 <span class="comment"> desc.</span>
- <a name="l00429"></a>00429 <span class="comment"> Create a Screen using a Viewport and a name of a previously loaded TextureAtlas.</span>
- <a name="l00430"></a>00430 <span class="comment"> Both must exist. The screen will register itself as a RenderQueueListener to the</span>
- <a name="l00431"></a>00431 <span class="comment"> SceneManager that has the Camera which is tied to the Viewport.</span>
- <a name="l00432"></a>00432 <span class="comment"> note.</span>
- <a name="l00433"></a>00433 <span class="comment"> Each screen is considered a new batch. To reduce your batch count in Gorilla, </span>
- <a name="l00434"></a>00434 <span class="comment"> reduce the number of screens you use.</span>
- <a name="l00435"></a>00435 <span class="comment"> */</span>
- <a name="l00436"></a>00436 <a class="code" href="class_gorilla_1_1_screen.html">Screen</a>* <a class="code" href="class_gorilla_1_1_silverback.html#aea736c34b584dce837c55d550c11d030">createScreen</a>(Ogre::Viewport*, <span class="keyword">const</span> Ogre::String& atlas);
- <a name="l00437"></a>00437 <span class="comment"></span>
- <a name="l00438"></a>00438 <span class="comment"> /*! function. destroyScreen</span>
- <a name="l00439"></a>00439 <span class="comment"> desc.</span>
- <a name="l00440"></a>00440 <span class="comment"> Destroy an existing screen, its layers and the contents of those layers.</span>
- <a name="l00441"></a>00441 <span class="comment"> */</span>
- <a name="l00442"></a>00442 <span class="keywordtype">void</span> <a class="code" href="class_gorilla_1_1_silverback.html#a212af4606fd8439b8b32a1af6164fbe8">destroyScreen</a>(<a class="code" href="class_gorilla_1_1_screen.html">Screen</a>*);
- <a name="l00443"></a>00443 <span class="comment"></span>
- <a name="l00444"></a>00444 <span class="comment"> /*! function. createScreenRenderable</span>
- <a name="l00445"></a>00445 <span class="comment"> */</span>
- <a name="l00446"></a>00446 <a class="code" href="class_gorilla_1_1_screen_renderable.html">ScreenRenderable</a>* <a class="code" href="class_gorilla_1_1_silverback.html#a644be17e6fd266d21edd1ec959c2baa9">createScreenRenderable</a>(<span class="keyword">const</span> Ogre::Vector2& maxSize, <span class="keyword">const</span> Ogre::String& atlas);
- <a name="l00447"></a>00447 <span class="comment"></span>
- <a name="l00448"></a>00448 <span class="comment"> /*! function. destroyScreen</span>
- <a name="l00449"></a>00449 <span class="comment"> desc.</span>
- <a name="l00450"></a>00450 <span class="comment"> Destroy an existing screen, its layers and the contents of those layers.</span>
- <a name="l00451"></a>00451 <span class="comment"> */</span>
- <a name="l00452"></a>00452 <span class="keywordtype">void</span> <a class="code" href="class_gorilla_1_1_silverback.html#a292cdecbfc3ce8cf5d7b35fda45af855">destroyScreenRenderable</a>(<a class="code" href="class_gorilla_1_1_screen_renderable.html">ScreenRenderable</a>*);
- <a name="l00453"></a>00453 <span class="comment"></span>
- <a name="l00454"></a>00454 <span class="comment"> /*! function. frameStarted</span>
- <a name="l00455"></a>00455 <span class="comment"> desc.</span>
- <a name="l00456"></a>00456 <span class="comment"> Call ScreenRenderable draw</span>
- <a name="l00457"></a>00457 <span class="comment"> */</span>
- <a name="l00458"></a>00458 <span class="keywordtype">bool</span> <a class="code" href="class_gorilla_1_1_silverback.html#a953980f1e28a2b9940c7186b51586b2b">frameStarted</a>(<span class="keyword">const</span> Ogre::FrameEvent& evt);
- <a name="l00459"></a>00459
- <a name="l00460"></a>00460 <span class="keyword">protected</span>:
- <a name="l00461"></a>00461
- <a name="l00462"></a>00462 std::map<Ogre::String, TextureAtlas*> mAtlases;
- <a name="l00463"></a>00463 std::vector<Screen*> mScreens;
- <a name="l00464"></a>00464 std::vector<ScreenRenderable*> mScreenRenderables;
- <a name="l00465"></a>00465
- <a name="l00466"></a>00466 };
- <a name="l00467"></a>00467 <span class="comment"></span>
- <a name="l00468"></a>00468 <span class="comment"> /*! class. GlyphData</span>
- <a name="l00469"></a>00469 <span class="comment"> desc.</span>
- <a name="l00470"></a>00470 <span class="comment"> Collection of glyphs of the same size.</span>
- <a name="l00471"></a>00471 <span class="comment"> */</span>
- <a name="l00472"></a><a class="code" href="class_gorilla_1_1_glyph_data.html">00472</a> <span class="keyword">class </span><a class="code" href="class_gorilla_1_1_glyph_data.html">GlyphData</a> : <span class="keyword">public</span> Ogre::GeneralAllocatedObject
- <a name="l00473"></a>00473 {
- <a name="l00474"></a>00474
- <a name="l00475"></a>00475 <span class="keyword">friend</span> <span class="keyword">class </span><a class="code" href="class_gorilla_1_1_texture_atlas.html">TextureAtlas</a>;
- <a name="l00476"></a>00476
- <a name="l00477"></a>00477 <span class="keyword">public</span>:
- <a name="l00478"></a>00478
- <a name="l00479"></a>00479 <a class="code" href="class_gorilla_1_1_glyph_data.html">GlyphData</a>();
- <a name="l00480"></a>00480
- <a name="l00481"></a>00481 ~<a class="code" href="class_gorilla_1_1_glyph_data.html">GlyphData</a>();
- <a name="l00482"></a>00482 <span class="comment"></span>
- <a name="l00483"></a>00483 <span class="comment"> /*! function. getGlyph</span>
- <a name="l00484"></a>00484 <span class="comment"> desc.</span>
- <a name="l00485"></a>00485 <span class="comment"> Get a glyph (character information) from a specific character.</span>
- <a name="l00486"></a>00486 <span class="comment"> note.</span>
- <a name="l00487"></a>00487 <span class="comment"> If the character doesn't exist then a null pointer is returned.</span>
- <a name="l00488"></a>00488 <span class="comment"> Do not delete the Glyph pointer.</span>
- <a name="l00489"></a>00489 <span class="comment"> */</span>
- <a name="l00490"></a><a class="code" href="class_gorilla_1_1_glyph_data.html#a17fb2c3de5ad1b62e2e3b89b8677cbf9">00490</a> <span class="keyword">inline</span> <a class="code" href="class_gorilla_1_1_glyph.html">Glyph</a>* <a class="code" href="class_gorilla_1_1_glyph_data.html#a17fb2c3de5ad1b62e2e3b89b8677cbf9">getGlyph</a>(Ogre::uint character)<span class="keyword"> const</span>
- <a name="l00491"></a>00491 <span class="keyword"> </span>{
- <a name="l00492"></a>00492 Ogre::uint safe_character = character - mRangeBegin;
- <a name="l00493"></a>00493 <span class="keywordflow">if</span> (safe_character >= 0 && safe_character <= mGlyphs.size())
- <a name="l00494"></a>00494 <span class="keywordflow">return</span> mGlyphs[safe_character];
- <a name="l00495"></a>00495 <span class="keywordflow">return</span> 0;
- <a name="l00496"></a>00496 }
- <a name="l00497"></a>00497
- <a name="l00498"></a>00498 std::vector<Glyph*> mGlyphs;
- <a name="l00499"></a>00499 Ogre::uint mRangeBegin, mRangeEnd;
- <a name="l00500"></a>00500 Ogre::Real mSpaceLength,
- <a name="l00501"></a>00501 mLineHeight,
- <a name="l00502"></a>00502 mBaseline,
- <a name="l00503"></a>00503 mLetterSpacing,
- <a name="l00504"></a>00504 mMonoWidth;
- <a name="l00505"></a>00505
- <a name="l00506"></a>00506 };
- <a name="l00507"></a>00507 <span class="comment"></span>
- <a name="l00508"></a>00508 <span class="comment"> /*! class. TextureAtlas</span>
- <a name="l00509"></a>00509 <span class="comment"> desc.</span>
- <a name="l00510"></a>00510 <span class="comment"> The TextureAtlas file represents a .gorilla file which contains all the needed information that</span>
- <a name="l00511"></a>00511 <span class="comment"> describes the portions of a single texture. Such as Glyph and Sprite information, text kerning,</span>
- <a name="l00512"></a>00512 <span class="comment"> line heights and so on. It isn't typically used by the end-user.</span>
- <a name="l00513"></a>00513 <span class="comment"> */</span>
- <a name="l00514"></a><a class="code" href="class_gorilla_1_1_texture_atlas.html">00514</a> <span class="keyword">class </span><a class="code" href="class_gorilla_1_1_texture_atlas.html">TextureAtlas</a> : <span class="keyword">public</span> Ogre::GeneralAllocatedObject
- <a name="l00515"></a>00515 {
- <a name="l00516"></a>00516
- <a name="l00517"></a>00517 <span class="keyword">friend</span> <span class="keyword">class </span><a class="code" href="class_gorilla_1_1_silverback.html">Silverback</a>;
- <a name="l00518"></a>00518
- <a name="l00519"></a>00519 <span class="keyword">public</span>:
- <a name="l00520"></a>00520
- <a name="l00521"></a>00521 Ogre::MaterialPtr createOrGet2DMasterMaterial();
- <a name="l00522"></a>00522
- <a name="l00523"></a>00523 Ogre::MaterialPtr createOrGet3DMasterMaterial();
- <a name="l00524"></a>00524 <span class="comment"></span>
- <a name="l00525"></a>00525 <span class="comment"> /*! function. getTexture</span>
- <a name="l00526"></a>00526 <span class="comment"> desc.</span>
- <a name="l00527"></a>00527 <span class="comment"> Get the texture assigned to this TextureAtlas</span>
- <a name="l00528"></a>00528 <span class="comment"> */</span>
- <a name="l00529"></a><a class="code" href="class_gorilla_1_1_texture_atlas.html#a7d9490e8e4bbb60c653e1eceb799cf94">00529</a> <span class="keyword">inline</span> Ogre::TexturePtr <a class="code" href="class_gorilla_1_1_texture_atlas.html#a7d9490e8e4bbb60c653e1eceb799cf94">getTexture</a>()<span class="keyword"> const</span>
- <a name="l00530"></a>00530 <span class="keyword"> </span>{
- <a name="l00531"></a>00531 <span class="keywordflow">return</span> mTexture;
- <a name="l00532"></a>00532 }
- <a name="l00533"></a>00533 <span class="comment"></span>
- <a name="l00534"></a>00534 <span class="comment"> /*! function. getMaterial</span>
- <a name="l00535"></a>00535 <span class="comment"> desc.</span>
- <a name="l00536"></a>00536 <span class="comment"> Get the material assigned to this TextureAtlas</span>
- <a name="l00537"></a>00537 <span class="comment"> */</span>
- <a name="l00538"></a><a class="code" href="class_gorilla_1_1_texture_atlas.html#af67234bb5b5b3a9fec1bf368779c62c6">00538</a> <span class="keyword">inline</span> Ogre::MaterialPtr <a class="code" href="class_gorilla_1_1_texture_atlas.html#af67234bb5b5b3a9fec1bf368779c62c6">get2DMaterial</a>()<span class="keyword"> const</span>
- <a name="l00539"></a>00539 <span class="keyword"> </span>{
- <a name="l00540"></a>00540 <span class="keywordflow">return</span> m2DMaterial;
- <a name="l00541"></a>00541 }
- <a name="l00542"></a>00542 <span class="comment"></span>
- <a name="l00543"></a>00543 <span class="comment"> /*! function. getMaterial</span>
- <a name="l00544"></a>00544 <span class="comment"> desc.</span>
- <a name="l00545"></a>00545 <span class="comment"> Get the material assigned to this TextureAtlas</span>
- <a name="l00546"></a>00546 <span class="comment"> */</span>
- <a name="l00547"></a><a class="code" href="class_gorilla_1_1_texture_atlas.html#a68428b96bce8bdfff0aaba16f5d9bd95">00547</a> <span class="keyword">inline</span> Ogre::MaterialPtr <a class="code" href="class_gorilla_1_1_texture_atlas.html#a68428b96bce8bdfff0aaba16f5d9bd95">get3DMaterial</a>()<span class="keyword"> const</span>
- <a name="l00548"></a>00548 <span class="keyword"> </span>{
- <a name="l00549"></a>00549 <span class="keywordflow">return</span> m3DMaterial;
- <a name="l00550"></a>00550 }<span class="comment"></span>
- <a name="l00551"></a>00551 <span class="comment"> /*! function. getMaterialName</span>
- <a name="l00552"></a>00552 <span class="comment"> desc.</span>
- <a name="l00553"></a>00553 <span class="comment"> Get the name of the material assigned to this TextureAtlas</span>
- <a name="l00554"></a>00554 <span class="comment"> */</span>
- <a name="l00555"></a><a class="code" href="class_gorilla_1_1_texture_atlas.html#a95f0df6a8938ccd8179c617eea279358">00555</a> <span class="keyword">inline</span> Ogre::String <a class="code" href="class_gorilla_1_1_texture_atlas.html#a95f0df6a8938ccd8179c617eea279358">get2DMaterialName</a>()<span class="keyword"> const</span>
- <a name="l00556"></a>00556 <span class="keyword"> </span>{
- <a name="l00557"></a>00557 <span class="keywordflow">return</span> m2DMaterial->getName();
- <a name="l00558"></a>00558 }<span class="comment"></span>
- <a name="l00559"></a>00559 <span class="comment"> /*! function. getMaterialName</span>
- <a name="l00560"></a>00560 <span class="comment"> desc.</span>
- <a name="l00561"></a>00561 <span class="comment"> Get the name of the material assigned to this TextureAtlas</span>
- <a name="l00562"></a>00562 <span class="comment"> */</span>
- <a name="l00563"></a><a class="code" href="class_gorilla_1_1_texture_atlas.html#aab96a0207c86a817dca70d84798fd4fc">00563</a> <span class="keyword">inline</span> Ogre::String <a class="code" href="class_gorilla_1_1_texture_atlas.html#aab96a0207c86a817dca70d84798fd4fc">get3DMaterialName</a>()<span class="keyword"> const</span>
- <a name="l00564"></a>00564 <span class="keyword"> </span>{
- <a name="l00565"></a>00565 <span class="keywordflow">return</span> m3DMaterial->getName();
- <a name="l00566"></a>00566 }
- <a name="l00567"></a>00567
- <a name="l00568"></a>00568 <span class="keyword">inline</span> <a class="code" href="class_gorilla_1_1_glyph_data.html">GlyphData</a>* getGlyphData(Ogre::uint index)<span class="keyword"> const</span>
- <a name="l00569"></a>00569 <span class="keyword"> </span>{
- <a name="l00570"></a>00570 std::map<Ogre::uint, GlyphData*>::const_iterator it = mGlyphData.find(index);
- <a name="l00571"></a>00571 <span class="keywordflow">if</span> (it == mGlyphData.end())
- <a name="l00572"></a>00572 <span class="keywordflow">return</span> 0;
- <a name="l00573"></a>00573 <span class="keywordflow">return</span> (*it).second;
- <a name="l00574"></a>00574 }
- <a name="l00575"></a>00575 <span class="comment"></span>
- <a name="l00576"></a>00576 <span class="comment"> /*! function. getSprite</span>
- <a name=…