<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0" xmlns:dc="http://purl.org/dc/elements/1.1/">
  <channel>
    <title>DZone Snippets: drawing code</title>
    <link>http://snippets.dzone.com/posts</link>
    <pubDate>Thu, 24 Jul 2008 18:04:43 GMT</pubDate>
    <description>DZone Snippets: drawing code</description>
    <item>
      <title>Graphical Plotter //Javascript Class</title>
      <link>http://snippets.dzone.com/posts/show/682</link>
      <description>&lt;a href="http://www.jsfromhell.com/dhtml/graphical-plotter"&gt;&lt;br /&gt;&lt;br /&gt;[UPDATED CODE AND HELP CAN BE FOUND HERE]&lt;br /&gt;&lt;/a&gt;&lt;br /&gt;&lt;br /&gt;&lt;br /&gt;An unuseful thing to draw using javascript, it's slow as hell :)&lt;br /&gt;&lt;br /&gt;&lt;code&gt;&lt;br /&gt;//+ Jonas Raoni Soares Silva&lt;br /&gt;//@ http://jsfromhell.com/dhtml/graphical-plotter [v1.0]&lt;br /&gt;&lt;br /&gt;Canvas = function(){&lt;br /&gt;	var o = this;&lt;br /&gt;	( o.penPos = { x: 0, y: 0 }, o.pixelSize = 10, o.pen = { style: "solid", size: 1, color: "#000" }, o.brush = { style: "solid", color: "#000" } );&lt;br /&gt;};&lt;br /&gt;with( { p: Canvas.prototype } ){&lt;br /&gt;	p.pixel = function( x, y, color ) {&lt;br /&gt;		var o = this, s = document.body.appendChild( document.createElement( "div" ) ).style;&lt;br /&gt;		return ( s.position = "absolute", s.width = ( o.pen.size * o.pixelSize ) + "px", s.height = ( o.pen.size * o.pixelSize ) + "px", s.fontSize = "1px", s.left = ( x * o.pixelSize ) + "px", s.top = ( y * o.pixelSize ) + "px", s.backgroundColor = color || o.pen.color, o );&lt;br /&gt;	};&lt;br /&gt;	p.line = function( x1, y1, x2, y2 ){&lt;br /&gt;		if( Math.abs( x1 - x2 ) &lt; Math.abs( y1 - y2 ) )&lt;br /&gt;			for( y = Math.min( y1, y2 ) - 1, x = Math.max( y1, y2 ); ++y &lt;= x; canvas.pixel( ( y * ( x1 - x2 ) - x1 * y2 + y1 * x2 ) / ( y1 - y2 ), y ) );&lt;br /&gt;		else&lt;br /&gt;			for( x = Math.min( x1, x2 ) - 1, y = Math.max( x1, x2 ); ++x &lt;= y; canvas.pixel( x, ( x * ( y1 - y2 ) - y1 * x2 + x1 * y2 ) / ( x1 - x2 ) ) );&lt;br /&gt;		return this;&lt;br /&gt;	};&lt;br /&gt;	p.arc = function( x, y, raio, startAngle, degrees ) {&lt;br /&gt;		for( degrees += startAngle; degrees --&gt; startAngle; this.pixel( Math.cos( degrees * Math.PI / 180 ) * raio + x, Math.sin( degrees * Math.PI / 180 ) * raio + y ) ); return this;&lt;br /&gt;	};&lt;br /&gt;	p.rectangle = function( x, y, width, height, rotation ){&lt;br /&gt;		return this.moveTo( x, y ).lineBy( 0, height ).lineBy( width, 0 ).lineBy( 0, -height ).lineBy( -width, 0 );&lt;br /&gt;	};&lt;br /&gt;	p.moveTo = function( x, y ){ var o = this; return ( o.penPos.x = x, o.penPos.y = y, o ); };&lt;br /&gt;	p.moveBy = function( x, y ){ var o = this; return o.moveTo( o.penPos.x + x, o.penPos.y + y ); };&lt;br /&gt;	p.lineTo = function( x, y ){ var o = this; return o.line( o.penPos.x, o.penPos.y, x, y ).moveTo( x, y ); };&lt;br /&gt;	p.lineBy = function( x, y ){ var o = this; return o.lineTo( o.penPos.x + x, o.penPos.y + y ); };&lt;br /&gt;	p.curveTo = function( cx, cy, x, y ){};&lt;br /&gt;	p.polyBezier = function( points ){};&lt;br /&gt;	p.path = function( points ){};&lt;br /&gt;}&lt;br /&gt;&lt;/code&gt;&lt;br /&gt;&lt;br /&gt;&lt;br /&gt;Example:&lt;br /&gt;&lt;br /&gt;&lt;code&gt;&lt;br /&gt;canvas = new Canvas;&lt;br /&gt;&lt;br /&gt;canvas.pen.color = "#f00";&lt;br /&gt;canvas.rectangle( 30, 20, 20, 20 );&lt;br /&gt;canvas.pen.color = "#080";&lt;br /&gt;canvas.rectangle( 35, 25, 10, 10 );&lt;br /&gt;canvas.pen.color = "#008";&lt;br /&gt;canvas.arc( 50, 30, 10, 180, 270 );&lt;br /&gt;canvas.arc( 30, 30, 10, 0, 270 );&lt;br /&gt;canvas.pen.color = "#ff0";&lt;br /&gt;&lt;/code&gt;</description>
      <pubDate>Fri, 09 Sep 2005 07:25:34 GMT</pubDate>
      <guid>http://snippets.dzone.com/posts/show/682</guid>
      <author>jonasraoni (Jonas Raoni Soares Silva)</author>
    </item>
  </channel>
</rss>
