<?xml version="1.0"?>
<rss version="2.0">
	<channel>
		<title>A5 : timer issue</title>
		<link>http://www.allegro.cc/forums/view/618870</link>
		<description>Allegro.cc Forum Thread</description>
		<webMaster>matthew@allegro.cc (Matthew Leverton)</webMaster>
		<lastBuildDate>Fri, 10 Nov 2023 00:50:48 +0000</lastBuildDate>
	</channel>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>Hi, I&#39;ve been trying to get to grips with the timer events and timers because I&#39;m trying to work on the speed of animations.</p><p>I wrote this 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="p">#include &lt;allegro5/allegro.h&gt;</span>
<span class="number">   2</span><span class="p">#include &lt;allegro5/allegro_primitives.h&gt;</span>
<span class="number">   3</span><span class="p">#include &lt;allegro5/allegro_image.h&gt;</span>
<span class="number">   4</span><span class="p">#include &lt;allegro5/allegro_font.h&gt;</span>
<span class="number">   5</span><span class="p">#include &lt;stdio.h&gt;</span>
<span class="number">   6</span><span class="p">#include &lt;stdlib.h&gt;</span>
<span class="number">   7</span>
<span class="number">   8</span>
<span class="number">   9</span>
<span class="number">  10</span>
<span class="number">  11</span>
<span class="number">  12</span><span class="k1">int</span> main<span class="k2">(</span><span class="k2">)</span>
<span class="number">  13</span><span class="k2">{</span>
<span class="number">  14</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> NULL<span class="k2">;</span>
<span class="number">  15</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> NULL<span class="k2">;</span>
<span class="number">  16</span>  
<span class="number">  17</span>    <a href="http://www.allegro.cc/manual/ALLEGRO_EVENT"><span class="a">ALLEGRO_EVENT</span></a> event<span class="k2">;</span>
<span class="number">  18</span>    
<span class="number">  19</span>  <span class="k1">int</span> loop_count <span class="k3">=</span> <span class="n">0</span><span class="k2">;</span>
<span class="number">  20</span>  <span class="k1">bool</span> got_loop_count <span class="k3">=</span> <span class="k1">false</span><span class="k2">;</span>
<span class="number">  21</span>  <span class="k1">bool</span> counting_loops <span class="k3">=</span> <span class="k1">false</span><span class="k2">;</span>
<span class="number">  22</span>  <span class="k1">int</span> timer_count_before <span class="k3">=</span> <span class="n">0</span><span class="k2">;</span>
<span class="number">  23</span>  <span class="k1">int</span> timer_count_after <span class="k3">=</span> <span class="n">0</span><span class="k2">;</span>
<span class="number">  24</span>  <span class="k1">int</span> time_counting <span class="k3">=</span> <span class="n">0</span><span class="k2">;</span>
<span class="number">  25</span>  
<span class="number">  26</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">  27</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_WINDOWED<span class="k2">)</span><span class="k2">;</span>
<span class="number">  28</span>  
<span class="number">  29</span>  <a href="http://www.allegro.cc/manual/ALLEGRO_EVENT_QUEUE"><span class="a">ALLEGRO_EVENT_QUEUE</span></a> <span class="k3">*</span>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">  30</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">0f</span><span class="k3">/</span><span class="n">120</span>.<span class="n">0f</span><span class="k2">)</span><span class="k2">;</span>
<span class="number">  31</span>  
<span class="number">  32</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">1600</span>, <span class="n">900</span><span class="k2">)</span><span class="k2">;</span>
<span class="number">  33</span>  <span class="k1">if</span><span class="k2">(</span>display <span class="k3">=</span><span class="k3">=</span> NULL<span class="k2">)</span>
<span class="number">  34</span>  <span class="k2">{</span>
<span class="number">  35</span>    <a href="http://www.delorie.com/djgpp/doc/libc/libc_624.html" target="_blank">printf</a><span class="k2">(</span><span class="s">"Couldn't create display."</span><span class="k2">)</span><span class="k2">;</span>
<span class="number">  36</span>  <span class="k2">}</span>
<span class="number">  37</span>  
<span class="number">  38</span>  <span class="k1">if</span><span class="k2">(</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="k3">=</span><span class="k3">=</span> <span class="k1">false</span><span class="k2">)</span>
<span class="number">  39</span>  <span class="k2">{</span>
<span class="number">  40</span>    <a href="http://www.delorie.com/djgpp/doc/libc/libc_624.html" target="_blank">printf</a><span class="k2">(</span><span class="s">"Couldn't initialise image addon."</span><span class="k2">)</span><span class="k2">;</span>
<span class="number">  41</span>  <span class="k2">}</span>
<span class="number">  42</span>  
<span class="number">  43</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">  44</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">  45</span>  
<span class="number">  46</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">  47</span>  
<span class="number">  48</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">  49</span>  
<span class="number">  50</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_font"><span class="a">al_load_font</span></a><span class="k2">(</span><span class="s">"fixed_font.tga"</span>, <span class="n">24</span>, <span class="n">0</span><span class="k2">)</span><span class="k2">;</span>
<span class="number">  51</span>  
<span class="number">  52</span>  
<span class="number">  53</span>  
<span class="number">  54</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>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">  55</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>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">  56</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>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">  57</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">  58</span>  
<span class="number">  59</span>  <a href="http://www.allegro.cc/manual/al_set_target_backbuffer"><span class="a">al_set_target_backbuffer</span></a><span class="k2">(</span>display<span class="k2">)</span><span class="k2">;</span>
<span class="number">  60</span>  
<span class="number">  61</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">  62</span>  
<span class="number">  63</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">  64</span>  
<span class="number">  65</span>  <span class="k1">while</span><span class="k2">(</span><span class="n">1</span><span class="k2">)</span>
<span class="number">  66</span>  <span class="k2">{</span>
<span class="number">  67</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>queue, <span class="k3">&amp;</span>event<span class="k2">)</span><span class="k2">;</span>
<span class="number">  68</span>    
<span class="number">  69</span>      <span class="k1">switch</span><span class="k2">(</span>event.type<span class="k2">)</span>
<span class="number">  70</span>      <span class="k2">{</span>
<span class="number">  71</span>        <span class="k1">case</span> ALLEGRO_EVENT_KEY_DOWN:
<span class="number">  72</span>          <span class="k1">if</span><span class="k2">(</span>event.keyboard.keycode <span class="k3">=</span><span class="k3">=</span> ALLEGRO_KEY_ESCAPE<span class="k2">)</span>
<span class="number">  73</span>          <span class="k2">{</span>  
<span class="number">  74</span>            <span class="k1">return</span> <span class="n">0</span><span class="k2">;</span>
<span class="number">  75</span>          <span class="k2">}</span>
<span class="number">  76</span>          <span class="k1">else</span> <span class="k1">if</span><span class="k2">(</span>event.keyboard.keycode <span class="k3">=</span><span class="k3">=</span> ALLEGRO_KEY_F1<span class="k2">)</span>
<span class="number">  77</span>          <span class="k2">{</span>
<span class="number">  78</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">  79</span>            <a href="http://www.delorie.com/djgpp/doc/libc/libc_624.html" target="_blank">printf</a><span class="k2">(</span><span class="s">"Program finished.\n\n"</span><span class="k2">)</span><span class="k2">;</span>
<span class="number">  80</span>            <a href="http://www.delorie.com/djgpp/doc/libc/libc_802.html" target="_blank">system</a><span class="k2">(</span><span class="s">"PAUSE"</span><span class="k2">)</span><span class="k2">;</span>
<span class="number">  81</span>            <span class="k1">return</span> <span class="n">0</span><span class="k2">;</span>
<span class="number">  82</span>          <span class="k2">}</span>
<span class="number">  83</span>          <span class="k1">break</span><span class="k2">;</span>
<span class="number">  84</span>        <span class="k1">case</span> ALLEGRO_EVENT_TIMER:
<span class="number">  85</span>        
<span class="number">  86</span>          <span class="k1">if</span><span class="k2">(</span>got_loop_count <span class="k3">=</span><span class="k3">=</span> <span class="k1">false</span><span class="k2">)</span>
<span class="number">  87</span>          <span class="k2">{</span>
<span class="number">  88</span>            <a href="http://www.delorie.com/djgpp/doc/libc/libc_624.html" target="_blank">printf</a><span class="k2">(</span><span class="s">"Got timer event.\n"</span><span class="k2">)</span><span class="k2">;</span>
<span class="number">  89</span>          <span class="k2">}</span>
<span class="number">  90</span>        
<span class="number">  91</span>          <span class="k1">if</span><span class="k2">(</span>counting_loops <span class="k3">=</span><span class="k3">=</span> <span class="k1">true</span><span class="k2">)</span>
<span class="number">  92</span>          <span class="k2">{</span>
<span class="number">  93</span>            timer_count_after <span class="k3">=</span> <a href="http://www.allegro.cc/manual/al_get_timer_count"><span class="a">al_get_timer_count</span></a><span class="k2">(</span>timer<span class="k2">)</span><span class="k2">;</span>
<span class="number">  94</span>            <a href="http://www.delorie.com/djgpp/doc/libc/libc_624.html" target="_blank">printf</a><span class="k2">(</span><span class="s">"timer count (second time) is %d.\n"</span>, timer_count_after<span class="k2">)</span><span class="k2">;</span>
<span class="number">  95</span>          
<span class="number">  96</span>          
<span class="number">  97</span>            time_counting <span class="k3">=</span> timer_count_after <span class="k3">-</span> timer_count_before<span class="k2">;</span>
<span class="number">  98</span>            got_loop_count <span class="k3">=</span> <span class="k1">true</span><span class="k2">;</span>
<span class="number">  99</span>            counting_loops <span class="k3">=</span> <span class="k1">false</span><span class="k2">;</span>
<span class="number"> 100</span>          <span class="k2">}</span>
<span class="number"> 101</span>        
<span class="number"> 102</span>          <span class="k1">if</span><span class="k2">(</span>counting_loops <span class="k3">=</span><span class="k3">=</span> <span class="k1">false</span> <span class="k3">&amp;</span><span class="k3">&amp;</span> got_loop_count <span class="k3">=</span><span class="k3">=</span> <span class="k1">false</span><span class="k2">)</span>
<span class="number"> 103</span>          <span class="k2">{</span>
<span class="number"> 104</span>            counting_loops <span class="k3">=</span> <span class="k1">true</span><span class="k2">;</span>
<span class="number"> 105</span>            timer_count_before <span class="k3">=</span> <a href="http://www.allegro.cc/manual/al_get_timer_count"><span class="a">al_get_timer_count</span></a><span class="k2">(</span>timer<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 106</span>            <a href="http://www.delorie.com/djgpp/doc/libc/libc_624.html" target="_blank">printf</a><span class="k2">(</span><span class="s">"timer count (first time) is %d.\n"</span>, timer_count_before<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 107</span>          <span class="k2">}</span>
<span class="number"> 108</span>        
<span class="number"> 109</span>          <span class="c">//al_flush_event_queue(queue);</span>
<span class="number"> 110</span>        
<span class="number"> 111</span>          <span class="k1">break</span><span class="k2">;</span>
<span class="number"> 112</span>        <span class="k1">case</span> ALLEGRO_EVENT_DISPLAY_CLOSE:
<span class="number"> 113</span>          <span class="k1">return</span> <span class="n">0</span><span class="k2">;</span>
<span class="number"> 114</span>          <span class="k1">break</span><span class="k2">;</span>
<span class="number"> 115</span>        default:
<span class="number"> 116</span>          <span class="k1">break</span><span class="k2">;</span>
<span class="number"> 117</span>      
<span class="number"> 118</span>      <span class="k2">}</span>
<span class="number"> 119</span>    
<span class="number"> 120</span>    
<span class="number"> 121</span>    <span class="c">//al_clear_to_color(al_map_rgb(0, 0, 0));</span>
<span class="number"> 122</span>    <span class="c">//al_draw_filled_circle(125, 384, 52.0f, al_map_rgb(255, 0, 0));</span>
<span class="number"> 123</span>    
<span class="number"> 124</span>    <span class="k1">if</span><span class="k2">(</span>got_loop_count <span class="k3">=</span><span class="k3">=</span> <span class="k1">true</span><span class="k2">)</span>
<span class="number"> 125</span>    <span class="k2">{</span>
<span class="number"> 126</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">30</span>, <span class="n">10</span>, <span class="n">0</span>, <span class="s">"Clock ticks = %d. Number of full loops : %d."</span>, time_counting, loop_count<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 127</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">30</span>, <span class="n">25</span>, <span class="n">0</span>, <span class="s">"Clock ticks before = %d. Clock ticks after = %d."</span>, timer_count_before, timer_count_after<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 128</span>    <span class="k2">}</span>
<span class="number"> 129</span>    
<span class="number"> 130</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"> 131</span>    
<span class="number"> 132</span>    <span class="k1">if</span><span class="k2">(</span>counting_loops <span class="k3">=</span><span class="k3">=</span> <span class="k1">true</span><span class="k2">)</span>
<span class="number"> 133</span>    <span class="k2">{</span>
<span class="number"> 134</span>      <a href="http://www.delorie.com/djgpp/doc/libc/libc_624.html" target="_blank">printf</a><span class="k2">(</span><span class="s">"Incrementing loop_count.\n"</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 135</span>      <span class="k3">+</span><span class="k3">+</span>loop_count<span class="k2">;</span>
<span class="number"> 136</span>    <span class="k2">}</span>
<span class="number"> 137</span>    
<span class="number"> 138</span>  <span class="k2">}</span>
<span class="number"> 139</span>  
<span class="number"> 140</span>  <span class="k1">return</span> <span class="n">0</span><span class="k2">;</span>
<span class="number"> 141</span>  
<span class="number"> 142</span><span class="k2">}</span>
</div></div><p>


I get this output :</p><p>Got timer event.<br />timer count (first time) is 4.<br />Incrementing loop_count.<br />Got timer event.<br />timer count (second time) is 4.</p><p>If someone would take the trouble to take a look at the code you might notice that despite the output confirming that a timer event and the ++loop_count; line have both occured imbetween the two points where al_get_timer_count is called the two calls to al_get_timer_count() both return 4. This doesn&#39;t make any sense to me. Does someone know why it&#39;s happening?
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (William Labbett)</author>
		<pubDate>Thu, 09 Nov 2023 03:13:12 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>Trying to wrap my head around what you have
</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">// a</span>
<span class="number">  2</span>          <span class="k1">if</span><span class="k2">(</span>got_loop_count <span class="k3">=</span><span class="k3">=</span> <span class="k1">false</span><span class="k2">)</span>
<span class="number">  3</span>          <span class="k2">{</span>
<span class="number">  4</span>            <a href="http://www.delorie.com/djgpp/doc/libc/libc_624.html" target="_blank">printf</a><span class="k2">(</span><span class="s">"Got timer event.\n"</span><span class="k2">)</span><span class="k2">;</span>
<span class="number">  5</span>          <span class="k2">}</span>
<span class="number">  6</span>   
<span class="number">  7</span>          <span class="c">// b     </span>
<span class="number">  8</span>          <span class="k1">if</span><span class="k2">(</span>counting_loops <span class="k3">=</span><span class="k3">=</span> <span class="k1">true</span><span class="k2">)</span>
<span class="number">  9</span>          <span class="k2">{</span>
<span class="number"> 10</span>            timer_count_after <span class="k3">=</span> <a href="http://www.allegro.cc/manual/al_get_timer_count"><span class="a">al_get_timer_count</span></a><span class="k2">(</span>timer<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 11</span>            <a href="http://www.delorie.com/djgpp/doc/libc/libc_624.html" target="_blank">printf</a><span class="k2">(</span><span class="s">"timer count (second time) is %d.\n"</span>, timer_count_after<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 12</span>          
<span class="number"> 13</span>          
<span class="number"> 14</span>            time_counting <span class="k3">=</span> timer_count_after <span class="k3">-</span> timer_count_before<span class="k2">;</span>
<span class="number"> 15</span>            got_loop_count <span class="k3">=</span> <span class="k1">true</span><span class="k2">;</span>
<span class="number"> 16</span>            counting_loops <span class="k3">=</span> <span class="k1">false</span><span class="k2">;</span>
<span class="number"> 17</span>          <span class="k2">}</span>
<span class="number"> 18</span>   
<span class="number"> 19</span>          <span class="c">// c     </span>
<span class="number"> 20</span>          <span class="k1">if</span><span class="k2">(</span>counting_loops <span class="k3">=</span><span class="k3">=</span> <span class="k1">false</span> <span class="k3">&amp;</span><span class="k3">&amp;</span> got_loop_count <span class="k3">=</span><span class="k3">=</span> <span class="k1">false</span><span class="k2">)</span>
<span class="number"> 21</span>          <span class="k2">{</span>
<span class="number"> 22</span>            counting_loops <span class="k3">=</span> <span class="k1">true</span><span class="k2">;</span>
<span class="number"> 23</span>            timer_count_before <span class="k3">=</span> <a href="http://www.allegro.cc/manual/al_get_timer_count"><span class="a">al_get_timer_count</span></a><span class="k2">(</span>timer<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 24</span>            <a href="http://www.delorie.com/djgpp/doc/libc/libc_624.html" target="_blank">printf</a><span class="k2">(</span><span class="s">"timer count (first time) is %d.\n"</span>, timer_count_before<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 25</span>          <span class="k2">}</span>
</div></div><p>

<b>start</b>: glc = false, cl = false;</p><p><b>1st iteration</b>: a printed, b ignored, c processed<br />cl = true, glc = false, tcb is set</p><p>cl is true so loop_count increments once</p><p><b>2nd iteration</b>: a printed, b processed, c ignored<br />cl = false, glc = true, tca is set, tc is calculated (tca-tcb)</p><p>cl is false and will always be false after this point<br />loop_count not incremented.</p><p><b>3rd iteration</b>: a ignored, b ignored, c ignored</p><p>Nothing happens after that because cl is false and glc is true</p><p>What is it supposed to do?
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (DanielH)</author>
		<pubDate>Thu, 09 Nov 2023 04:22:53 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>Your code doesn&#39;t really make sense. Keep it simple. Allegro has everything you need in the timer event itself.</p><div class="source-code snippet"><div class="inner"><pre><span class="k1">do</span> <span class="k2">{</span>
   <a href="http://www.allegro.cc/manual/ALLEGRO_EVENT"><span class="a">ALLEGRO_EVENT</span></a> ev<span class="k2">;</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>queue , <span class="k3">&amp;</span>ev<span class="k2">)</span><span class="k2">;</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>
      old_ticks <span class="k3">=</span> tick_count<span class="k2">;</span>
      tick_count <span class="k3">=</span> ev.timer.count<span class="k2">;</span><span class="c">/** forgive I can't remember if this is right*/</span>
      do_stuff_with_ticks<span class="k2">(</span>tick_count <span class="k3">-</span> old_ticks<span class="k2">)</span><span class="k2">;</span>
   <span class="k2">}</span>
   <span class="k1">else</span> <span class="k2">{</span>...<span class="k2">}</span>
   
<span class="k2">}</span> <span class="k1">while</span> <span class="k2">(</span><span class="k3">!</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>queue<span class="k2">)</span><span class="k2">;</span>
</pre></div></div><p>
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (Edgar Reynaldo)</author>
		<pubDate>Thu, 09 Nov 2023 08:53:59 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>No, the code isn&#39;t familiar but it makes perfect sense. It does exactly what Daniel described. Thenks Daniel for working it out.</p><p>What it&#39;s meant to do is simple :</p><p>It calculates how many clock ticks it takes to run the code after the event loop.<br />I need to know this because I need to how frequently my drawing code gets executed. (I simplified the program and left out the drawing code).</p><p>So it makes a record of the timer count. Then it does one run of the code after<br />the event loop. Then when the code gets back to the event loop it waits for the next timer event and records the count.</p><p>What doesn&#39;t make sense it that according to the event queue there&#39;s a new timer tick but the timer count hasn&#39;t changed. The manual does say that once al_wait_for_event get&#39;s an event it copies the event into the ALLEGRO_EVENT * provided and removes it from the queue so the next ALLEGRO_EVENT_TIMER should be a new clock tick meaning the number returned from al_get_timer_count should be larger.</p><p>BTW If I call al_flush_event_queue which shouldn&#39;t be necessary the code works as expected.
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (William Labbett)</author>
		<pubDate>Thu, 09 Nov 2023 17:44:23 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>Don&#39;t use al_get_timer_count. That is supposed to be always up to date. Use the tick count from the event. If you need to profile, use a high performance timer. There is one available in Eagle.
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (Edgar Reynaldo)</author>
		<pubDate>Thu, 09 Nov 2023 21:13:45 +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/618870/1053963#target">William Labbett</a> said:</div><div class="quote"><p> I need to know this because I need to how frequently my drawing code gets executed. (I simplified the program and left out the drawing code).</p></div></div><p>How frequently compared to your logic timer? Or do you want an FPS counter?</p><p>Normally you would just draw once per logic update. And maybe skip the drawing when the event queue is not empty after the logic is done to avoid getting behind.
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (torhu)</author>
		<pubDate>Thu, 09 Nov 2023 23:59:33 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>Thanks very much to both of you.</p><div class="quote_container"><div class="title"><a href="http://www.allegro.cc/forums/thread/618870/1053965#target">torhu</a> said:</div><div class="quote"><p>How frequently compared to your logic timer?</p></div></div><p>

It&#39;s got to be only as frequent or less frequent right? If it can&#39;t be more frequent I&#39;d have to decrease the ticks_per_second passed to al_create_timer() EDIT : if I wanted to slow down the graphics updating ?.</p><p>I did also want an FPS counter and I figured that was sort of what I was doing in a not so normal way.
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (William Labbett)</author>
		<pubDate>Fri, 10 Nov 2023 00:43:24 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p><span class="source-code"><a href="http://www.allegro.cc/manual/al_wait_for_event"><span class="a">al_wait_for_event</span></a></span> will limit your frame counter to events. If you want to calculate FPS then draw every loop iteration and only process an event if there is an event.</p><p>Check out my <a href="https://github.com/dlharmon911/TicTacToe">Tic Tac Toe</a> game. I don&#39;t wait for events.</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">void</span> App::processInput<span class="k2">(</span><span class="k2">)</span>
<span class="number">  2</span><span class="k2">{</span>
<span class="number">  3</span>  <span class="k1">static</span> <a href="http://www.allegro.cc/manual/ALLEGRO_EVENT"><span class="a">ALLEGRO_EVENT</span></a> event<span class="k2">;</span>
<span class="number">  4</span>
<span class="number">  5</span>  <span class="k1">while</span> <span class="k2">(</span><span class="k3">!</span>al_event_queue_is_empty<span class="k2">(</span>this-&gt;m_queue<span class="k2">)</span><span class="k2">)</span>
<span class="number">  6</span>  <span class="k2">{</span>
<span class="number">  7</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>this-&gt;m_queue, <span class="k3">&amp;</span>event<span class="k2">)</span><span class="k2">;</span>
<span class="number">  8</span>
<span class="number">  9</span>    <span class="k1">switch</span> <span class="k2">(</span>event.type<span class="k2">)</span>
<span class="number"> 10</span>    <span class="k2">{</span>
<span class="number"> 11</span>    <span class="k1">case</span> ALLEGRO_EVENT_TIMER:
<span class="number"> 12</span>    <span class="k2">{</span>
<span class="number"> 13</span>      <span class="k3">+</span><span class="k3">+</span>this-&gt;m_counter<span class="k2">;</span>
<span class="number"> 14</span>    <span class="k2">}</span> <span class="k1">break</span><span class="k2">;</span>
<span class="number"> 15</span><span class="c">// ...</span>
<span class="number"> 16</span><span class="k2">}</span>
<span class="number"> 17</span>
<span class="number"> 18</span>
<span class="number"> 19</span><span class="k1">int32_t</span> App::loop<span class="k2">(</span><span class="k2">)</span>
<span class="number"> 20</span><span class="k2">{</span>
<span class="number"> 21</span>  <span class="k1">while</span> <span class="k2">(</span><span class="k3">!</span>this-&gt;m_kill<span class="k2">)</span>
<span class="number"> 22</span>  <span class="k2">{</span>
<span class="number"> 23</span>    this-&gt;processInput<span class="k2">(</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 24</span>
<span class="number"> 25</span>    <span class="k1">while</span> <span class="k2">(</span>this-&gt;m_counter <span class="k3">&gt;</span> <span class="n">0</span><span class="k2">)</span>
<span class="number"> 26</span>    <span class="k2">{</span>
<span class="number"> 27</span>      this-&gt;doLogic<span class="k2">(</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 28</span>      <span class="k3">-</span><span class="k3">-</span>this-&gt;m_counter<span class="k2">;</span>
<span class="number"> 29</span>    <span class="k2">}</span>
<span class="number"> 30</span>
<span class="number"> 31</span>    <span class="k1">if</span> <span class="k2">(</span>this-&gt;m_dirty<span class="k2">)</span>
<span class="number"> 32</span>    <span class="k2">{</span>
<span class="number"> 33</span>      this-&gt;draw<span class="k2">(</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 34</span>      this-&gt;m_dirty <span class="k3">=</span> <span class="k1">false</span><span class="k2">;</span>
<span class="number"> 35</span>    <span class="k2">}</span>
<span class="number"> 36</span>
<span class="number"> 37</span>    <a href="http://www.allegro.cc/manual/al_rest"><span class="a">al_rest</span></a><span class="k2">(</span><span class="n">0</span>.<span class="n">01</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 38</span>  <span class="k2">}</span>
<span class="number"> 39</span>
<span class="number"> 40</span>  <span class="k1">return</span> <span class="n">0</span><span class="k2">;</span>
<span class="number"> 41</span><span class="k2">}</span>
</div></div><p>

You could remove the &#39;dirty&#39; check and add a couple vars (frames and seconds). At each draw, increment a frame counter. At each timer increment a seconds counter. FPS = frames/second;
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (DanielH)</author>
		<pubDate>Fri, 10 Nov 2023 00:50:48 +0000</pubDate>
	</item>
</rss>
