class_resource_instance.html 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214
  1. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
  2. <html xmlns="http://www.w3.org/1999/xhtml" lang="en-US">
  3. <head>
  4. <meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/>
  5. <meta http-equiv="X-UA-Compatible" content="IE=11"/>
  6. <meta name="generator" content="Doxygen 1.9.8"/>
  7. <meta name="viewport" content="width=device-width, initial-scale=1"/>
  8. <title>Torque2D Reference: ResourceInstance Class Reference</title>
  9. <link href="tabs.css" rel="stylesheet" type="text/css"/>
  10. <script type="text/javascript" src="jquery.js"></script>
  11. <script type="text/javascript" src="dynsections.js"></script>
  12. <link href="search/search.css" rel="stylesheet" type="text/css"/>
  13. <script type="text/javascript" src="search/searchdata.js"></script>
  14. <script type="text/javascript" src="search/search.js"></script>
  15. <link href="doxygen.css" rel="stylesheet" type="text/css" />
  16. <link href="t2d-stylesheet-extra.css" rel="stylesheet" type="text/css"/>
  17. </head>
  18. <body>
  19. <div id="top"><!-- do not remove this div, it is closed by doxygen! -->
  20. <div id="titlearea">
  21. <table cellspacing="0" cellpadding="0">
  22. <tbody>
  23. <tr id="projectrow">
  24. <td id="projectalign">
  25. <div id="projectname">Torque2D Reference
  26. </div>
  27. </td>
  28. </tr>
  29. </tbody>
  30. </table>
  31. </div>
  32. <!-- end header part -->
  33. <!-- Generated by Doxygen 1.9.8 -->
  34. <script type="text/javascript">
  35. /* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */
  36. var searchBox = new SearchBox("searchBox", "search/",'.html');
  37. /* @license-end */
  38. </script>
  39. <script type="text/javascript" src="menudata.js"></script>
  40. <script type="text/javascript" src="menu.js"></script>
  41. <script type="text/javascript">
  42. /* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */
  43. $(function() {
  44. initMenu('',true,false,'search.php','Search');
  45. $(document).ready(function() { init_search(); });
  46. });
  47. /* @license-end */
  48. </script>
  49. <div id="main-nav"></div>
  50. <!-- window showing the filter options -->
  51. <div id="MSearchSelectWindow"
  52. onmouseover="return searchBox.OnSearchSelectShow()"
  53. onmouseout="return searchBox.OnSearchSelectHide()"
  54. onkeydown="return searchBox.OnSearchSelectKey(event)">
  55. </div>
  56. <!-- iframe showing the search results (closed by default) -->
  57. <div id="MSearchResultsWindow">
  58. <div id="MSearchResults">
  59. <div class="SRPage">
  60. <div id="SRIndex">
  61. <div id="SRResults"></div>
  62. <div class="SRStatus" id="Loading">Loading...</div>
  63. <div class="SRStatus" id="Searching">Searching...</div>
  64. <div class="SRStatus" id="NoMatches">No Matches</div>
  65. </div>
  66. </div>
  67. </div>
  68. </div>
  69. </div><!-- top -->
  70. <div class="header">
  71. <div class="summary">
  72. <a href="#pub-methods">Public Member Functions</a> &#124;
  73. <a href="#pub-attribs">Public Attributes</a> &#124;
  74. <a href="class_resource_instance-members.html">List of all members</a> </div>
  75. <div class="headertitle"><div class="title">ResourceInstance Class Reference</div></div>
  76. </div><!--header-->
  77. <div class="contents">
  78. <p><code>#include &lt;resourceManager.h&gt;</code></p>
  79. <div id="dynsection-0" onclick="return toggleVisibility(this)" class="dynheader closed" style="cursor:pointer;">
  80. <img id="dynsection-0-trigger" src="closed.png" alt="+"/> Inheritance diagram for ResourceInstance:</div>
  81. <div id="dynsection-0-summary" class="dynsummary" style="display:block;">
  82. </div>
  83. <div id="dynsection-0-content" class="dyncontent" style="display:none;">
  84. <div class="center">
  85. <img src="class_resource_instance.png" usemap="#ResourceInstance_map" alt=""/>
  86. <map id="ResourceInstance_map" name="ResourceInstance_map">
  87. <area href="class_audio_buffer.html" alt="AudioBuffer" shape="rect" coords="0,56,113,80"/>
  88. <area href="class_g_bitmap.html" alt="GBitmap" shape="rect" coords="123,56,236,80"/>
  89. <area href="class_g_font.html" alt="GFont" shape="rect" coords="246,56,359,80"/>
  90. </map>
  91. </div></div>
  92. <table class="memberdecls">
  93. <tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="pub-methods" name="pub-methods"></a>
  94. Public Member Functions</h2></td></tr>
  95. <tr class="memitem:a60f6680bb78492eb8b97d3e36514a139" id="r_a60f6680bb78492eb8b97d3e36514a139"><td class="memItemLeft" align="right" valign="top">&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_resource_instance.html#a60f6680bb78492eb8b97d3e36514a139">ResourceInstance</a> ()</td></tr>
  96. <tr class="separator:a60f6680bb78492eb8b97d3e36514a139"><td class="memSeparator" colspan="2">&#160;</td></tr>
  97. <tr class="memitem:a6684f1419b225f2ccd7dfd495fd19bb3" id="r_a6684f1419b225f2ccd7dfd495fd19bb3"><td class="memItemLeft" align="right" valign="top">virtual&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_resource_instance.html#a6684f1419b225f2ccd7dfd495fd19bb3">~ResourceInstance</a> ()</td></tr>
  98. <tr class="separator:a6684f1419b225f2ccd7dfd495fd19bb3"><td class="memSeparator" colspan="2">&#160;</td></tr>
  99. </table><table class="memberdecls">
  100. <tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="pub-attribs" name="pub-attribs"></a>
  101. Public Attributes</h2></td></tr>
  102. <tr class="memitem:abdc28331c98eadf7e51f9ce3595ea557" id="r_abdc28331c98eadf7e51f9ce3595ea557"><td class="memItemLeft" align="right" valign="top"><a class="el" href="class_resource_object.html">ResourceObject</a> *&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_resource_instance.html#abdc28331c98eadf7e51f9ce3595ea557">mSourceResource</a></td></tr>
  103. <tr class="memdesc:abdc28331c98eadf7e51f9ce3595ea557"><td class="mdescLeft">&#160;</td><td class="mdescRight">Pointer to the <a class="el" href="class_resource_object.html">ResourceObject</a> that stores all our book-keeping data. <br /></td></tr>
  104. <tr class="separator:abdc28331c98eadf7e51f9ce3595ea557"><td class="memSeparator" colspan="2">&#160;</td></tr>
  105. </table>
  106. <a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2>
  107. <div class="textblock"><p>The base class for all resources.</p>
  108. <p>This must be subclassed to implement a resource that can be managed.</p>
  109. <p>Creating a new resource type is very simple. First, you need a function which can create a new instance of the resource given a stream:</p>
  110. <div class="fragment"><div class="line"><a class="code hl_class" href="class_resource_instance.html">ResourceInstance</a>* constructBitmapPNG(<a class="code hl_class" href="class_stream.html">Stream</a> &amp;stream)</div>
  111. <div class="line">{</div>
  112. <div class="line"> <a class="code hl_class" href="class_g_bitmap.html">GBitmap</a> *bmp = <span class="keyword">new</span> <a class="code hl_class" href="class_g_bitmap.html">GBitmap</a>;</div>
  113. <div class="line"> <span class="keywordflow">if</span>(bmp-&gt;<a class="code hl_function" href="class_g_bitmap.html#a774d522d2929606364b95b535119f51a">readPNG</a>(stream))</div>
  114. <div class="line"> <span class="keywordflow">return</span> bmp;</div>
  115. <div class="line"> <span class="keywordflow">else</span></div>
  116. <div class="line"> {</div>
  117. <div class="line"> <span class="keyword">delete</span> bmp;</div>
  118. <div class="line"> <span class="keywordflow">return</span> NULL;</div>
  119. <div class="line"> }</div>
  120. <div class="line">}</div>
  121. <div class="ttc" id="aclass_g_bitmap_html"><div class="ttname"><a href="class_g_bitmap.html">GBitmap</a></div><div class="ttdef"><b>Definition</b> gBitmap.h:54</div></div>
  122. <div class="ttc" id="aclass_g_bitmap_html_a774d522d2929606364b95b535119f51a"><div class="ttname"><a href="class_g_bitmap.html#a774d522d2929606364b95b535119f51a">GBitmap::readPNG</a></div><div class="ttdeci">bool readPNG(Stream &amp;io_rStream)</div><div class="ttdef"><b>Definition</b> bitmapPng.cc:125</div></div>
  123. <div class="ttc" id="aclass_resource_instance_html"><div class="ttname"><a href="class_resource_instance.html">ResourceInstance</a></div><div class="ttdef"><b>Definition</b> resourceManager.h:103</div></div>
  124. <div class="ttc" id="aclass_stream_html"><div class="ttname"><a href="class_stream.html">Stream</a></div><div class="ttdoc">Base stream class for streaming data across a specific media.</div><div class="ttdef"><b>Definition</b> stream.h:73</div></div>
  125. </div><!-- fragment --><p>Then you need to register the extension of your resource type with the resource manager:</p>
  126. <div class="fragment"><div class="line">ResourceManager-&gt;<a class="code hl_function" href="class_res_manager.html#a0036ffad373b2d87df5abf674cb4cda1">registerExtension</a>(<span class="stringliteral">&quot;.png&quot;</span>, constructBitmapPNG);</div>
  127. <div class="ttc" id="aclass_res_manager_html_a0036ffad373b2d87df5abf674cb4cda1"><div class="ttname"><a href="class_res_manager.html#a0036ffad373b2d87df5abf674cb4cda1">ResManager::registerExtension</a></div><div class="ttdeci">void registerExtension(const char *extension, RESOURCE_CREATE_FN create_fn)</div><div class="ttdoc">Tells the resource manager what to do with a resource that it loads.</div><div class="ttdef"><b>Definition</b> resourceManager.cc:712</div></div>
  128. </div><!-- fragment --><p>And, of course, you need to provide a subclass of <a class="el" href="class_resource_instance.html">ResourceInstance</a>:</p>
  129. <div class="fragment"><div class="line"><span class="keyword">class </span><a class="code hl_class" href="class_g_bitmap.html">GBitmap</a> : <a class="code hl_class" href="class_resource_instance.html">ResourceInstance</a> {</div>
  130. <div class="line"> ... whatever you need <span class="keywordflow">for</span> your resource goes in here ...</div>
  131. <div class="line">}</div>
  132. </div><!-- fragment --><p><a class="el" href="class_resource_instance.html">ResourceInstance</a> imposes very few requirements on you as the resource type implementor. All you "have" to provide is a destructor to deallocate whatever storage your resource might allocate. The ResourceManager will ensure that there is only one instance of the <a class="el" href="class_resource_instance.html">ResourceInstance</a> for each file, and that it is only destroyed when no more references to it remain.</p>
  133. <dl class="section see"><dt>See also</dt><dd>TerrainFile, <a class="el" href="class_g_bitmap.html">GBitmap</a>, <a class="el" href="class_audio_buffer.html">AudioBuffer</a> for more examples. </dd></dl>
  134. </div><h2 class="groupheader">Constructor &amp; Destructor Documentation</h2>
  135. <a id="a60f6680bb78492eb8b97d3e36514a139" name="a60f6680bb78492eb8b97d3e36514a139"></a>
  136. <h2 class="memtitle"><span class="permalink"><a href="#a60f6680bb78492eb8b97d3e36514a139">&#9670;&#160;</a></span>ResourceInstance()</h2>
  137. <div class="memitem">
  138. <div class="memproto">
  139. <table class="mlabels">
  140. <tr>
  141. <td class="mlabels-left">
  142. <table class="memname">
  143. <tr>
  144. <td class="memname"><a class="el" href="class_resource_instance.html">ResourceInstance</a> </td>
  145. <td>(</td>
  146. <td class="paramname"></td><td>)</td>
  147. <td></td>
  148. </tr>
  149. </table>
  150. </td>
  151. <td class="mlabels-right">
  152. <span class="mlabels"><span class="mlabel">inline</span></span> </td>
  153. </tr>
  154. </table>
  155. </div><div class="memdoc">
  156. </div>
  157. </div>
  158. <a id="a6684f1419b225f2ccd7dfd495fd19bb3" name="a6684f1419b225f2ccd7dfd495fd19bb3"></a>
  159. <h2 class="memtitle"><span class="permalink"><a href="#a6684f1419b225f2ccd7dfd495fd19bb3">&#9670;&#160;</a></span>~ResourceInstance()</h2>
  160. <div class="memitem">
  161. <div class="memproto">
  162. <table class="mlabels">
  163. <tr>
  164. <td class="mlabels-left">
  165. <table class="memname">
  166. <tr>
  167. <td class="memname">virtual ~<a class="el" href="class_resource_instance.html">ResourceInstance</a> </td>
  168. <td>(</td>
  169. <td class="paramname"></td><td>)</td>
  170. <td></td>
  171. </tr>
  172. </table>
  173. </td>
  174. <td class="mlabels-right">
  175. <span class="mlabels"><span class="mlabel">inline</span><span class="mlabel">virtual</span></span> </td>
  176. </tr>
  177. </table>
  178. </div><div class="memdoc">
  179. </div>
  180. </div>
  181. <h2 class="groupheader">Member Data Documentation</h2>
  182. <a id="abdc28331c98eadf7e51f9ce3595ea557" name="abdc28331c98eadf7e51f9ce3595ea557"></a>
  183. <h2 class="memtitle"><span class="permalink"><a href="#abdc28331c98eadf7e51f9ce3595ea557">&#9670;&#160;</a></span>mSourceResource</h2>
  184. <div class="memitem">
  185. <div class="memproto">
  186. <table class="memname">
  187. <tr>
  188. <td class="memname"><a class="el" href="class_resource_object.html">ResourceObject</a>* mSourceResource</td>
  189. </tr>
  190. </table>
  191. </div><div class="memdoc">
  192. <p>Pointer to the <a class="el" href="class_resource_object.html">ResourceObject</a> that stores all our book-keeping data. </p>
  193. </div>
  194. </div>
  195. <hr/>The documentation for this class was generated from the following file:<ul>
  196. <li>io/resource/<b>resourceManager.h</b></li>
  197. </ul>
  198. </div><!-- contents -->
  199. <!-- start footer part -->
  200. <hr class="footer"/><address class="footer"><small>
  201. Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.9.8
  202. </small></address>
  203. </body>
  204. </html>