纯JS画点、画线、画圆的方法
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>无标题文档</title>
<style type="text/css">
div{ overflow:hidden;}
</style>
<script type="text/javascript">
/* 珠峰培训 2011年12月9日课堂示例
以下画点,画线,画圆的方法,都不是用HTML5的canvas,而是用的纯js
用到了一些数学的三角函数方法
以下代码是课堂随机写出,没有做更多优化
*/
function point(x,y){//画点
var oDiv=document.createElement('div');
oDiv.style.position='absolute';
oDiv.style.height='2px';
oDiv.style.width='2px';
oDiv.style.backgroundColor='red';
oDiv.style.left=x+'px';
oDiv.style.top=y+'px';
//document.body.appendChild(oDiv);
return oDiv;//注意:返回的值是一个dom节点,但并未追加到文档中
}
function drawLine(x1,y1,x2,y2){//画一条直线的方法
var x=x2-x1;//宽
var y=y2-y1;//高
var frag=document.createDocumentFragment();
if(Math.abs(y)>Math.abs(x)){//那个边更长,用那边来做画点的依据(就是下面那个循环),如果不这样,
if(y>0)//正着画线是这样的
- for(var i=0;i<y;i++){
- var width=x/y*i //x/y是直角两个边长的比,根据这个比例,求出新坐标的位置
- {
- frag.appendChild(point(width+x1,i+y1));
- }
- }
- if(y<0){//有时候是倒着画线的
- for(var i=0;i>y;i--){
- var width=x/y*i
- {
- frag.appendChild( point(width+x1,i+y1));
- }
- }
- }
- }//end if
- else {
- if(x>0)//正着画线是这样的
- for(var i=0;i<x;i++){
- var height=y/x*i
- {
- frag.appendChild(point(i+x1,height+y1));
- }
- }
- if(x<0){//有时候是倒着画线的
- for(var i=0;i>x;i--){
- var height=y/x*i
- {
- frag.appendChild( point(i+x1,height+y1));
- }
- }
- }//end if
- }
- //document.body.appendChild(frag);
- document.getElementById('div1').appendChild(frag);
- //var oDiv=document.createElement('div')
- //oDiv.appendChild(frag);
- //document.body.appendChild(oDiv);
- }
- function drawCircle(){//画个圆
- var r=200;
- var x1=300;
- var y1=300;
- var frag=document.createDocumentFragment();
- for(var degree=0;degree<360;degree+=2){
- var x2=r*Math.sin(degree*Math.PI/180);
- var y2=r*Math.cos(degree*Math.PI/180);
- frag.appendChild(point(x1+x2,y1+y2));
- }
- document.body.appendChild(frag);
- }
- function dragCircle(x1,y1,x2,y2){//拖出一个圆来
- var r=Math.sqrt((x2-x1)*(x2-x1)+(y2-y1)*(y2-y1));//求出半径的长 直角三角形中 斜边的平方=两个直边的平方之和
- var frag=document.createDocumentFragment();
- for(var degree=0;degree<360;degree+=2){//每隔2度画一个点
- var x2=r*Math.sin(degree*Math.PI/180);
- var y2=r*Math.cos(degree*Math.PI/180);
- frag.appendChild(point(x1+x2,y1+y2));
- }
- document.getElementById('div1').appendChild(frag);
- }
- window.onload=function(){
- drawCircle()
- drawLine(500,30,0,30);
- drawLine(300,20,300,500);
- drawLine(50,20,700,500);
- var x1=0;
- var y1=0;
- //以下是处理拖拽 拖拽的时候,出现一条直线和一个圆
- //注意:由于这些操作都是由DOM来完成的,所以性能开销比较大,尤其是在IE里,明显的会卡一些。
- function down(e){
- var e=e||window.event;
- x1=e.clientX;
- y1=e.clientY;
- document.onmousemove=move;
- document.onmouseup=up;
- }
- function move(e){
- document.getElementById('div1').innerHTML='';
- var e=e||window.event;
- var x2=e.clientX;
- var y2=e.clientY;
- drawLine(x1,y1,x2,y2);//用这个方法就可以在浏览器上拖出一条直线来
- dragCircle(x1,y1,x2,y2);//用这个方法就可以在浏览器上拖出一个圆来
- }
- function up(){
- document.onmousemove=null;
- document.onmouseup=null;
- }
- document.onmousedown=down;
- }
- </script>
- </head>
- <body>
- <div id="div1">在浏览器上拖动鼠标试试</div>
- </body>
- </html>
纯JS画点、画线、画圆的方法的更多相关文章
- javascript画直线和画圆的方法(非HTML5的方法)
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- HTML5画:线、圆、矩形、渐变
示例一:矩形 <!DOCTYPE html><head> <meta charset=utf-8> <title>HTML5画线.圆.矩形</ti ...
- 【液晶模块系列基础视频】4.1.X-GUI图形界面库-画线画圆等函数简介
[液晶模块系列基础视频]4.1.X-GUI图形界面库-画线画圆等函数简介 ============================== 技术论坛:http://www.eeschool.org 博客地 ...
- WPF在圆上画出刻度线
思路 我们可以使用Ellipse先画出一个圆当背景,然后用Canvas再叠加画上刻度线,就能得到如下的效果 我们先用Ellipse画一个橙色的圆,然后将Canvas的宽度和高度绑定到Ellipse的宽 ...
- IOS用CGContextRef画各种图形(文字、圆、直线、弧线、矩形、扇形、椭圆、三角形、圆角矩形、贝塞尔曲线、图片)
... 首先了解一下CGContextRef: An opaque type that represents a Quartz 2D drawing environment. Graphics Con ...
- (转) IOS用CGContextRef画各种图形(文字、圆、直线、弧线、矩形、扇形、椭圆、三角形、圆角矩形、贝塞尔曲线、图片)
首先了解一下CGContextRef: An opaque type that represents a Quartz 2D drawing environment. Graphics Context ...
- [置顶] IOS用CGContextRef画各种图形(文字、圆、直线、弧线、矩形、扇形、椭圆、三角形、圆角矩形、贝塞尔曲线、图片)
首先了解一下CGContextRef: An opaque type that represents a Quartz 2D drawing environment. Graphics Context ...
- ArcGIS API for Flex实现GraphicsLayer上画点、线、面。
目的: ArcGIS API for Flex实现GraphicsLayer上画点.线.面. 准备工作: 1.这次地图数据就用Esri提供的http://server.arcgisonline.com ...
- unity3d NavMeshAgent 寻路画线/画路径
今天在群里看见有个小伙在问Game视图寻路时怎么画线 正好前几天写了个寻路,而且自己也不知道具体怎么在寻路时画线,所以决定帮帮他,自己也好学习一下 在百度查了一下资料,直接搜寻路画路径.寻路画线... ...
随机推荐
- 分布式文件系统HDFS体系
系列文件列表: http://os.51cto.com/art/201306/399379.htm 1.介绍 hadoop文件系统(HDFS)是一个运行在普通的硬件之上的分布式文件系统,它和现有的分布 ...
- 通俗理解C#委托和事件
引言 委托 和 事件在 .Net Framework中的应用非常广泛,然而,较好地理解委托和事件对很多接触C#时间不长的人来说并不容易.它们就像是一道槛儿,过了这个槛的人,觉得真是太容易了,而没有过去 ...
- Cross-Browser HTML5 Placeholder Text
One of the nice enhancement in HTML5 web form is being able to add placeholder text to input fields. ...
- java面试笔试试题http://www.jobui.com/mianshiti/it/java/6827/
一.判断题(每题1分,共10分)1.Applet是一种特殊的Panel,它是Java Applet程序的最外层容器.()2.Java的源代码中定义几个类,编译结果就生成几个以.class为后缀的字节码 ...
- 理解C++ static
1.为什么设计static?考虑下面的需求: 在程序运行过程中,在一个范围内,有一个对象大家共享,而且可以多次使用,状态能够保持,对象的生命周期一直持续到程序运行结束. 2.静态对象要分配在全局数据区 ...
- hdu 5286 How far away ? tarjan/lca
How far away ? Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://acm.hdu.edu.cn/showproblem.php?pi ...
- TP复习11
## ThinkPHP 3.1.2 模板中的基本语法#讲师:赵桐正微博:http://weibo.com/zhaotongzheng 本节课大纲:一.导入CSS和JS文件 1.css link js ...
- 翻译学python---《Learn Python the hard Way》---第一章 绪论
打算学习python,但是又不想单纯地看书或是写个小项目,干脆引入很流行的翻译学习法来学习吧- 在论坛上看到了国外的一本<Learn Python the hard Way> ...
- iOS开发——UI篇Swift篇&UISegmentedControl
UISegmentedControl override func viewDidLoad() { super.viewDidLoad() titleLabel.text = titleString / ...
- 清除SQL Server 2008中登陆时的历史记录
win7 在地址栏直接输入下面路径,删除SqlStudio.bin文件%AppData%\Microsoft\Microsoft SQL Server\100\Tools\Shell