<?xml version="1.0"?>
<rss version="2.0">
	<channel>
		<title>[A5] how to draw a rectangle filled with a gradient?</title>
		<link>http://www.allegro.cc/forums/view/606569</link>
		<description>Allegro.cc Forum Thread</description>
		<webMaster>matthew@allegro.cc (Matthew Leverton)</webMaster>
		<lastBuildDate>Wed, 09 Mar 2011 18:21:05 +0000</lastBuildDate>
	</channel>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>How can I draw a rectangle filled with a horizontal or vertical gradient with Allegro 5?</p><p>With Allegro 4, I could draw a rectangular gradient using the polygon drawing routines.
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (axilmar)</author>
		<pubDate>Tue, 01 Mar 2011 22:40:24 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>I&#39;m not sure if its the only way, but try using the primitive addon. particularly <span class="source-code"><a href="http://www.allegro.cc/manual/al_draw_prim"><span class="a">al_draw_prim</span></a></span>.
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (Thomas Fjellstrom)</author>
		<pubDate>Tue, 01 Mar 2011 22:45:42 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>There is no specific function for it, but <span class="source-code"><a href="http://www.allegro.cc/manual/al_draw_prim"><span class="a">al_draw_prim</span></a></span> should be able to do it (untested):</p><div class="source-code snippet"><div class="inner"><pre><span class="k1">void</span> draw_vertical_gradient_rect<span class="k2">(</span><span class="k1">float</span> x, y, w, h, <a href="http://www.allegro.cc/manual/ALLEGRO_COLOR"><span class="a">ALLEGRO_COLOR</span></a> top, bottom<span class="k2">)</span> <span class="k2">{</span>
    <a href="http://www.allegro.cc/manual/ALLEGRO_VERTEX"><span class="a">ALLEGRO_VERTEX</span></a> v<span class="k2">[</span><span class="k2">]</span> <span class="k3">=</span> <span class="k2">{</span>
        <span class="k2">{</span>.x <span class="k3">=</span> x, .y <span class="k3">=</span> y, .z <span class="k3">=</span> <span class="n">0</span>, .color <span class="k3">=</span> top<span class="k2">}</span>,
        <span class="k2">{</span>.x <span class="k3">=</span> x <span class="k3">+</span> w, .y <span class="k3">=</span> y, .z <span class="k3">=</span> <span class="n">0</span>, .color <span class="k3">=</span> top<span class="k2">}</span>,
        <span class="k2">{</span>.x <span class="k3">=</span> x, .y <span class="k3">=</span> y <span class="k3">+</span> h, .z <span class="k3">=</span> <span class="n">0</span>, .color <span class="k3">=</span> bottom<span class="k2">}</span>,
        <span class="k2">{</span>.x <span class="k3">=</span> x <span class="k3">+</span> w, .y <span class="k3">=</span> y <span class="k3">+</span> h, .z <span class="k3">=</span> <span class="n">0</span>, .color <span class="k3">=</span> bottom<span class="k2">}</span><span class="k2">}</span><span class="k2">;</span>
    <a href="http://www.allegro.cc/manual/al_draw_prim"><span class="a">al_draw_prim</span></a><span class="k2">(</span>v, NULL, NULL, <span class="n">0</span>, <span class="n">4</span>, ALLEGRO_PRIM_TRIANGLE_STRIP<span class="k2">)</span><span class="k2">;</span>
<span class="k2">}</span>
</pre></div></div><p>

Some of the examples also demonstrate it I think.
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (Elias)</author>
		<pubDate>Tue, 01 Mar 2011 22:47:18 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>This is how I&#39;ve been doing it, but I think that Elias&#39; idea is more elegant. <img src="http://www.allegro.cc/forums/smileys/wink.gif" alt=";)" />
