<?xml version="1.0"?>
<rss version="2.0">
	<channel>
		<title>Drawing text slows down FPS dramatically</title>
		<link>http://www.allegro.cc/forums/view/616680</link>
		<description>Allegro.cc Forum Thread</description>
		<webMaster>matthew@allegro.cc (Matthew Leverton)</webMaster>
		<lastBuildDate>Mon, 09 Jan 2017 05:20:33 +0000</lastBuildDate>
	</channel>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>EDIT: Unless there is something wrong with my FPS calculation, it seems like a blank screen will give me around 3000 to 5000 FPS, but if I draw even one small bit of text, it drops down to 20 FPS. Drawing a line does not seem to affect FPS.</p><p>I&#39;ve only just now noticed that with each call to al_draw_text() my FPS drops dramatically. I noticed it when I had flashing &quot;Press Enter&quot; text, whenever the text was visible, an object that followed my mouse stuttered.</p><p>I can&#39;t think of anything that I might have done to cause this problem. I tried adding several more lines to draw &quot;Main Menu&quot; over and over and with each draw the FPS cut in half for each draw.</p><p>I believe this is all the applicable code:</p><div class="source-code"><div class="toolbar"><span class="button numbers"><b>#</b></span><span class="button select">Select</span><span class="button expand">Expand</span></div><div class="inner"><span class="number">  1</span><span class="c">// GAME LOOP</span>
