<?xml version="1.0"?>
<rss version="2.0">
	<channel>
		<title>Help with Flood Fill Algorithm</title>
		<link>http://www.allegro.cc/forums/view/611690</link>
		<description>Allegro.cc Forum Thread</description>
		<webMaster>matthew@allegro.cc (Matthew Leverton)</webMaster>
		<lastBuildDate>Tue, 25 Dec 2012 04:05:23 +0000</lastBuildDate>
	</channel>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>I am trying to write a flood fill algorithm using Allegro 5.0.7.  Logically, my code should be working, but for some reason I don&#39;t think the set_pixel is being applied.  The only thing I can think is the Allegro functions aren&#39;t doing what I think they are doing.  My IDE is Visual C++ 2010.  Can anyone help?</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="number">  2</span><span class="k1">void</span> FloodFill<span class="k2">(</span>Point s, <a href="http://www.allegro.cc/manual/ALLEGRO_COLOR"><span class="a">ALLEGRO_COLOR</span></a> newClr<span class="k2">)</span>
<span class="number">  3</span><span class="k2">{</span>
<span class="number">  4</span>  <a href="http://www.allegro.cc/manual/al_lock_bitmap"><span class="a">al_lock_bitmap</span></a><span class="k2">(</span>FOCUS,ALLEGRO_PIXEL_FORMAT_ANY,ALLEGRO_LOCK_READWRITE<span class="k2">)</span><span class="k2">;</span>
<span class="number">  5</span>  <a href="http://www.allegro.cc/manual/ALLEGRO_COLOR"><span class="a">ALLEGRO_COLOR</span></a> oldClr <span class="k3">=</span> <a href="http://www.allegro.cc/manual/al_get_pixel"><span class="a">al_get_pixel</span></a><span class="k2">(</span>FOCUS,s.X,s.Y<span class="k2">)</span><span class="k2">;</span>
<span class="number">  6</span>  <span class="k1">if</span> <span class="k2">(</span>oldClr.r <span class="k3">=</span><span class="k3">=</span> newClr.r <span class="k3">&amp;</span><span class="k3">&amp;</span>
<span class="number">  7</span>      oldClr.g <span class="k3">=</span><span class="k3">=</span> newClr.g <span class="k3">&amp;</span><span class="k3">&amp;</span>
<span class="number">  8</span>      oldClr.b <span class="k3">=</span><span class="k3">=</span> newClr.b <span class="k3">&amp;</span><span class="k3">&amp;</span>
<span class="number">  9</span>      oldClr.a <span class="k3">=</span><span class="k3">=</span> newClr.a<span class="k2">)</span> <span class="k2">{</span> <span class="k1">return</span><span class="k2">;</span> <span class="k2">}</span>
<span class="number"> 10</span>
<span class="number"> 11</span>  stack<span class="k3">&lt;</span>Point&gt; ptsCollection<span class="k2">;</span>
<span class="number"> 12</span>  ptsCollection.push<span class="k2">(</span>s<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 13</span>
<span class="number"> 14</span>  <a href="http://www.allegro.cc/manual/al_draw_pixel"><span class="a">al_draw_pixel</span></a><span class="k2">(</span>s.X,s.Y,newClr<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 15</span>
<span class="number"> 16</span>  <span class="k1">while</span> <span class="k2">(</span><span class="k3">!</span>ptsCollection.empty<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>    Point nPt <span class="k3">=</span> ptsCollection.top<span class="k2">(</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 19</span>    ptsCollection.pop<span class="k2">(</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 20</span>    
<span class="number"> 21</span>    <span class="k1">if</span> <span class="k2">(</span>nPt.X <span class="k3">&gt;</span> <span class="n">0</span><span class="k2">)</span> ProcessPoint<span class="k2">(</span>ptsCollection, nPt.X-1, nPt.Y, oldClr, newClr<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 22</span>    <span class="k1">if</span> <span class="k2">(</span>nPt.Y <span class="k3">&gt;</span> <span class="n">0</span><span class="k2">)</span> ProcessPoint<span class="k2">(</span>ptsCollection, nPt.X, nPt.Y-1, oldClr, newClr<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 23</span>    <span class="k1">if</span> <span class="k2">(</span>nPt.X <span class="k3">&lt;</span> <a href="http://www.allegro.cc/manual/al_get_bitmap_width"><span class="a">al_get_bitmap_width</span></a><span class="k2">(</span>FOCUS<span class="k2">)</span><span class="k3">-</span><span class="n">1</span><span class="k2">)</span> ProcessPoint<span class="k2">(</span>ptsCollection, nPt.X<span class="k3">+</span><span class="n">1</span>, nPt.Y, oldClr, newClr<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 24</span>    <span class="k1">if</span> <span class="k2">(</span>nPt.Y <span class="k3">&lt;</span> <a href="http://www.allegro.cc/manual/al_get_bitmap_height"><span class="a">al_get_bitmap_height</span></a><span class="k2">(</span>FOCUS<span class="k2">)</span><span class="k3">-</span><span class="n">1</span><span class="k2">)</span> ProcessPoint<span class="k2">(</span>ptsCollection, nPt.X,nPt.Y<span class="k3">+</span><span class="n">1</span>, oldClr, newClr<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 25</span>  <span class="k2">}</span>
<span class="number"> 26</span>  <a href="http://www.allegro.cc/manual/al_unlock_bitmap"><span class="a">al_unlock_bitmap</span></a><span class="k2">(</span>FOCUS<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 27</span><span class="k2">}</span>
<span class="number"> 28</span>
<span class="number"> 29</span><span class="k1">void</span> ProcessPoint<span class="k2">(</span>stack<span class="k3">&lt;</span>Point&gt;<span class="k3">&amp;</span> ptsCollection, <span class="k1">int</span> X, <span class="k1">int</span> Y, <a href="http://www.allegro.cc/manual/ALLEGRO_COLOR"><span class="a">ALLEGRO_COLOR</span></a> oClr, <a href="http://www.allegro.cc/manual/ALLEGRO_COLOR"><span class="a">ALLEGRO_COLOR</span></a> nClr<span class="k2">)</span>
<span class="number"> 30</span><span class="k2">{</span>
<span class="number"> 31</span>  <a href="http://www.allegro.cc/manual/ALLEGRO_COLOR"><span class="a">ALLEGRO_COLOR</span></a> tempClr <span class="k3">=</span> <a href="http://www.allegro.cc/manual/al_get_pixel"><span class="a">al_get_pixel</span></a><span class="k2">(</span>FOCUS,X,Y<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 32</span>  <span class="k1">if</span> <span class="k2">(</span>tempClr.r <span class="k3">=</span><span class="k3">=</span> oClr.r <span class="k3">&amp;</span><span class="k3">&amp;</span>
<span class="number"> 33</span>      tempClr.g <span class="k3">=</span><span class="k3">=</span> oClr.g <span class="k3">&amp;</span><span class="k3">&amp;</span>
<span class="number"> 34</span>      tempClr.b <span class="k3">=</span><span class="k3">=</span> oClr.b <span class="k3">&amp;</span><span class="k3">&amp;</span>
<span class="number"> 35</span>      tempClr.a <span class="k3">=</span><span class="k3">=</span> oClr.a<span class="k2">)</span>
<span class="number"> 36</span>  <span class="k2">{</span>
<span class="number"> 37</span>    ptsCollection.push<span class="k2">(</span>Point<span class="k2">(</span>X,Y<span class="k2">)</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 38</span>    cout <span class="k3">&lt;</span><span class="k3">&lt;</span> X <span class="k3">&lt;</span><span class="k3">&lt;</span> <span class="s">", "</span> <span class="k3">&lt;</span><span class="k3">&lt;</span> Y <span class="k3">&lt;</span><span class="k3">&lt;</span> <span class="s">"\n"</span><span class="k2">;</span>
<span class="number"> 39</span>    <a href="http://www.allegro.cc/manual/al_draw_pixel"><span class="a">al_draw_pixel</span></a><span class="k2">(</span>X,Y,nClr<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 40</span>  <span class="k2">}</span>
<span class="number"> 41</span><span class="k2">}</span>
</div></div><p>
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (HellfireXP)</author>
		<pubDate>Tue, 25 Dec 2012 00:07:39 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>Assuming your algorithm is correct and you are seeing your <span class="source-code">cout</span> lines...</p><p>Are you sure that you have called <span class="source-code"><a href="http://www.allegro.cc/manual/al_set_target_bitmap"><span class="a">al_set_target_bitmap</span></a><span class="k2">(</span><span class="k2">)</span></span> on the appropriate bitmap?</p><p>Are you then drawing that bitmap to the back buffer?
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (Matthew Leverton)</author>
		<pubDate>Tue, 25 Dec 2012 00:52:52 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>I&#39;d also use al_put_pixel, al_draw_pixel isn&#39;t really supposed to do much on a locked bitmap I think (at least the other al_draw_* functions aren&#39;t).
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (Elias)</author>
		<pubDate>Tue, 25 Dec 2012 02:25:38 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>Thanks guys.  The solution that worked was changing al_draw_pixel to al_put_pixel.  I had the cout &lt;&lt; in there just to try and see where my error was - I didn&#39;t plan on leaving it.</p><p>One thing I noticed was that all the coordinates kept being added to the stack over and over; thus none of them were applying the color to the bitmap or they&#39;d have been removed.  Good to know for future application - I&#39;ll use al_put_pixel instead. <img src="http://www.allegro.cc/forums/smileys/smiley.gif" alt=":)" /></p><p>Thanks.:D
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (HellfireXP)</author>
		<pubDate>Tue, 25 Dec 2012 04:05:23 +0000</pubDate>
	</item>
</rss>
