<script
Language="javascript">
/******************
JS2D函数集 *******************<br />
在引用或转载时请保留此版权信息,谢谢!!!<br
/>
<br />
本函数集可以单独存成一个js文件:"JS2D.js"<br
/>
<br />
***************************************************/
/************* 画点
**************<br />
x,y 点所在的屏幕坐标(像素)<br />
color 颜色(字符串值)<br />
size 大小(像素)<br />
**********************************/
function
drawDot(x,y,color,size)
{
document.write("<table border='0' cellspacing=0
cellpadding=0><tr><td style='position: absolute; left:
"+x+";
top:
"+y+";background-color:
"+color+"' width="+size+"
height="+size+"></td></tr></table>");
}
/************* 画直线
**************<br />
x1,y1 起点所在的屏幕坐标(像素)<br />
x2,y2 终点所在的屏幕坐标(像素)<br />
color 颜色(字符串值)<br />
size 大小(像素)<br />
style 样式<br />
=0 实线<br />
=1 虚线<br />
=2 虚实线<br />
**********************************/
function
drawLine(x1,y1,x2,y2,color,size,style)
{
var
i;
var
r=Math.floor(Math.sqrt((x2-x1)*(x2-x1)+(y2-y1)*(y2-y1)));
var
theta=Math.atan((x2-x1)/(y2-y1));
if((y2-y1)<0&&(x2-x1)<0)//第三象限
theta=Math.PI+theta;
else if((y2-y1)>0&&(x2-x1)<0)//第二象限
theta=2*Math.PI+theta;
else if((y2-y1)<0&&(x2-x1)>0)//第四象限
theta=Math.PI+theta;
var
dx=Math.sin(theta);//alert(dx)<br />
var
dy=Math.cos(theta);
for(i=0;i<r;i++)
{
switch(style)
{
case 0:
drawDot(x1+i*dx,y1+i*dy,color,size);
break;
case 1:
i+=size*2;
drawDot(x1+i*dx,y1+i*dy,color,size);
break;
case 2:
if(Math.floor(i/4/size)%2==0)
{
drawDot(x1+i*dx,y1+i*dy,color,size);
}
else
{
i+=size*2;
drawDot(x1+i*dx,y1+i*dy,color,size);
}
break;
default:
drawDot(x1+i*dx,y1+i*dy,color,size);
break;
}
}
}
/************* 画实心矩形
**************<br />
x1,y1 起点(矩形左上角)所在的屏幕坐标(像素)<br />
x2,y2 终点(矩形右下角)所在的屏幕坐标(像素)<br />
color 颜色(字符串值)<br />
**********************************/
function
drawFilledRect(x1,y1,x2,y2,color)
{
document.write("<table border='0' cellspacing=0
cellpadding=0><tr><td style='position: absolute; left:
"+(x1)+"; top: "+
(y1)+";background-color:
"+color+"' width="+(x2-x1)+"
height="+(y2-y1)+"></td></tr></table>")
}
/************* 画矩形
**************<br />
x1,y1 起点(矩形左上角)所在的屏幕坐标(像素)<br />
x2,y2 终点(矩形右下角)所在的屏幕坐标(像素)<br />
color 颜色(字符串值)<br />
size 大小(像素)<br />
style 样式<br />
=0 实线<br />
=1 虚线<br />
=2 虚实线<br />
**********************************/
function
drawRect(x1,y1,x2,y2,color,size,style)
{
drawLine(x1,y1,x2,y1,color,size,style);
drawLine(x1,y2,x2,y2,color,size,style);
drawLine(x1,y1,x1,y2,color,size,style);
drawLine(x2,y1,x2,y2,color,size,style);
}
/************* 画椭圆
**************<br />
x,y 中心所在的屏幕坐标(像素)<br
/>
a,b 长轴和短轴的长度(像素)<br
/>
color 颜色(字符串值)<br
/>
size 大小(像素)<br
/>
precision 边缘精细度<br />
**********************************/
function
drawOval(x,y,a,b,color,size,precision)
{
var
i;
var
iMax=2*Math.PI;
var
step=2*Math.PI/(precision*Math.sqrt(a*b)*4.5);
for(i=0;i<iMax;i+=step)
{
drawDot(x+a*Math.cos(i),y+b*Math.sin(i),color,size);
}
}
/************* 画多边形
**************<br />
x,y 中心所在的屏幕坐标(像素)<br />
r 多边形外接圆半径(像素)<br
/>
n 多边形的边数<br
/>
color 颜色(字符串值)<br />
size 大小(像素)<br />
style 样式<br />
=0 实线<br />
=1 虚线<br />
=2 虚实线<br />
**********************************/
function
drawPoly(x,y,r,n,color,size,style)
{
var
i;
var
theta=Math.PI;
var
x1=x,y1=y-r,x2,y2;
for(i=0;i<n;i++)
{
theta-=(2*Math.PI/n);
x2=x+r*Math.sin(theta);
y2=y+r*Math.cos(theta);
drawLine(x1,y1,x2,y2,color,size,style);
x1=x2;
y1=y2;//alert(x1+" "+y1)<br />
}
}
</script>
分享到:
相关推荐
js 画图
支持javascript画图 详细请见:http://blog.chinaunix.net/u/21684/showart_453823.html
博文链接:https://lib.iteye.com/blog/141305
js 画图 图画板js 画图 图画板js 画图 图画板js 画图 图画板
js画图工具,支持正方形、圆形、折现、菱形画图,封装比较简单,需要用到的朋友可以自己扩展!
js画图js画图js画图js画图js画图
js画图包这是个德国人写的很强大,可以实现一般图形的绘制,填充。里面的统计图例子中js文件引入的路径有问题应该改为<script type="text/javascript" src="wz_jsgraphics.js"></script>
页面简洁美观,画笔,橡皮擦等功能。画笔可选大小、样色,并可导出图片。
js画图 js画图包及使用方法 wz_jsgraphics wz_jsgraphics使用
js画图作的五子棋程序,不用一个图片,棋盘,棋子都是用js画出来的,这可是原创噢,不过画图的脚本是人家老外的,呵呵,边界有点问题,大伙改改吧
支持java,js画图的工具,里面有帮助文档,war包,jar包 直接可用,画图超炫,简单易用
js 画图,可以实现动态折线图的哦,另外还有饼图和柱状图 省了不少麻烦
JavaScript画图画图画图画图画图画图画图画图画图画图画图画图画图画图画图画图画图画图画图画图画图画图
这是一个很不错的JS画图板,可以根据自己需要改成网上手写签字
JS画图所用js 博文链接:https://wrong1111.iteye.com/blog/475350
sketch.js 画图工具效果是一款跟随鼠标画图效果代码 。温馨提示:chrome 浏览器下效果最佳。
js画图,直接在浏览器上画图的 开发经验 在开发一个国外项目中用到了这个插件