<span class="number">  2</span><span class="k1">while</span> <span class="k2">(</span>engine-&gt;state_manager-&gt;running<span class="k2">(</span><span class="k2">)</span><span class="k2">)</span>
<span class="number">  3</span><span class="k2">{</span>
<span class="number">  4</span>  <span class="k1">if</span> <span class="k2">(</span>engine-&gt;event_handler-&gt;handleEvents<span class="k2">(</span><span class="k2">)</span><span class="k2">)</span> <span class="c">//Function included in post</span>
<span class="number">  5</span>  <span class="k2">{</span>
<span class="number">  6</span>    <a href="http://www.allegro.cc/manual/ALLEGRO_EVENT"><span class="a">ALLEGRO_EVENT</span></a> ev <span class="k3">=</span> engine-&gt;event_handler-&gt;getEvent<span class="k2">(</span><span class="k2">)</span><span class="k2">;</span>
<span class="number">  7</span>    engine-&gt;input_handler-&gt;getInput<span class="k2">(</span>ev<span class="k2">)</span><span class="k2">;</span>
<span class="number">  8</span>    engine-&gt;state_manager-&gt;handleEvents<span class="k2">(</span><span class="k2">)</span><span class="k2">;</span>
<span class="number">  9</span>
<span class="number"> 10</span>    <span class="k1">if</span> <span class="k2">(</span>engine-&gt;input_handler-&gt;isKeyPressed<span class="k2">(</span>ALLEGRO_KEY_ESCAPE<span class="k2">)</span> <span class="k3">|</span><span class="k3">|</span> engine-&gt;event_handler-&gt;eventIs<span class="k2">(</span>ALLEGRO_EVENT_DISPLAY_CLOSE<span class="k2">)</span><span class="k2">)</span>
<span class="number"> 11</span>    <span class="k2">{</span>
<span class="number"> 12</span>      engine-&gt;state_manager-&gt;quit<span class="k2">(</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 13</span>    <span class="k2">}</span>
<span class="number"> 14</span>    <span class="k1">else</span> <span class="k1">if</span> <span class="k2">(</span>engine-&gt;event_handler-&gt;eventIs<span class="k2">(</span>ALLEGRO_EVENT_TIMER<span class="k2">)</span><span class="k2">)</span>
<span class="number"> 15</span>    <span class="k2">{</span>
<span class="number"> 16</span>      engine-&gt;state_manager-&gt;update<span class="k2">(</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 17</span>    <span class="k2">}</span>
<span class="number"> 18</span>  <span class="k2">}</span>
<span class="number"> 19</span>
<span class="number"> 20</span>  <span class="k1">if</span> <span class="k2">(</span>engine-&gt;event_handler-&gt;eventQueueEmpty<span class="k2">(</span><span class="k2">)</span><span class="k2">)</span> <span class="c">// Simply calls al_is_event_queue_empty()</span>
<span class="number"> 21</span>  <span class="k2">{</span>
<span class="number"> 22</span>    <span class="k1">uint64_t</span> ms <span class="k3">=</span> t.getMilliseconds<span class="k2">(</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 23</span>    elapsed <span class="k3">=</span> ms <span class="k3">-</span> prev_time<span class="k2">;</span>
<span class="number"> 24</span>    prev_time <span class="k3">=</span> ms<span class="k2">;</span>
<span class="number"> 25</span>    
<span class="number"> 26</span>    engine-&gt;state_manager-&gt;draw<span class="k2">(</span>elapsed<span class="k2">)</span><span class="k2">;</span> <span class="c">// Function included in post</span>
<span class="number"> 27</span>    engine-&gt;draw_engine-&gt;flipAndClear<span class="k2">(</span><a href="http://www.allegro.cc/manual/al_map_rgb"><span class="a">al_map_rgb</span></a><span class="k2">(</span><span class="n">0</span>, <span class="n">0</span>, <span class="n">0</span><span class="k2">)</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 28</span>  <span class="k2">}</span>
<span class="number"> 29</span>  engine-&gt;state_manager-&gt;cleanStates<span class="k2">(</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 30</span><span class="k2">}</span>
<span class="number"> 31</span>
<span class="number"> 32</span><span class="k1">bool</span> EventHandler::handleEvents<span class="k2">(</span><span class="k2">)</span>
<span class="number"> 33</span><span class="k2">{</span>
<span class="number"> 34</span>  <a href="http://www.allegro.cc/manual/ALLEGRO_EVENT"><span class="a">ALLEGRO_EVENT</span></a> ev<span class="k2">;</span>
<span class="number"> 35</span>
<span class="number"> 36</span>  <span class="k1">if</span> <span class="k2">(</span><span class="k3">!</span><a href="http://www.allegro.cc/manual/al_get_next_event"><span class="a">al_get_next_event</span></a><span class="k2">(</span>event_queue, <span class="k3">&amp;</span>ev<span class="k2">)</span><span class="k2">)</span> <span class="k1">return</span> <span class="k1">false</span><span class="k2">;</span>
<span class="number"> 37</span>
<span class="number"> 38</span>  <span class="k1">if</span> <span class="k2">(</span>ev.type <span class="k3">=</span><span class="k3">=</span> ALLEGRO_EVENT_DISPLAY_SWITCH_OUT<span class="k2">)</span>
<span class="number"> 39</span>    focus <span class="k3">=</span> <span class="k1">false</span><span class="k2">;</span>
<span class="number"> 40</span>  <span class="k1">else</span> <span class="k1">if</span> <span class="k2">(</span>ev.type <span class="k3">=</span><span class="k3">=</span> ALLEGRO_EVENT_DISPLAY_SWITCH_IN<span class="k2">)</span>
<span class="number"> 41</span>    focus <span class="k3">=</span> <span class="k1">true</span><span class="k2">;</span>
<span class="number"> 42</span>  <span class="k1">else</span> <span class="k1">if</span> <span class="k2">(</span>ev.type <span class="k3">=</span><span class="k3">=</span> ALLEGRO_EVENT_DISPLAY_RESIZE<span class="k2">)</span>
<span class="number"> 43</span>  <span class="k2">{</span>
<span class="number"> 44</span>    <a href="http://www.allegro.cc/manual/al_acknowledge_resize"><span class="a">al_acknowledge_resize</span></a><span class="k2">(</span><a href="http://www.allegro.cc/manual/al_get_current_display"><span class="a">al_get_current_display</span></a><span class="k2">(</span><span class="k2">)</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 45</span>    axe::log<span class="k2">(</span>_MESSAGE, <span class="s">"Display Resized!\n"</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 46</span>    engine-&gt;draw_engine-&gt;resized<span class="k2">(</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 47</span>    <span class="c">// Windows has just been resized, let anything know about it.</span>
<span class="number"> 48</span>  <span class="k2">}</span>
<span class="number"> 49</span>
<span class="number"> 50</span>  this-&gt;ev <span class="k3">=</span> ev<span class="k2">;</span>
<span class="number"> 51</span>
<span class="number"> 52</span>  <span class="k1">return</span> <span class="k1">true</span><span class="k2">;</span>
<span class="number"> 53</span><span class="k2">}</span>
<span class="number"> 54</span>
<span class="number"> 55</span><span class="k1">void</span> MenuState::draw<span class="k2">(</span>uint64 elapsed<span class="k2">)</span>
<span class="number"> 56</span><span class="k2">{</span>
<span class="number"> 57</span>  <span class="c">//Press Enter will flash once per second</span>
<span class="number"> 58</span>  el <span class="k3">+</span><span class="k3">=</span> elapsed<span class="k2">;</span>
<span class="number"> 59</span>  <span class="k1">if</span> <span class="k2">(</span>el <span class="k3">&gt;</span><span class="k3">=</span> <span class="n">500</span><span class="k2">)</span> draw_text <span class="k3">=</span> <span class="k1">true</span><span class="k2">;</span>
<span class="number"> 60</span>  <span class="k1">if</span> <span class="k2">(</span>el <span class="k3">&gt;</span><span class="k3">=</span> <span class="n">1000</span><span class="k2">)</span>
<span class="number"> 61</span>  <span class="k2">{</span>
<span class="number"> 62</span>    el <span class="k3">-</span><span class="k3">=</span> <span class="n">1000</span><span class="k2">;</span>
<span class="number"> 63</span>    draw_text <span class="k3">=</span> <span class="k1">false</span><span class="k2">;</span>
<span class="number"> 64</span>  <span class="k2">}</span>
<span class="number"> 65</span>
<span class="number"> 66</span>  <span class="k1">if</span> <span class="k2">(</span>font1<span class="k2">)</span>
<span class="number"> 67</span>  <span class="k2">{</span>
<span class="number"> 68</span>    <a href="http://www.allegro.cc/manual/al_draw_text"><span class="a">al_draw_text</span></a><span class="k2">(</span>font1, <a href="http://www.allegro.cc/manual/al_map_rgb"><span class="a">al_map_rgb</span></a><span class="k2">(</span><span class="n">255</span>, <span class="n">255</span>, <span class="n">255</span><span class="k2">)</span>, w <span class="k3">/</span> <span class="n">2</span>, <span class="n">64</span>, ALLEGRO_ALIGN_CENTRE, <span class="s">"Main Menu"</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 69</span>  <span class="k2">}</span>
<span class="number"> 70</span>
<span class="number"> 71</span>  <span class="k1">if</span> <span class="k2">(</span>draw_text <span class="k3">&amp;</span><span class="k3">&amp;</span> font2<span class="k2">)</span>
<span class="number"> 72</span>  <span class="k2">{</span>
<span class="number"> 73</span>    <a href="http://www.allegro.cc/manual/al_draw_text"><span class="a">al_draw_text</span></a><span class="k2">(</span>font1, <a href="http://www.allegro.cc/manual/al_map_rgb"><span class="a">al_map_rgb</span></a><span class="k2">(</span><span class="n">255</span>, <span class="n">255</span>, <span class="n">255</span><span class="k2">)</span>, w <span class="k3">/</span> <span class="n">2</span>, h <span class="k3">-</span> <span class="n">128</span>, ALLEGRO_ALIGN_CENTRE, <span class="s">"Press Enter"</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 74</span>  <span class="k2">}</span>
<span class="number"> 75</span>
<span class="number"> 76</span>  <span class="c">//Draws an X starting at (0,0) moving 90 pixels to the right per second, and 50 pixels down per second</span>
<span class="number"> 77</span>
<span class="number"> 78</span>  x <span class="k3">+</span><span class="k3">=</span> <span class="n">90</span>.f <span class="k3">*</span> elapsed <span class="k3">/</span> <span class="n">1000</span>.f<span class="k2">;</span>
<span class="number"> 79</span>  y <span class="k3">+</span><span class="k3">=</span> <span class="n">50</span>.f <span class="k3">*</span> elapsed <span class="k3">/</span> <span class="n">1000</span>.f<span class="k2">;</span>
<span class="number"> 80</span>
<span class="number"> 81</span>  <a href="http://www.allegro.cc/manual/al_draw_line"><span class="a">al_draw_line</span></a><span class="k2">(</span>x <span class="k3">-</span> <span class="n">8</span>, y <span class="k3">-</span> <span class="n">8</span>, x <span class="k3">+</span> <span class="n">8</span>, y <span class="k3">+</span> <span class="n">8</span>, <a href="http://www.allegro.cc/manual/al_map_rgb"><span class="a">al_map_rgb</span></a><span class="k2">(</span><span class="n">255</span>, <span class="n">0</span>, <span class="n">0</span><span class="k2">)</span>, <span class="n">2</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 82</span>  <a href="http://www.allegro.cc/manual/al_draw_line"><span class="a">al_draw_line</span></a><span class="k2">(</span>x <span class="k3">-</span> <span class="n">8</span>, y <span class="k3">+</span> <span class="n">8</span>, x <span class="k3">+</span> <span class="n">8</span>, y <span class="k3">-</span> <span class="n">8</span>, <a href="http://www.allegro.cc/manual/al_map_rgb"><span class="a">al_map_rgb</span></a><span class="k2">(</span><span class="n">255</span>, <span class="n">0</span>, <span class="n">0</span><span class="k2">)</span>, <span class="n">2</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 83</span><span class="k2">}</span>
</div></div><p>

Thanks for the help!
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (Aksel Huff)</author>
		<pubDate>Sun, 08 Jan 2017 06:09:43 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>Are you loading your fonts before al_create_display? They might be memory bitmaps. Show font and display creation code. All video bitmaps are attached to a display and if you haven&#39;t created a display you don&#39;t have anything to attach it to so they&#39;re memory bitmaps.</p><p>Or your problem is something else. What version of Allegro are you using? What platform are you on? What&#39;s your compiler?
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (Edgar Reynaldo)</author>
		<pubDate>Sun, 08 Jan 2017 08:28:40 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>Thanks for the help! I would not have figured this out if you hadn&#39;t have brought up memory/video bitmaps!</p><p>EDIT2: I added &quot;al_set_new_bitmap_flags(ALLEGRO_VIDEO_BITMAP);&quot; before loading fonts and the problem disappeared! I&#39;m guessing Allegro is defaulting to memory bitmaps for some reason? Or something I&#39;ve done has changed the bitmap flags. Also I&#39;ve just now noticed that lines 65 and 67 are using al_set_new_bitmap_flags rather than al_set_new_display_flags(). I haven&#39;t tested it yet, but I&#39;m guessing that is the culprit.</p><p>I&#39;m using Allegro 5.2.2 from NuGet in MSVC Express 2015. Windows 10.</p><p>The display is created inside &quot;engine-&gt;draw_engine-&gt;init()&quot;, and then near the end of my game initialization I load a font to draw the FPS with</p><p>Here is essentially the program entry for my game:</p><div class="source-code"><div class="toolbar"><span class="button numbers"><b>#</b></span><span class="button select">Select</span><span class="button expand">Expand</span></div><div class="inner"><span class="number">  1</span><span class="k1">int</span> Game::init<span class="k2">(</span><span class="k2">)</span>
<span class="number">  2</span><span class="k2">{</span>
<span class="number">  3</span>  t.start<span class="k2">(</span><span class="k2">)</span><span class="k2">;</span>
<span class="number">  4</span>
<span class="number">  5</span>  <a href="http://www.delorie.com/djgpp/doc/libc/libc_739.html" target="_blank">srand</a><span class="k2">(</span><a href="http://www.delorie.com/djgpp/doc/libc/libc_821.html" target="_blank">time</a><span class="k2">(</span>NULL<span class="k2">)</span><span class="k2">)</span><span class="k2">;</span>
<span class="number">  6</span>  engine <span class="k3">=</span> <span class="k1">new</span> axe::Engine<span class="k2">(</span><span class="k2">)</span><span class="k2">;</span>
<span class="number">  7</span>  <span class="k1">const</span> <span class="k1">float</span> ticks_per_second <span class="k3">=</span> <span class="n">30</span>.f<span class="k2">;</span>
<span class="number">  8</span>
<span class="number">  9</span>  <span class="c">/***************   SET DEFAULT SETTINGS   ***************/</span>
<span class="number"> 10</span>
<span class="number"> 11</span>  <span class="k1">int</span> width <span class="k3">=</span> <span class="n">1280</span><span class="k2">;</span>
<span class="number"> 12</span>  <span class="k1">int</span> height <span class="k3">=</span> <span class="n">720</span><span class="k2">;</span>
<span class="number"> 13</span>  <span class="k1">bool</span> fullscreen <span class="k3">=</span> <span class="k1">false</span><span class="k2">;</span>
<span class="number"> 14</span>  <span class="k1">bool</span> music <span class="k3">=</span> <span class="k1">true</span><span class="k2">;</span>
<span class="number"> 15</span>  <span class="k1">bool</span> sfx <span class="k3">=</span> <span class="k1">true</span><span class="k2">;</span>
<span class="number"> 16</span>  <span class="k1">bool</span> <a href="http://www.allegro.cc/manual/vsync"><span class="a">vsync</span></a> <span class="k3">=</span> <span class="k1">true</span><span class="k2">;</span>
<span class="number"> 17</span>  <span class="k1">bool</span> maximized <span class="k3">=</span> <span class="k1">true</span><span class="k2">;</span>
<span class="number"> 18</span>
<span class="number"> 19</span>  engine-&gt;settings_handler-&gt;set<span class="k2">(</span><span class="s">"x_resolution"</span>, width<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 20</span>  engine-&gt;settings_handler-&gt;set<span class="k2">(</span><span class="s">"y_resolution"</span>, height<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 21</span>  engine-&gt;settings_handler-&gt;set<span class="k2">(</span><span class="s">"fullscreen"</span>, fullscreen<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 22</span>  engine-&gt;settings_handler-&gt;set<span class="k2">(</span><span class="s">"maximized"</span>, maximized<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 23</span>  engine-&gt;settings_handler-&gt;set<span class="k2">(</span><span class="s">"vsync"</span>, <a href="http://www.allegro.cc/manual/vsync"><span class="a">vsync</span></a><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 24</span>  engine-&gt;settings_handler-&gt;set<span class="k2">(</span><span class="s">"music"</span>, music<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 25</span>  engine-&gt;settings_handler-&gt;set<span class="k2">(</span><span class="s">"sfx"</span>, sfx<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 26</span>
<span class="number"> 27</span>  engine-&gt;settings_handler-&gt;loadSettings<span class="k2">(</span><span class="s">".settings"</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 28</span>  engine-&gt;settings_handler-&gt;printSettings<span class="k2">(</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 29</span>
<span class="number"> 30</span>  engine-&gt;settings_handler-&gt;get<span class="k2">(</span><span class="s">"x_resolution"</span>, width<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 31</span>  engine-&gt;settings_handler-&gt;get<span class="k2">(</span><span class="s">"y_resolution"</span>, height<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 32</span>  engine-&gt;settings_handler-&gt;get<span class="k2">(</span><span class="s">"fullscreen"</span>, fullscreen<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 33</span>  engine-&gt;settings_handler-&gt;get<span class="k2">(</span><span class="s">"maximized"</span>, maximized<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 34</span>  engine-&gt;settings_handler-&gt;get<span class="k2">(</span><span class="s">"vsync"</span>, <a href="http://www.allegro.cc/manual/vsync"><span class="a">vsync</span></a><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 35</span>  engine-&gt;settings_handler-&gt;get<span class="k2">(</span><span class="s">"music"</span>, music<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 36</span>  engine-&gt;settings_handler-&gt;get<span class="k2">(</span><span class="s">"sfx"</span>, sfx<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 37</span>
<span class="number"> 38</span>  <span class="k1">if</span> <span class="k2">(</span>engine-&gt;init<span class="k2">(</span>ticks_per_second<span class="k2">)</span><span class="k2">)</span>
<span class="number"> 39</span>  <span class="k2">{</span>
<span class="number"> 40</span>    axe::crash<span class="k2">(</span><span class="s">"Engine failed to initialize!"</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 41</span>    <span class="k1">return</span> <span class="n">1</span><span class="k2">;</span>
<span class="number"> 42</span>  <span class="k2">}</span>
<span class="number"> 43</span>  engine-&gt;draw_engine-&gt;init<span class="k2">(</span>width, height, fullscreen, <span class="k1">false</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 44</span>
<span class="number"> 45</span>  engine-&gt;draw_engine-&gt;setWindowIcon<span class="k2">(</span>RES::IMG::ICO<span class="k2">)</span><span class="k2">;</span> <span class="c">//todo add \n to the error report for this function</span>
<span class="number"> 46</span>  engine-&gt;draw_engine-&gt;setWindowTitle<span class="k2">(</span><span class="s">"The 21st Floor"</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 47</span>
<span class="number"> 48</span>  engine-&gt;sound_manager-&gt;setMusicMute<span class="k2">(</span><span class="k3">!</span>music<span class="k2">)</span><span class="k2">;</span> <span class="c">// true in settings means music is on, true in sound_manager means music is off</span>
<span class="number"> 49</span>  engine-&gt;sound_manager-&gt;setSFXMute<span class="k2">(</span><span class="k3">!</span>sfx<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 50</span>
<span class="number"> 51</span>  engine-&gt;state_manager-&gt;changeState<span class="k2">(</span><span class="k1">new</span> SplashState<span class="k2">(</span>engine<span class="k2">)</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 52</span>
<span class="number"> 53</span>  fnt <span class="k3">=</span> nullptr<span class="k2">;</span>
<span class="number"> 54</span>  fnt <span class="k3">=</span> <a href="http://www.allegro.cc/manual/al_load_font"><span class="a">al_load_font</span></a><span class="k2">(</span>RES::FNT::ARIAL, <span class="n">18</span>, <span class="n">0</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 55</span>
<span class="number"> 56</span>  <span class="k1">return</span> <span class="n">0</span><span class="k2">;</span>
<span class="number"> 57</span><span class="k2">}</span>
</div></div><p>

And here is my disaster of window initialization!</p><div class="source-code"><div class="toolbar"><span class="button numbers"><b>#</b></span><span class="button select">Select</span><span class="button expand">Expand</span></div><div class="inner"><span class="number">  1</span><span class="k1">int</span> DrawEngine::init<span class="k2">(</span><span class="k1">int</span> w, <span class="k1">int</span> h, <span class="k1">bool</span> fullscreen, <span class="k1">bool</span> match_aspect_ratio<span class="k2">)</span>
<span class="number">  2</span><span class="k2">{</span>
<span class="number">  3</span>  <a href="http://www.allegro.cc/manual/ALLEGRO_DISPLAY_MODE"><span class="a">ALLEGRO_DISPLAY_MODE</span></a> display_data<span class="k2">;</span>
<span class="number">  4</span>
<span class="number">  5</span>  this-&gt;fullscreen <span class="k3">=</span> fullscreen<span class="k2">;</span>
<span class="number">  6</span>  screenWidth <span class="k3">=</span> w<span class="k2">;</span>
<span class="number">  7</span>  screenHeight <span class="k3">=</span> h<span class="k2">;</span>
<span class="number">  8</span>
<span class="number">  9</span>  <span class="c">//Get all possible fullscreen resolutions and calculate aspect ratio</span>
<span class="number"> 10</span>  <span class="k1">int</span> num_display_modes <span class="k3">=</span> <a href="http://www.allegro.cc/manual/al_get_num_display_modes"><span class="a">al_get_num_display_modes</span></a><span class="k2">(</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 11</span>  <a href="http://www.allegro.cc/manual/al_get_display_mode"><span class="a">al_get_display_mode</span></a><span class="k2">(</span>num_display_modes <span class="k3">-</span> <span class="n">1</span>, <span class="k3">&amp;</span>display_data<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 12</span>  <span class="k1">float</span> aspect_ratio <span class="k3">=</span> <span class="k1">float</span><span class="k2">(</span>display_data.width<span class="k2">)</span> <span class="k3">/</span> <span class="k1">float</span><span class="k2">(</span>display_data.height<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 13</span>
<span class="number"> 14</span>  <span class="c">//Fill vector with all resolutions, removing duplicates and anything not matching aspect ratio</span>
<span class="number"> 15</span>  <a href="http://www.delorie.com/djgpp/doc/libc/libc_624.html" target="_blank">printf</a><span class="k2">(</span><span class="s">"Supported Fullscreen Resolutions:\n"</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 16</span>  <span class="k1">for</span> <span class="k2">(</span><span class="k1">int</span> i <span class="k3">=</span> <span class="n">0</span><span class="k2">;</span> i <span class="k3">&lt;</span> num_display_modes<span class="k2">;</span> i<span class="k3">+</span><span class="k3">+</span><span class="k2">)</span>
<span class="number"> 17</span>  <span class="k2">{</span>
<span class="number"> 18</span>    <a href="http://www.allegro.cc/manual/al_get_display_mode"><span class="a">al_get_display_mode</span></a><span class="k2">(</span>i, <span class="k3">&amp;</span>display_data<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 19</span>
<span class="number"> 20</span>    <span class="k1">bool</span> same_aspect<span class="k2">;</span>
<span class="number"> 21</span>
<span class="number"> 22</span>    <span class="k1">if</span> <span class="k2">(</span>match_aspect_ratio<span class="k2">)</span>
<span class="number"> 23</span>      same_aspect <span class="k3">=</span> <span class="k1">float</span><span class="k2">(</span>display_data.width<span class="k2">)</span> <span class="k3">/</span> <span class="k1">float</span><span class="k2">(</span>display_data.height<span class="k2">)</span> <span class="k3">=</span><span class="k3">=</span> aspect_ratio<span class="k2">;</span>
<span class="number"> 24</span>    <span class="k1">else</span>
<span class="number"> 25</span>      same_aspect <span class="k3">=</span> <span class="k1">true</span><span class="k2">;</span>
<span class="number"> 26</span>
<span class="number"> 27</span>    <span class="k1">if</span> <span class="k2">(</span>same_aspect<span class="k2">)</span>
<span class="number"> 28</span>    <span class="k2">{</span>
<span class="number"> 29</span>      <span class="k1">bool</span> <a href="http://www.delorie.com/djgpp/doc/libc/libc_281.html" target="_blank">dup</a> <span class="k3">=</span> <span class="k1">false</span><span class="k2">;</span>
<span class="number"> 30</span>      <span class="k1">for</span> <span class="k2">(</span>std::vector<span class="k3">&lt;</span>ALLEGRO_DISPLAY_MODE&gt;::iterator it <span class="k3">=</span> display_modes.begin<span class="k2">(</span><span class="k2">)</span><span class="k2">;</span> it <span class="k3">!</span><span class="k3">=</span> display_modes.end<span class="k2">(</span><span class="k2">)</span><span class="k2">;</span> <span class="k3">+</span><span class="k3">+</span>it<span class="k2">)</span>
<span class="number"> 31</span>      <span class="k2">{</span>
<span class="number"> 32</span>        <span class="k1">if</span> <span class="k2">(</span>display_data.width <span class="k3">=</span><span class="k3">=</span> <span class="k2">(</span><span class="k3">*</span>it<span class="k2">)</span>.width <span class="k3">&amp;</span><span class="k3">&amp;</span> display_data.height <span class="k3">=</span><span class="k3">=</span> <span class="k2">(</span><span class="k3">*</span>it<span class="k2">)</span>.height<span class="k2">)</span>
<span class="number"> 33</span>          <a href="http://www.delorie.com/djgpp/doc/libc/libc_281.html" target="_blank">dup</a> <span class="k3">=</span> <span class="k1">true</span><span class="k2">;</span>
<span class="number"> 34</span>      <span class="k2">}</span>
<span class="number"> 35</span>      <span class="k1">if</span> <span class="k2">(</span><span class="k3">!</span><a href="http://www.delorie.com/djgpp/doc/libc/libc_281.html" target="_blank">dup</a><span class="k2">)</span>
<span class="number"> 36</span>      <span class="k2">{</span>
<span class="number"> 37</span>        display_modes.push_back<span class="k2">(</span>display_data<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 38</span>        <a href="http://www.delorie.com/djgpp/doc/libc/libc_624.html" target="_blank">printf</a><span class="k2">(</span><span class="s">"   %ix%i\n"</span>, display_data.width, display_data.height<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 39</span>      <span class="k2">}</span>
<span class="number"> 40</span>    <span class="k2">}</span>
<span class="number"> 41</span>  <span class="k2">}</span>
<span class="number"> 42</span>
<span class="number"> 43</span>  <span class="c">//Make sure the resolution supplied to this function is supported in fullscreen</span>
<span class="number"> 44</span>  <span class="k1">if</span> <span class="k2">(</span>fullscreen<span class="k2">)</span>
<span class="number"> 45</span>  <span class="k2">{</span>
<span class="number"> 46</span>    <a href="http://www.allegro.cc/manual/al_set_new_display_flags"><span class="a">al_set_new_display_flags</span></a><span class="k2">(</span>ALLEGRO_FULLSCREEN<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 47</span>    
<span class="number"> 48</span>    <span class="k1">bool</span> found <span class="k3">=</span> <span class="k1">false</span><span class="k2">;</span>
<span class="number"> 49</span>    <span class="k1">for</span> <span class="k2">(</span><span class="k1">int</span> i <span class="k3">=</span> display_modes.size<span class="k2">(</span><span class="k2">)</span> <span class="k3">-</span> <span class="n">1</span><span class="k2">;</span> i <span class="k3">&gt;</span><span class="k3">=</span> <span class="n">0</span><span class="k2">;</span> i--<span class="k2">)</span>
<span class="number"> 50</span>    <span class="k2">{</span>
<span class="number"> 51</span>      <span class="k1">if</span> <span class="k2">(</span>display_modes<span class="k2">[</span>i<span class="k2">]</span>.width <span class="k3">=</span><span class="k3">=</span> screenWidth <span class="k3">&amp;</span><span class="k3">&amp;</span> display_modes<span class="k2">[</span>i<span class="k2">]</span>.height <span class="k3">=</span><span class="k3">=</span> screenHeight<span class="k2">)</span>
<span class="number"> 52</span>      <span class="k2">{</span>
<span class="number"> 53</span>        found <span class="k3">=</span> <span class="k1">true</span><span class="k2">;</span>
<span class="number"> 54</span>      <span class="k2">}</span>
<span class="number"> 55</span>    <span class="k2">}</span>
<span class="number"> 56</span>    <span class="k1">if</span> <span class="k2">(</span><span class="k3">!</span>found<span class="k2">)</span>
<span class="number"> 57</span>    <span class="k2">{</span>
<span class="number"> 58</span>      screenWidth <span class="k3">=</span> display_modes.back<span class="k2">(</span><span class="k2">)</span>.width<span class="k2">;</span>
<span class="number"> 59</span>      screenHeight <span class="k3">=</span> display_modes.back<span class="k2">(</span><span class="k2">)</span>.height<span class="k2">;</span>
<span class="number"> 60</span>      axe::log<span class="k2">(</span>axe::_WARNING, <span class="s">"Resolution Settings Invalid: Setting resolution to default: %ix%i\n"</span>, screenWidth, screenHeight<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 61</span>    <span class="k2">}</span>
<span class="number"> 62</span>  <span class="k2">}</span>
<span class="number"> 63</span>  <span class="k1">else</span> <span class="k1">if</span> <span class="k2">(</span>screenWidth <span class="k3">=</span><span class="k3">=</span> display_modes.back<span class="k2">(</span><span class="k2">)</span>.width <span class="k3">&amp;</span><span class="k3">&amp;</span> screenHeight <span class="k3">=</span><span class="k3">=</span> display_modes.back<span class="k2">(</span><span class="k2">)</span>.height<span class="k2">)</span>
<span class="number"> 64</span>  <span class="k2">{</span>
<span class="number"> 65</span>    <a href="http://www.allegro.cc/manual/al_set_new_bitmap_flags"><span class="a">al_set_new_bitmap_flags</span></a><span class="k2">(</span>ALLEGRO_MAXIMIZED<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 66</span>  <span class="k2">}</span>
<span class="number"> 67</span>  <span class="k1">else</span> <a href="http://www.allegro.cc/manual/al_set_new_bitmap_flags"><span class="a">al_set_new_bitmap_flags</span></a><span class="k2">(</span>ALLEGRO_WINDOWED<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 68</span>
<span class="number"> 69</span>  display <span class="k3">=</span> <a href="http://www.allegro.cc/manual/al_create_display"><span class="a">al_create_display</span></a><span class="k2">(</span>screenWidth, screenHeight<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 70</span>
<span class="number"> 71</span>  <span class="k1">if</span> <span class="k2">(</span><span class="k3">!</span>display<span class="k2">)</span>
<span class="number"> 72</span>  <span class="k2">{</span>
<span class="number"> 73</span>    axe::crash<span class="k2">(</span><span class="s">"Unable to create display at resolution %ix%i"</span>, screenWidth, screenHeight<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 74</span>    <span class="k1">return</span> <span class="n">1</span><span class="k2">;</span>
<span class="number"> 75</span>  <span class="k2">}</span>
<span class="number"> 76</span>
<span class="number"> 77</span>  <span class="k1">if</span> <span class="k2">(</span><span class="k3">!</span>fullscreen<span class="k2">)</span> centerWindow<span class="k2">(</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 78</span>
<span class="number"> 79</span>  <a href="http://www.allegro.cc/manual/al_init_image_addon"><span class="a">al_init_image_addon</span></a><span class="k2">(</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 80</span>  <a href="http://www.allegro.cc/manual/al_init_primitives_addon"><span class="a">al_init_primitives_addon</span></a><span class="k2">(</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 81</span>  <a href="http://www.allegro.cc/manual/al_init_font_addon"><span class="a">al_init_font_addon</span></a><span class="k2">(</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 82</span>  <a href="http://www.allegro.cc/manual/al_init_ttf_addon"><span class="a">al_init_ttf_addon</span></a><span class="k2">(</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 83</span>
<span class="number"> 84</span>  <a href="http://www.allegro.cc/manual/al_register_event_source"><span class="a">al_register_event_source</span></a><span class="k2">(</span>event_queue, <a href="http://www.allegro.cc/manual/al_get_display_event_source"><span class="a">al_get_display_event_source</span></a><span class="k2">(</span>display<span class="k2">)</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 85</span>
<span class="number"> 86</span>  <a href="http://www.delorie.com/djgpp/doc/libc/libc_624.html" target="_blank">printf</a><span class="k2">(</span><span class="s">"DrawEngine Initialized\n"</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 87</span>
<span class="number"> 88</span>  <span class="k1">return</span> <span class="n">0</span><span class="k2">;</span>
<span class="number"> 89</span><span class="k2">}</span>
</div></div><p>

I&#39;m going to quickly write up a minimal program to see if I can recreate the issue.<br />EDIT: I&#39;ve created a barebones program and I can call al_draw_text several hundred times per frame and still get 1000+ FPS using the exact same FPS calculation I am in my game. I must have done something wrong somewhere.
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (Aksel Huff)</author>
		<pubDate>Sun, 08 Jan 2017 11:01:33 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>It&#39;s a good idea to initialize every addon before creating a display. Do that all in a single init function once before you use your engine. You call init, and then you create a font. In init you create a display, so the font should be attached to a display.</p><div class="quote_container"><div class="title"><a href="http://www.allegro.cc/forums/thread/616680/1027604#target">Aksel Huff</a> said:</div><div class="quote"><p>
Also I&#39;ve just now noticed that lines 65 and 67 are using al_set_new_bitmap_flags rather than al_set_new_display_flags(). I haven&#39;t tested it yet, but I&#39;m guessing that is the culprit.
</p></div></div><p>
Yes, that&#39;s a problem. You should be calling <span class="source-code"><a href="http://www.allegro.cc/manual/al_set_new_display_flags"><span class="a">al_set_new_display_flags</span></a></span> there. Calling al_set_new_bitmap_flags with display flags is an error. There&#39;s a separate set of flags.
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (Edgar Reynaldo)</author>
		<pubDate>Mon, 09 Jan 2017 05:20:33 +0000</pubDate>
	</item>
</rss>
