<?xml version="1.0"?>
<rss version="2.0">
	<channel>
		<title>[al_draw_text] really slow</title>
		<link>http://www.allegro.cc/forums/view/608131</link>
		<description>Allegro.cc Forum Thread</description>
		<webMaster>matthew@allegro.cc (Matthew Leverton)</webMaster>
		<lastBuildDate>Sat, 20 Aug 2011 02:05:54 +0000</lastBuildDate>
	</channel>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>Hi, i&#39;m having problems with displaying text with Allegro 5. Whenever i display a text in screen, the framerate drops from ~60 to ~12.</p><p>Here is an example i made where this is happening:</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="p">#include &lt;stdio.h&gt;</span>
<span class="number">  2</span><span class="p">#include &lt;allegro5/allegro.h&gt;</span>
<span class="number">  3</span><span class="p">#include &lt;allegro5/allegro_font.h&gt;</span>
<span class="number">  4</span><span class="p">#include &lt;allegro5/allegro_ttf.h&gt;</span>
<span class="number">  5</span>
<span class="number">  6</span><span class="k1">const</span> <span class="k1">int</span> FPS <span class="k3">=</span> <span class="n">60</span><span class="k2">;</span>
<span class="number">  7</span><span class="k1">int</span> main<span class="k2">(</span><span class="k2">)</span>
<span class="number">  8</span><span class="k2">{</span>
<span class="number">  9</span>    <a href="http://www.allegro.cc/manual/al_init"><span class="a">al_init</span></a><span class="k2">(</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 10</span>
<span class="number"> 11</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"> 12</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"> 13</span>    <a href="http://www.allegro.cc/manual/al_install_keyboard"><span class="a">al_install_keyboard</span></a><span class="k2">(</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 14</span>
<span class="number"> 15</span>    <a href="http://www.allegro.cc/manual/ALLEGRO_EVENT_QUEUE"><span class="a">ALLEGRO_EVENT_QUEUE</span></a><span class="k3">*</span> event_queue <span class="k3">=</span> <a href="http://www.allegro.cc/manual/al_create_event_queue"><span class="a">al_create_event_queue</span></a><span class="k2">(</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 16</span>    <a href="http://www.allegro.cc/manual/ALLEGRO_TIMER"><span class="a">ALLEGRO_TIMER</span></a><span class="k3">*</span> timer <span class="k3">=</span> <a href="http://www.allegro.cc/manual/al_create_timer"><span class="a">al_create_timer</span></a><span class="k2">(</span><span class="n">1</span>.<span class="n">0</span> <span class="k3">/</span> FPS<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 17</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_keyboard_event_source"><span class="a">al_get_keyboard_event_source</span></a><span class="k2">(</span><span class="k2">)</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 18</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_timer_event_source"><span class="a">al_get_timer_event_source</span></a><span class="k2">(</span>timer<span class="k2">)</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 19</span>
<span class="number"> 20</span>    <a href="http://www.allegro.cc/manual/ALLEGRO_DISPLAY"><span class="a">ALLEGRO_DISPLAY</span></a> <span class="k3">*</span>display <span class="k3">=</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><span class="n">640</span>,<span class="n">480</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 21</span>  <a href="http://www.allegro.cc/manual/ALLEGRO_FONT"><span class="a">ALLEGRO_FONT</span></a>    <span class="k3">*</span><a href="http://www.allegro.cc/manual/font"><span class="a">font</span></a>    <span class="k3">=</span> <a href="http://www.allegro.cc/manual/al_load_ttf_font"><span class="a">al_load_ttf_font</span></a><span class="k2">(</span><span class="s">"ARIAL.ttf"</span>,<span class="n">20</span>,<span class="n">0</span> <span class="k2">)</span><span class="k2">;</span>
<span class="number"> 22</span>
<span class="number"> 23</span>  <a href="http://www.allegro.cc/manual/ALLEGRO_BITMAP"><span class="a">ALLEGRO_BITMAP</span></a><span class="k3">*</span> text_img <span class="k3">=</span> <a href="http://www.allegro.cc/manual/al_create_bitmap"><span class="a">al_create_bitmap</span></a><span class="k2">(</span><a href="http://www.allegro.cc/manual/al_get_text_width"><span class="a">al_get_text_width</span></a><span class="k2">(</span><a href="http://www.allegro.cc/manual/font"><span class="a">font</span></a>,<span class="s">"HelloWorld!"</span><span class="k2">)</span>, <a href="http://www.allegro.cc/manual/al_get_font_ascent"><span class="a">al_get_font_ascent</span></a><span class="k2">(</span><a href="http://www.allegro.cc/manual/font"><span class="a">font</span></a><span class="k2">)</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 24</span>  <a href="http://www.allegro.cc/manual/al_set_target_bitmap"><span class="a">al_set_target_bitmap</span></a><span class="k2">(</span>text_img<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 25</span>  <a href="http://www.allegro.cc/manual/al_clear_to_color"><span class="a">al_clear_to_color</span></a><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"> 26</span>  <a href="http://www.allegro.cc/manual/al_draw_text"><span class="a">al_draw_text</span></a><span class="k2">(</span><a href="http://www.allegro.cc/manual/font"><span class="a">font</span></a>,<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>, <span class="n">0</span>,<span class="n">0</span>,<span class="n">0</span>,<span class="s">"HelloWorld!"</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 27</span>  <a href="http://www.allegro.cc/manual/al_set_target_bitmap"><span class="a">al_set_target_bitmap</span></a><span class="k2">(</span><a href="http://www.allegro.cc/manual/al_get_backbuffer"><span class="a">al_get_backbuffer</span></a><span class="k2">(</span>display<span class="k2">)</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 28</span>
<span class="number"> 29</span>    <span class="k1">char</span> is_pressed_space <span class="k3">=</span> <span class="k1">false</span><span class="k2">;</span>
<span class="number"> 30</span>    <span class="k1">char</span> is_pressed_enter <span class="k3">=</span> <span class="k1">false</span><span class="k2">;</span>
<span class="number"> 31</span>
<span class="number"> 32</span>  <span class="k1">int</span> TT <span class="k3">=</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="number"> 33</span>  <span class="k1">int</span> fps<span class="k3">=</span><span class="n">0</span>, fps_temp<span class="k3">=</span><span class="n">0</span><span class="k2">;</span>
<span class="number"> 34</span>
<span class="number"> 35</span>  <a href="http://www.allegro.cc/manual/al_clear_to_color"><span class="a">al_clear_to_color</span></a><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"> 36</span>
<span class="number"> 37</span>    <a href="http://www.allegro.cc/manual/al_flip_display"><span class="a">al_flip_display</span></a><span class="k2">(</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 38</span>    <a href="http://www.allegro.cc/manual/al_start_timer"><span class="a">al_start_timer</span></a><span class="k2">(</span>timer<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 39</span>
<span class="number"> 40</span>  <span class="k1">int</span> redraw <span class="k3">=</span> <span class="k1">false</span><span class="k2">;</span>
<span class="number"> 41</span>    <span class="k1">while</span><span class="k2">(</span><span class="n">1</span><span class="k2">)</span><span class="k2">{</span>
<span class="number"> 42</span>
<span class="number"> 43</span>
<span class="number"> 44</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"> 45</span>       <a href="http://www.allegro.cc/manual/al_wait_for_event"><span class="a">al_wait_for_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="number"> 46</span>       <span class="k1">if</span><span class="k2">(</span>ev.type <span class="k3">=</span><span class="k3">=</span> ALLEGRO_EVENT_TIMER<span class="k2">)</span> <span class="k2">{</span>
<span class="number"> 47</span>         redraw <span class="k3">=</span> <span class="k1">true</span><span class="k2">;</span>
<span class="number"> 48</span>       <span class="k2">}</span>
<span class="number"> 49</span>       <span class="k1">if</span><span class="k2">(</span>ev.type <span class="k3">=</span><span class="k3">=</span> ALLEGRO_EVENT_KEY_DOWN<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>ev.keyboard.keycode<span class="k3">=</span><span class="k3">=</span>ALLEGRO_KEY_SPACE<span class="k2">)</span>
<span class="number"> 52</span>      is_pressed_space<span class="k3">=</span><span class="k1">true</span><span class="k2">;</span>
<span class="number"> 53</span>    <span class="k1">if</span> <span class="k2">(</span>ev.keyboard.keycode<span class="k3">=</span><span class="k3">=</span>ALLEGRO_KEY_ENTER<span class="k2">)</span>
<span class="number"> 54</span>      is_pressed_enter<span class="k3">=</span><span class="k1">true</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>ev.type <span class="k3">=</span><span class="k3">=</span> ALLEGRO_EVENT_KEY_UP<span class="k2">)</span>
<span class="number"> 57</span>       <span class="k2">{</span>
<span class="number"> 58</span>    <span class="k1">if</span> <span class="k2">(</span>ev.keyboard.keycode<span class="k3">=</span><span class="k3">=</span>ALLEGRO_KEY_SPACE<span class="k2">)</span>
<span class="number"> 59</span>      is_pressed_space<span class="k3">=</span><span class="k1">false</span><span class="k2">;</span>
<span class="number"> 60</span>    <span class="k1">if</span> <span class="k2">(</span>ev.keyboard.keycode<span class="k3">=</span><span class="k3">=</span>ALLEGRO_KEY_ENTER<span class="k2">)</span>
<span class="number"> 61</span>      is_pressed_enter<span class="k3">=</span><span class="k1">false</span><span class="k2">;</span>
<span class="number"> 62</span>    <span class="k1">if</span> <span class="k2">(</span>ev.keyboard.keycode<span class="k3">=</span><span class="k3">=</span>ALLEGRO_KEY_ESCAPE<span class="k2">)</span>
<span class="number"> 63</span>      <span class="k1">break</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>redraw <span class="k3">&amp;</span><span class="k3">&amp;</span> <a href="http://www.allegro.cc/manual/al_is_event_queue_empty"><span class="a">al_is_event_queue_empty</span></a><span class="k2">(</span>event_queue<span class="k2">)</span><span class="k2">)</span>
<span class="number"> 67</span>        <span class="k2">{</span>
<span class="number"> 68</span>         redraw <span class="k3">=</span> <span class="k1">false</span><span class="k2">;</span>
<span class="number"> 69</span>
<span class="number"> 70</span>         <a href="http://www.allegro.cc/manual/al_clear_to_color"><span class="a">al_clear_to_color</span></a><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"> 71</span>       <span class="k1">if</span> <span class="k2">(</span>is_pressed_space<span class="k2">)</span>
<span class="number"> 72</span>         <a href="http://www.allegro.cc/manual/al_draw_textf"><span class="a">al_draw_textf</span></a><span class="k2">(</span><a href="http://www.allegro.cc/manual/font"><span class="a">font</span></a>,<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>, <span class="n">100</span>,<span class="n">100</span>,<span class="n">0</span>,<span class="s">"FPS: %d"</span>,fps<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 73</span>     <span class="k1">if</span> <span class="k2">(</span>is_pressed_enter<span class="k2">)</span>
<span class="number"> 74</span>       <a href="http://www.allegro.cc/manual/al_draw_bitmap"><span class="a">al_draw_bitmap</span></a><span class="k2">(</span>text_img, <span class="n">200</span>, <span class="n">200</span>, <span class="n">0</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 75</span>         <a href="http://www.allegro.cc/manual/al_flip_display"><span class="a">al_flip_display</span></a><span class="k2">(</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 76</span>
<span class="number"> 77</span>         fps_temp<span class="k3">+</span><span class="k3">+</span><span class="k2">;</span>
<span class="number"> 78</span>         <span class="k1">int</span> tt <span class="k3">=</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="number"> 79</span>         <span class="k1">if</span> <span class="k2">(</span>tt <span class="k3">!</span><span class="k3">=</span> TT<span class="k2">)</span>
<span class="number"> 80</span>         <span class="k2">{</span>
<span class="number"> 81</span>           TT<span class="k3">=</span>tt<span class="k2">;</span>
<span class="number"> 82</span>           fps <span class="k3">=</span> fps_temp<span class="k2">;</span>
<span class="number"> 83</span>           fps_temp<span class="k3">=</span><span class="n">0</span><span class="k2">;</span>
<span class="number"> 84</span>           <a href="http://www.delorie.com/djgpp/doc/libc/libc_624.html" target="_blank">printf</a><span class="k2">(</span><span class="s">"%d\n"</span>,fps<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 85</span>         <span class="k2">}</span>
<span class="number"> 86</span>      <span class="k2">}</span>
<span class="number"> 87</span>
<span class="number"> 88</span>
<span class="number"> 89</span>
<span class="number"> 90</span>    <span class="k2">}</span>
<span class="number"> 91</span>    <a href="http://www.allegro.cc/manual/al_destroy_display"><span class="a">al_destroy_display</span></a><span class="k2">(</span>display<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 92</span>    <span class="k1">return</span> <span class="n">0</span><span class="k2">;</span>
<span class="number"> 93</span><span class="k2">}</span>
</div></div><p>
When nothing is being shown the fps is 60, and it doesn&#39;t change when i show the bitmap, but when i show the text it is 12-13.</p><p>I&#39;m linking with liballegro-5.0.4-monolith-md-debug.a, but i&#39;ve also tried with the other options, but no change.<br />I&#39;m using a slow netbook (1.4Ghz), but i&#39;ve never experienced anything like this with Allegro4
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (nicolas_l)</author>
		<pubDate>Fri, 19 Aug 2011 18:40:43 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>What video card does it have? Attaching the allegro.log file may help.</p><p>If you draw this text beforehand (to cache things), does it speed it up: &quot;FPS: 0123456789&quot;?
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (Matthew Leverton)</author>
		<pubDate>Fri, 19 Aug 2011 19:10:12 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>it has a integrated Intel GMA500 (it&#39;s not a good card, and it sucks in openGL (could that be the cause?))</p><p>drawing the text before doesn&#39;t change anything</p><p>I&#39;ve attached allegro.log
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (nicolas_l)</author>
		<pubDate>Fri, 19 Aug 2011 19:37:17 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>It&#39;s using Direct3D at the moment. You can try OpenGL:</p><div class="source-code snippet"><div class="inner"><pre><span class="p">#include &lt;allegro5/allegro_opengl.h&gt;</span>

<span class="c">//...</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_OPENGL<span class="k2">)</span><span class="k2">;</span>
<a href="http://www.allegro.cc/manual/al_create_display"><span class="a">al_create_display</span></a><span class="k2">(</span> ... <span class="k2">)</span><span class="k2">;</span>
</pre></div></div><p>
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (Matthew Leverton)</author>
		<pubDate>Fri, 19 Aug 2011 19:44:46 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>Ok. But with OpenGL the program won&#39;t start (but that is becouse the computer, i&#39;ve had problems with other openGL games (advice: never buy an netbook with gma500)
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (nicolas_l)</author>
		<pubDate>Fri, 19 Aug 2011 20:14:35 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><div class="quote_container"><div class="title"><a href="http://www.allegro.cc/forums/thread/608131/928639#target">nicolas_l</a> said:</div><div class="quote"><p>
</p><div class="source-code snippet"><div class="inner"><pre>   <a href="http://www.allegro.cc/manual/ALLEGRO_DISPLAY"><span class="a">ALLEGRO_DISPLAY</span></a> <span class="k3">*</span>display <span class="k3">=</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><span class="n">640</span>,<span class="n">480</span><span class="k2">)</span><span class="k2">;</span>
</pre></div></div><p>
</p></div></div><p>
The compiler says that line is undefined - one too many &#39;display&#39;s there.</p><p>I compiled your program against Allegro 5.1 SVN and had no problems at all using consola.ttf. It all ran at 60 fps. This was on a 2.1Ghz dual core Turion 64 laptop with integrated ATI Radeon X1270 though.</p><p>Oh, and please fix your code formatting next time - it&#39;s really hard to read.
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (Edgar Reynaldo)</author>
		<pubDate>Sat, 20 Aug 2011 02:05:54 +0000</pubDate>
	</item>
</rss>