</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">///////////////////////////////////////////////////////////////////////////////</span>
<span class="number">  2</span><span class="k1">void</span> DrawRoundedGradientRect<span class="k2">(</span> <span class="k1">float</span> x1, <span class="k1">float</span> y1, <span class="k1">float</span> x2, <span class="k1">float</span> y2,
<span class="number">  3</span>                <a href="http://www.allegro.cc/manual/ALLEGRO_COLOR"><span class="a">ALLEGRO_COLOR</span></a> c1, <a href="http://www.allegro.cc/manual/ALLEGRO_COLOR"><span class="a">ALLEGRO_COLOR</span></a> c2 <span class="k2">)</span>
<span class="number">  4</span><span class="k2">{</span>
<span class="number">  5</span>  <span class="c">///////////////////////////////////////////////////////////////////////////</span>
<span class="number">  6</span>  <span class="c">// w and h should be AT LEAST a 4 to display correctly.</span>
<span class="number">  7</span>  <span class="c">///////////////////////////////////////////////////////////////////////////</span>
<span class="number">  8</span>  <span class="k1">int</span> i<span class="k2">;</span>
<span class="number">  9</span>  <span class="k1">float</span> h2<span class="k2">;</span>
<span class="number"> 10</span>  h2 <span class="k3">=</span> <span class="k2">(</span>y2 <span class="k3">-</span> y1<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 11</span>  x1<span class="k3">+</span><span class="k3">=</span><span class="n">0</span>.<span class="n">5</span><span class="k2">;</span>
<span class="number"> 12</span>  y1<span class="k3">+</span><span class="k3">=</span><span class="n">0</span>.<span class="n">5</span><span class="k2">;</span>
<span class="number"> 13</span>  x2-<span class="k3">=</span><span class="n">0</span>.<span class="n">5</span><span class="k2">;</span>
<span class="number"> 14</span>  y2-<span class="k3">=</span><span class="n">0</span>.<span class="n">5</span><span class="k2">;</span>
<span class="number"> 15</span>  UChar r<span class="k2">[</span><span class="n">2</span><span class="k2">]</span>, g<span class="k2">[</span><span class="n">2</span><span class="k2">]</span>, b<span class="k2">[</span><span class="n">2</span><span class="k2">]</span><span class="k2">;</span>
<span class="number"> 16</span>  <a href="http://www.allegro.cc/manual/al_unmap_rgb"><span class="a">al_unmap_rgb</span></a><span class="k2">(</span>c1,<span class="k3">&amp;</span>r<span class="k2">[</span><span class="n">0</span><span class="k2">]</span>,<span class="k3">&amp;</span>g<span class="k2">[</span><span class="n">0</span><span class="k2">]</span>,<span class="k3">&amp;</span>b<span class="k2">[</span><span class="n">0</span><span class="k2">]</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 17</span>  <a href="http://www.allegro.cc/manual/al_unmap_rgb"><span class="a">al_unmap_rgb</span></a><span class="k2">(</span>c2,<span class="k3">&amp;</span>r<span class="k2">[</span><span class="n">1</span><span class="k2">]</span>,<span class="k3">&amp;</span>g<span class="k2">[</span><span class="n">1</span><span class="k2">]</span>,<span class="k3">&amp;</span>b<span class="k2">[</span><span class="n">1</span><span class="k2">]</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 18</span>  <span class="k1">float</span> dr <span class="k3">=</span> <span class="k2">(</span><span class="k2">(</span>r<span class="k2">[</span><span class="n">1</span><span class="k2">]</span> <span class="k3">-</span> r<span class="k2">[</span><span class="n">0</span><span class="k2">]</span><span class="k2">)</span>%<span class="n">255</span><span class="k2">)</span><span class="k3">/</span>h2<span class="k2">;</span>
<span class="number"> 19</span>  <span class="k1">float</span> dg <span class="k3">=</span> <span class="k2">(</span><span class="k2">(</span>g<span class="k2">[</span><span class="n">1</span><span class="k2">]</span> <span class="k3">-</span> g<span class="k2">[</span><span class="n">0</span><span class="k2">]</span><span class="k2">)</span>%<span class="n">255</span><span class="k2">)</span><span class="k3">/</span>h2<span class="k2">;</span>
<span class="number"> 20</span>  <span class="k1">float</span> db <span class="k3">=</span> <span class="k2">(</span><span class="k2">(</span>b<span class="k2">[</span><span class="n">1</span><span class="k2">]</span> <span class="k3">-</span> b<span class="k2">[</span><span class="n">0</span><span class="k2">]</span><span class="k2">)</span>%<span class="n">255</span><span class="k2">)</span><span class="k3">/</span>h2<span class="k2">;</span>
<span class="number"> 21</span>  <span class="k1">int</span> xOffset <span class="k3">=</span> <span class="n">0</span><span class="k2">;</span>
<span class="number"> 22</span>  <span class="k1">for</span> <span class="k2">(</span>i<span class="k3">=</span>y1<span class="k2">;</span> i<span class="k3">&lt;</span>y2<span class="k2">;</span> i<span class="k3">+</span><span class="k3">=</span><span class="n">1</span><span class="k2">)</span>
<span class="number"> 23</span>  <span class="k2">{</span>
<span class="number"> 24</span>    <span class="k1">if</span> <span class="k2">(</span> i <span class="k3">=</span><span class="k3">=</span> y1 <span class="k3">|</span><span class="k3">|</span> i <span class="k3">=</span><span class="k3">=</span> y2 <span class="k2">)</span>
<span class="number"> 25</span>      xOffset <span class="k3">=</span> <span class="n">2</span><span class="k2">;</span>
<span class="number"> 26</span>    <span class="k1">if</span> <span class="k2">(</span> i <span class="k3">=</span><span class="k3">=</span> <span class="k2">(</span>y1<span class="k3">+</span><span class="n">1</span><span class="k2">)</span> <span class="k3">|</span><span class="k3">|</span> i <span class="k3">=</span><span class="k3">=</span> <span class="k2">(</span>y2-1<span class="k2">)</span> <span class="k2">)</span>
<span class="number"> 27</span>      xOffset <span class="k3">=</span> <span class="n">1</span><span class="k2">;</span>
<span class="number"> 28</span>    <a href="http://www.allegro.cc/manual/al_draw_line"><span class="a">al_draw_line</span></a><span class="k2">(</span>x1<span class="k3">+</span>xOffset,i,x2-xOffset,i,<a href="http://www.allegro.cc/manual/al_map_rgb"><span class="a">al_map_rgb</span></a><span class="k2">(</span>r<span class="k2">[</span><span class="n">0</span><span class="k2">]</span><span class="k3">+</span><span class="k3">=</span>dr,
<span class="number"> 29</span>               g<span class="k2">[</span><span class="n">0</span><span class="k2">]</span><span class="k3">+</span><span class="k3">=</span>dg,b<span class="k2">[</span><span class="n">0</span><span class="k2">]</span><span class="k3">+</span><span class="k3">=</span>db<span class="k2">)</span>,<span class="n">1</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="k2">}</span>
<span class="number"> 32</span><span class="c">///////////////////////////////////////////////////////////////////////////////</span>
</div></div><p>
Needs to be fixed up, and strange colors can happen still if the color range is less than the height of the rect. But, I leave that up to you to fix if you wish to use it...</p><p>Changed it to use Elias&#39; code...
</p><div class="source-code snippet"><div class="inner"><pre><span class="k1">void</span> DrawRoundedGradientRect<span class="k2">(</span> <span class="k1">float</span> x1, <span class="k1">float</span> y1, <span class="k1">float</span> x2, <span class="k1">float</span> y2,
                <a href="http://www.allegro.cc/manual/ALLEGRO_COLOR"><span class="a">ALLEGRO_COLOR</span></a> c1, <a href="http://www.allegro.cc/manual/ALLEGRO_COLOR"><span class="a">ALLEGRO_COLOR</span></a> c2<span class="k2">)</span>
<span class="k2">{</span>
    <a href="http://www.allegro.cc/manual/ALLEGRO_VERTEX"><span class="a">ALLEGRO_VERTEX</span></a> v<span class="k2">[</span><span class="k2">]</span> <span class="k3">=</span>
  <span class="k2">{</span>
        <span class="k2">{</span> x1, y1, <span class="n">0</span>, <span class="n">0</span>, <span class="n">0</span>, c1<span class="k2">}</span>,
        <span class="k2">{</span> x2, y1, <span class="n">0</span>, <span class="n">0</span>, <span class="n">0</span>, c1<span class="k2">}</span>,
        <span class="k2">{</span> x1, y2, <span class="n">0</span>, <span class="n">0</span>, <span class="n">0</span>, c2<span class="k2">}</span>,
        <span class="k2">{</span> x2, y2, <span class="n">0</span>, <span class="n">0</span>, <span class="n">0</span>, c2<span class="k2">}</span>
  <span class="k2">}</span><span class="k2">;</span>
    <a href="http://www.allegro.cc/manual/al_draw_prim"><span class="a">al_draw_prim</span></a><span class="k2">(</span>v, NULL, NULL, <span class="n">0</span>, <span class="n">4</span>, ALLEGRO_PRIM_TRIANGLE_STRIP<span class="k2">)</span><span class="k2">;</span>
<span class="k2">}</span>
<span class="c">///////////////////////////////////////////////////////////////////////////////</span>
</pre></div></div><p>
Same results. I like it much better though. <img src="http://www.allegro.cc/forums/smileys/grin.gif" alt=";D" />
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (Don Freeman)</author>
		<pubDate>Thu, 03 Mar 2011 23:59:35 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>I have coded this function:</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> algui_fill_rect_gradient<span class="k2">(</span>
<span class="number">  2</span>    <span class="k1">int</span> left, <span class="k1">int</span> top, <span class="k1">int</span> right, <span class="k1">int</span> bottom, 
<span class="number">  3</span>    <a href="http://www.allegro.cc/manual/ALLEGRO_COLOR"><span class="a">ALLEGRO_COLOR</span></a> top_left, <a href="http://www.allegro.cc/manual/ALLEGRO_COLOR"><span class="a">ALLEGRO_COLOR</span></a> top_right, <a href="http://www.allegro.cc/manual/ALLEGRO_COLOR"><span class="a">ALLEGRO_COLOR</span></a> bottom_right, <a href="http://www.allegro.cc/manual/ALLEGRO_COLOR"><span class="a">ALLEGRO_COLOR</span></a> bottom_left<span class="k2">)</span>
<span class="number">  4</span><span class="k2">{</span>
<span class="number">  5</span>    <a href="http://www.allegro.cc/manual/ALLEGRO_VERTEX"><span class="a">ALLEGRO_VERTEX</span></a> v<span class="k2">[</span><span class="n">4</span><span class="k2">]</span><span class="k2">;</span>
<span class="number">  6</span>    
<span class="number">  7</span>    <span class="c">/* setup the top-left vertex */</span>
<span class="number">  8</span>    v<span class="k2">[</span><span class="n">0</span><span class="k2">]</span>.x <span class="k3">=</span> left<span class="k2">;</span>
<span class="number">  9</span>    v<span class="k2">[</span><span class="n">0</span><span class="k2">]</span>.y <span class="k3">=</span> top<span class="k2">;</span>
<span class="number"> 10</span>    v<span class="k2">[</span><span class="n">0</span><span class="k2">]</span>.z <span class="k3">=</span> <span class="n">0</span><span class="k2">;</span>
<span class="number"> 11</span>    v<span class="k2">[</span><span class="n">0</span><span class="k2">]</span>.color <span class="k3">=</span> top_left<span class="k2">;</span>
<span class="number"> 12</span>    
<span class="number"> 13</span>    <span class="c">/* setup the top-right vertex */</span>
<span class="number"> 14</span>    v<span class="k2">[</span><span class="n">1</span><span class="k2">]</span>.x <span class="k3">=</span> left<span class="k2">;</span>
<span class="number"> 15</span>    v<span class="k2">[</span><span class="n">1</span><span class="k2">]</span>.y <span class="k3">=</span> right <span class="k3">+</span> <span class="n">0</span>.<span class="n">6f</span><span class="k2">;</span>
<span class="number"> 16</span>    v<span class="k2">[</span><span class="n">1</span><span class="k2">]</span>.z <span class="k3">=</span> <span class="n">0</span><span class="k2">;</span>
<span class="number"> 17</span>    v<span class="k2">[</span><span class="n">1</span><span class="k2">]</span>.color <span class="k3">=</span> top_right<span class="k2">;</span>
<span class="number"> 18</span>
<span class="number"> 19</span>    <span class="c">/* setup the bottom-left vertex */</span>
<span class="number"> 20</span>    v<span class="k2">[</span><span class="n">2</span><span class="k2">]</span>.x <span class="k3">=</span> left<span class="k2">;</span>
<span class="number"> 21</span>    v<span class="k2">[</span><span class="n">2</span><span class="k2">]</span>.y <span class="k3">=</span> bottom <span class="k3">+</span> <span class="n">0</span>.<span class="n">6f</span><span class="k2">;</span>
<span class="number"> 22</span>    v<span class="k2">[</span><span class="n">2</span><span class="k2">]</span>.z <span class="k3">=</span> <span class="n">0</span><span class="k2">;</span>
<span class="number"> 23</span>    v<span class="k2">[</span><span class="n">2</span><span class="k2">]</span>.color <span class="k3">=</span> bottom_left<span class="k2">;</span>
<span class="number"> 24</span>
<span class="number"> 25</span>    <span class="c">/* setup the bottom-right vertex */</span>
<span class="number"> 26</span>    v<span class="k2">[</span><span class="n">3</span><span class="k2">]</span>.x <span class="k3">=</span> right <span class="k3">+</span> <span class="n">0</span>.<span class="n">6f</span><span class="k2">;</span>
<span class="number"> 27</span>    v<span class="k2">[</span><span class="n">3</span><span class="k2">]</span>.y <span class="k3">=</span> bottom <span class="k3">+</span> <span class="n">0</span>.<span class="n">6f</span><span class="k2">;</span>
<span class="number"> 28</span>    v<span class="k2">[</span><span class="n">3</span><span class="k2">]</span>.z <span class="k3">=</span> <span class="n">0</span><span class="k2">;</span>
<span class="number"> 29</span>    v<span class="k2">[</span><span class="n">3</span><span class="k2">]</span>.color <span class="k3">=</span> bottom_right<span class="k2">;</span>
<span class="number"> 30</span>    
<span class="number"> 31</span>    <span class="c">/* draw the shape */</span>
<span class="number"> 32</span>    <a href="http://www.allegro.cc/manual/al_draw_prim"><span class="a">al_draw_prim</span></a><span class="k2">(</span>v, NULL, NULL, <span class="n">0</span>, <span class="n">4</span>, ALLEGRO_PRIM_TRIANGLE_STRIP<span class="k2">)</span><span class="k2">;</span>
</div></div><p>

I am using the above function like this:</p><div class="source-code snippet"><div class="inner"><pre>    algui_fill_rect_gradient<span class="k2">(</span><span class="n">20</span>, <span class="n">10</span>, <span class="n">59</span>, <span class="n">49</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">255</span>, <span class="n">255</span><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">255</span>, <span class="n">255</span>, <span class="n">255</span><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">255</span>, <span class="n">255</span>, <span class="n">255</span><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">255</span>, <span class="n">255</span>, <span class="n">255</span><span class="k2">)</span><span class="k2">)</span><span class="k2">;</span>
</pre></div></div><p>

However, the result is not a rectangle, it is a triangle:</p><p><span class="remote-thumbnail"><span class="json">{"name":"Cafji.png","src":"\/\/djungxnpq2nug.cloudfront.net\/image\/cache\/c\/d\/cd0815d114a3329b5d4c2a0be07d5294.png","w":640,"h":480,"tn":"\/\/djungxnpq2nug.cloudfront.net\/image\/cache\/c\/d\/cd0815d114a3329b5d4c2a0be07d5294"}</span><img src="http://www.allegro.cc//djungxnpq2nug.cloudfront.net/image/cache/c/d/cd0815d114a3329b5d4c2a0be07d5294-240.jpg" alt="Cafji.png" title="Hosted by imgur.com" width="240" height="180" /></span></p><p>What am I doing wrong?
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (axilmar)</author>
		<pubDate>Tue, 08 Mar 2011 22:18:38 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>if you change your background to a different colour do you get a black and a white triangle or just the white triange? I know nothing of the prim functions but I&#39;m guessing it&#39;s just flipping between black and white based on your gradiant being the same colour for all corners?
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (Neil Walker)</author>
		<pubDate>Tue, 08 Mar 2011 22:26:07 +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/606569/906714#target">Neil Walker</a> said:</div><div class="quote"><p>
if you change your background to a different colour do you get a black and a white triangle or just the white triange? I know nothing of the prim functions but I&#39;m guessing it&#39;s just flipping between black and white based on your gradiant being the same colour for all corners?
</p></div></div><p>

I don&#39;t think so. For example, if I change the background to gray:</p><p><span class="remote-thumbnail"><span class="json">{"name":"Dcb8r.png","src":"\/\/djungxnpq2nug.cloudfront.net\/image\/cache\/8\/e\/8eafc3d309cc02702905ef36d8051a45.png","w":640,"h":480,"tn":"\/\/djungxnpq2nug.cloudfront.net\/image\/cache\/8\/e\/8eafc3d309cc02702905ef36d8051a45"}</span><img src="http://www.allegro.cc//djungxnpq2nug.cloudfront.net/image/cache/8/e/8eafc3d309cc02702905ef36d8051a45-240.jpg" alt="Dcb8r.png" title="Hosted by imgur.com" width="240" height="180" /></span>
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (axilmar)</author>
		<pubDate>Tue, 08 Mar 2011 22:36:10 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>One thing I noticed, instead of ending at the last point, you are moving beyond it:
</p><div class="source-code snippet"><div class="inner"><pre><span class="c">/* setup the bottom-right vertex */</span>
v<span class="k2">[</span><span class="n">3</span><span class="k2">]</span>.x <span class="k3">=</span> right <span class="k3">+</span> <span class="n">0</span>.<span class="n">6f</span><span class="k2">;</span>
v<span class="k2">[</span><span class="n">3</span><span class="k2">]</span>.y <span class="k3">=</span> bottom <span class="k3">+</span> <span class="n">0</span>.<span class="n">6f</span><span class="k2">;</span>
</pre></div></div><p>
These should probably be just right or left+right, and bottom or top+bottom. I don&#39;t understand wtf the 0.6 is for, but that&#39;s not right. I think your other problem is the order you put your vertices...it&#39;s a triangle strip, so you should 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">/* setup the top-left vertex */</span>
<span class="number">  2</span>    v<span class="k2">[</span><span class="n">0</span><span class="k2">]</span>.x <span class="k3">=</span> left<span class="k2">;</span>
<span class="number">  3</span>    v<span class="k2">[</span><span class="n">0</span><span class="k2">]</span>.y <span class="k3">=</span> top<span class="k2">;</span>
<span class="number">  4</span>    v<span class="k2">[</span><span class="n">0</span><span class="k2">]</span>.z <span class="k3">=</span> <span class="n">0</span><span class="k2">;</span>
<span class="number">  5</span>    v<span class="k2">[</span><span class="n">0</span><span class="k2">]</span>.color <span class="k3">=</span> top_left<span class="k2">;</span>
<span class="number">  6</span>    
<span class="number">  7</span>    <span class="c">/* setup the top-right vertex */</span>
<span class="number">  8</span>    v<span class="k2">[</span><span class="n">1</span><span class="k2">]</span>.x <span class="k3">=</span> left<span class="k2">;</span>
<span class="number">  9</span>    v<span class="k2">[</span><span class="n">1</span><span class="k2">]</span>.y <span class="k3">=</span> right <span class="k3">+</span> <span class="n">0</span>.<span class="n">6f</span><span class="k2">;</span>
<span class="number"> 10</span>    v<span class="k2">[</span><span class="n">1</span><span class="k2">]</span>.z <span class="k3">=</span> <span class="n">0</span><span class="k2">;</span>
<span class="number"> 11</span>    v<span class="k2">[</span><span class="n">1</span><span class="k2">]</span>.color <span class="k3">=</span> top_right<span class="k2">;</span>
<span class="number"> 12</span>
<span class="number"> 13</span>    <span class="c">/* setup the bottom-right vertex */</span>
<span class="number"> 14</span>    v<span class="k2">[</span><span class="n">2</span><span class="k2">]</span>.x <span class="k3">=</span> right <span class="k3">+</span> <span class="n">0</span>.<span class="n">6f</span><span class="k2">;</span>
<span class="number"> 15</span>    v<span class="k2">[</span><span class="n">2</span><span class="k2">]</span>.y <span class="k3">=</span> bottom <span class="k3">+</span> <span class="n">0</span>.<span class="n">6f</span><span class="k2">;</span>
<span class="number"> 16</span>    v<span class="k2">[</span><span class="n">2</span><span class="k2">]</span>.z <span class="k3">=</span> <span class="n">0</span><span class="k2">;</span>
<span class="number"> 17</span>    v<span class="k2">[</span><span class="n">2</span><span class="k2">]</span>.color <span class="k3">=</span> bottom_right<span class="k2">;</span>
<span class="number"> 18</span>
<span class="number"> 19</span>    <span class="c">/* setup the bottom-left vertex */</span>
<span class="number"> 20</span>    v<span class="k2">[</span><span class="n">3</span><span class="k2">]</span>.x <span class="k3">=</span> left<span class="k2">;</span>
<span class="number"> 21</span>    v<span class="k2">[</span><span class="n">3</span><span class="k2">]</span>.y <span class="k3">=</span> bottom <span class="k3">+</span> <span class="n">0</span>.<span class="n">6f</span><span class="k2">;</span>
<span class="number"> 22</span>    v<span class="k2">[</span><span class="n">3</span><span class="k2">]</span>.z <span class="k3">=</span> <span class="n">0</span><span class="k2">;</span>
<span class="number"> 23</span>    v<span class="k2">[</span><span class="n">3</span><span class="k2">]</span>.color <span class="k3">=</span> bottom_left<span class="k2">;</span>
</div></div><p>

And the output you had was solid white with no gradient because that is what you passed to the function, but I&#39;m sure you knew that one.
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (Don Freeman)</author>
		<pubDate>Tue, 08 Mar 2011 22:37:02 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>Your point coordinates are probably wrong. E.g this:
</p><div class="source-code snippet"><div class="inner"><pre>v<span class="k2">[</span><span class="n">1</span><span class="k2">]</span>.x <span class="k3">=</span> left<span class="k2">;</span>
v<span class="k2">[</span><span class="n">1</span><span class="k2">]</span>.y <span class="k3">=</span> right <span class="k3">+</span> <span class="n">0</span>.<span class="n">6f</span><span class="k2">;</span>
</pre></div></div><p>

And what&#39;s with the 0.6?</p><p>EDIT: Pretty sure the order of his points is fine. For triangle fans you go clockwise, for triangle strips you zig-zag.
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (SiegeLord)</author>
		<pubDate>Tue, 08 Mar 2011 22:37:35 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>But seriously, the code you needed was posted by me <a href="http://www.allegro.cc/forums/thread/606569/906125#target">here at the bottom</a>, all you had to do was add two more color parameters to the function... <img src="http://www.allegro.cc/forums/smileys/rolleyes.gif" alt="::)" /><img src="http://www.allegro.cc/forums/smileys/lipsrsealed.gif" alt=":-X" /></p><p>SiegeLord:<br />Works for me, and not him...so I&#39;d say it&#39;s the vertice order. Especially considering that is the portion that is missing. <img src="http://www.allegro.cc/forums/smileys/tongue.gif" alt=":P" />
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (Don Freeman)</author>
		<pubDate>Tue, 08 Mar 2011 22:39:15 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>Except the order in your first post is the same as in axilmar&#39;s post <img src="http://www.allegro.cc/forums/smileys/wink.gif" alt=";)" />:</p><div class="source-code snippet"><div class="inner"><pre><span class="k1">void</span> DrawRoundedGradientRect<span class="k2">(</span> <span class="k1">float</span> x1, <span class="k1">float</span> y1, <span class="k1">float</span> x2, <span class="k1">float</span> y2,
                <a href="http://www.allegro.cc/manual/ALLEGRO_COLOR"><span class="a">ALLEGRO_COLOR</span></a> c1, <a href="http://www.allegro.cc/manual/ALLEGRO_COLOR"><span class="a">ALLEGRO_COLOR</span></a> c2<span class="k2">)</span>
<span class="k2">{</span>
    <a href="http://www.allegro.cc/manual/ALLEGRO_VERTEX"><span class="a">ALLEGRO_VERTEX</span></a> v<span class="k2">[</span><span class="k2">]</span> <span class="k3">=</span>
  <span class="k2">{</span>
        <span class="k2">{</span> x1, y1, <span class="n">0</span>, <span class="n">0</span>, <span class="n">0</span>, c1<span class="k2">}</span>, <span class="c">//top left</span>
        <span class="k2">{</span> x2, y1, <span class="n">0</span>, <span class="n">0</span>, <span class="n">0</span>, c1<span class="k2">}</span>, <span class="c">//top right</span>
        <span class="k2">{</span> x1, y2, <span class="n">0</span>, <span class="n">0</span>, <span class="n">0</span>, c2<span class="k2">}</span>, <span class="c">//bottom left</span>
        <span class="k2">{</span> x2, y2, <span class="n">0</span>, <span class="n">0</span>, <span class="n">0</span>, c2<span class="k2">}</span>  <span class="c">//bottom right</span>
  <span class="k2">}</span><span class="k2">;</span>
    <a href="http://www.allegro.cc/manual/al_draw_prim"><span class="a">al_draw_prim</span></a><span class="k2">(</span>v, NULL, NULL, <span class="n">0</span>, <span class="n">4</span>, ALLEGRO_PRIM_TRIANGLE_STRIP<span class="k2">)</span><span class="k2">;</span>
<span class="k2">}</span>
</pre></div></div><p>
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (SiegeLord)</author>
		<pubDate>Tue, 08 Mar 2011 22:42:07 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>By GOD it is isn&#39;t it...my eyes are not what they used to be l0l! <img src="http://www.allegro.cc/forums/smileys/wink.gif" alt=";)" /> Why label these top and bottom and not just x2, y2 like everyone else...
</p><div class="source-code snippet"><div class="inner"><pre><span class="c">/* setup the top-left vertex */</span>
 <span class="n">13</span>    <span class="c">/* setup the top-right vertex */</span>
 <span class="n">14</span>    v<span class="k2">[</span><span class="n">1</span><span class="k2">]</span>.x <span class="k3">=</span> left<span class="k2">;</span>
 <span class="n">15</span>    v<span class="k2">[</span><span class="n">1</span><span class="k2">]</span>.y <span class="k3">=</span> right <span class="k3">+</span> <span class="n">0</span>.<span class="n">6f</span><span class="k2">;</span>
 <span class="n">16</span>    v<span class="k2">[</span><span class="n">1</span><span class="k2">]</span>.z <span class="k3">=</span> <span class="n">0</span><span class="k2">;</span>
 <span class="n">17</span>    v<span class="k2">[</span><span class="n">1</span><span class="k2">]</span>.color <span class="k3">=</span> top_right<span class="k2">;</span>
</pre></div></div><p>
Oh....but we both didn&#39;t see this at first so <img src="http://www.allegro.cc/forums/smileys/tongue.gif" alt=":P" /> Look at lines 14 and 15...I&#39;m pretty sure that v[1].y is suppose to be v[1].y = top+0.6f. Well, that and the color value would be wrong at least going by the variable&#39;s label.
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (Don Freeman)</author>
		<pubDate>Tue, 08 Mar 2011 22:49:03 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>Actually, I goofed at this line:</p><div class="source-code snippet"><div class="inner"><pre>v<span class="k2">[</span><span class="n">1</span><span class="k2">]</span>.x <span class="k3">=</span> left<span class="k2">;</span>
v<span class="k2">[</span><span class="n">1</span><span class="k2">]</span>.y <span class="k3">=</span> right <span class="k3">+</span> <span class="n">0</span>.<span class="n">6f</span><span class="k2">;</span>
</pre></div></div><p>

It&#39;s two hours that I am viewing this code, and I couldn&#39;t parse it correctly. Sorry :-).
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (axilmar)</author>
		<pubDate>Tue, 08 Mar 2011 23:22:56 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>Don&#39;t forget to correct the color line there as well...see my post above.
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (Don Freeman)</author>
		<pubDate>Tue, 08 Mar 2011 23:44:54 +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/606569/906734#target">Don Freeman</a> said:</div><div class="quote"><p>
Don&#39;t forget to correct the color line there as well...see my post above.
</p></div></div><p>

Isn&#39;t vertex 1 the top-right vertex?
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (axilmar)</author>
		<pubDate>Wed, 09 Mar 2011 18:21:05 +0000</pubDate>
	</item>
</rss>
