样例:http://www.zhaojz.com.cn/demo/draw10.html

依赖:【点】、【直线】

//过直线外一点画垂线
function drawVerticalLine(point, line){
//画辅助线-start
var color = 'DarkRed'; //垂线的颜色
var color2 = "#ccc"; //其它辅助线的颜色
drawPoint({
pw:2,ph:2,color:'DarkRed',point: line[0]
});
drawPoint({
pw:2,ph:2,color:'DarkRed',point: line[1]
});
drawLine(point, line[0], {color: color2});
drawLine(point, line[1], {color: color2});
//画辅助线-end drawPoint({
pw:2,ph:2,color:'DarkRed',point: point
}); var v_1_0 = line[1][1]-line[0][1];
var h_1_0 = line[1][0]-line[0][0];
var c_square = Math.pow(v_1_0,2) + Math.pow(h_1_0,2);
var c = Math.sqrt(c_square); //计算直线上两点之间的距离 var a_b_slope = 0;
var hasSlope = true;
if(v_1_0 == 0){
hasSlope = false;
}
a_b_slope = v_1_0/h_1_0; //直线的斜率 var point_pos = 1; //定义point与直线的位置关系
//当直线的斜率大于0时,如果点在直线上方,point_pos = 1,如果点在直线下方,point_pos = 3
//当直线的斜率小于0时,如果点在直线上方,point_pos = 2,如果点在直线下方,point_pos = 4
if(hasSlope){
var a_b_intercept = line[1][1]-a_b_slope*line[1][0];
var p_intercept = point[1]-a_b_slope*point[0];
if(a_b_slope >= 0){
if(p_intercept > a_b_intercept){
point_pos = 3;
}else{
point_pos = 1;
}
}else{
if(p_intercept < a_b_intercept){
point_pos = 2;
}else{
point_pos = 4;
}
}
}
//A为直线与水平线的夹角(锐角)
var sinA = Math.abs(v_1_0)/c; //sinA
var cosA = Math.abs(h_1_0)/c; //cosA
//C为垂线在顺时针方向上与水平线的夹角
var sinC = 0;
var cosC = 0;
//D为过point与line的平行线与水平线的夹角
var sinD = 0;
var cosD = 0;
switch(point_pos){
case 1:
sinC = cosA;
cosC = -sinA;
sinD = -cosC;
cosD = sinC;
break;
case 2:
sinC = cosA;
cosC = sinA;
sinD = cosC;
cosD = -sinC;
break;
case 3:
sinC = -cosA;
cosC = sinA;
sinD = cosC;
cosD = -sinC;
break;
case 4:
sinC = -cosA;
cosC = -sinA;
sinD = -cosC;
cosD = sinC;
break;
default:
}
//过point画line的平行线
drawLine(point, [point[0]+c*cosD, point[1]+c*sinD], {color: 'Red'});
drawLine(point, [point[0]+c*(-cosD), point[1]+c*(-sinD)], {color: 'Red'}); var point_v_1 = point[1]-line[1][1];
var point_h_1 = point[0]-line[1][0];
var point_dist_1 = Math.sqrt(Math.pow(point_v_1,2)+Math.pow(point_h_1,2)); //point到line上一点的距离
var point_v_0 = point[1]-line[0][1];
var point_h_0 = point[0]-line[0][0];
var point_dist_0 = Math.sqrt(Math.pow(point_v_0,2)+Math.pow(point_h_0,2)); //point到line上另外一点的距离
var s = (c+point_dist_1+point_dist_0)/2;
var area = Math.sqrt(s*(s-c)*(s-point_dist_0)*(s-point_dist_1)); //以point、line[0]和line[1]为顶点的三角形的面积
var h = 2*area/c; //三角形的高 var vpoint = [point[0]+h*cosC, point[1]+h*sinC]; //垂点
drawLine(point, vpoint); //画垂线
}

JS画几何图形之六【过直线外一点作垂线】的更多相关文章

  1. JS画几何图形之一【直线】

    JS画图的想法经过大脑的时候,觉得有点意思,所以就实践了一番.JS画图为系列文章,本是讲点.线和面 先看样例:http://www.zhaojz.com.cn/demo/draw5.html 一.点 ...

  2. JS画几何图形之五【过圆外一点作切线】

    样例:http://www.zhaojz.com.cn/demo/draw9.html 依赖:[点].[直线].[圆] //画切线 //point 圆外的一点 //dot 圆心 //r 半径 func ...

  3. JS画几何图形之三【正弦曲线】

    数学式:y=Asin(ωx+φ)+k 样例:http://www.zhaojz.com.cn/demo/draw7.html 依赖:[点].[直线] JS函数的声明: //画正弦曲线 //dot 原点 ...

  4. JS画几何图形之二【圆】

    半径为r的圆上的点p(x,y)与圆心O(x0,y0)的关系: x = x0+rcosA;  y = y0+rsinA ,A为弧度 样例:http://www.zhaojz.com.cn/demo/dr ...

  5. JS画几何图形之四【饼图】

    饼图是将一个圆分割为多个扇形. 样例:http://www.zhaojz.com.cn/demo/draw8.html 依赖:[扇形] //饼图 //dot 圆点 //r 半径 //data 数据(一 ...

  6. MT【45】抛物线外一点作抛物线的切线(尺规作图题)

    注1:S为抛物线焦点 注2:由切线的唯一性,以及切线时可以利用MT[42]评得到三角形全等从而得到切线平分$\angle MQS$得到

  7. 用JS画斐波那契螺旋线(黄金螺旋线)

    偶然看到斐波那契螺旋线(黄金螺旋线)的定义及画图方法,试着用JS画了一下,很漂亮,很好玩 具体定义及画法大家查一下就有了,很简单. 以下是代码: <!DOCTYPE html> <h ...

  8. js画一棵树

    用纯js画一棵树.思路: 1.一棵树的图片,作为页面背景: 2.通过html5中的canvas画布进行遮罩: 3.定时每隔10ms,从下往上清除1px的遮罩: <!DOCTYPE html> ...

  9. jquery.wordexport.js打印echarts.js画出的柱状图

    jquery.wordexport.js打印echarts.js画出的柱状图. echarts画出的图是不能直接打印出来的(echarts的柱状图是用canvas画出来的),而jquery.worde ...

随机推荐

  1. Linux上安装和卸载mysql数据库 (一)

    一.前言 第一次写博客,很激动同时有点畏惧,激动是我可以将我的经验进行分享,畏惧是我怕我写的东西,大家借鉴的时候,有些步骤不能成功.不过,我还是很有信息的,我分享的经验都是我搭建成功以后才分享出来.这 ...

  2. 查看.ssh文件在哪

    输入命令 ll -d ~/.ssh 后你就都明白了.

  3. python之列表(list)的使用方法介绍

    python之列表(list)介绍 在python的使用过程中,我们经常会用到列表,然而经常会遇到疑惑,下面我将详细介绍下列表使用方法. 一.列表 列表经常用到的功能使增.删.改和查功能. 1. 增 ...

  4. BST 解析 (二)height and deletion

    前面一章介绍了BST的结构和一些简单的基本功能,例如:insert,findMin,nextLarger等等.这一节主要讲解一些BST的delete node操作还有BST的height的分析以及一些 ...

  5. Java内存模型与Java线程实现原理

    硬件的效率与一致性 基于高速缓存的存储交互很好的解决了处理器和内存的速度矛盾,但是也为计算机系统带来了更高的复杂度,因为引入了一个新问题:缓存一致性. 在多处理器系统中,每个处理器都有自己的高速缓存, ...

  6. 【读书笔记】《Effective Java》——创建和销毁对象

    Item 1. 考虑用静态工厂方法替代构造器 获得一个类的实例时我们都会采取一个共有的构造器.Foo x = new Foo(): 同时我们应该掌握另一种方法就是静态工厂方法(static facto ...

  7. NYOJ 119 士兵杀敌(三) RMQ ST

    NYOJ 119 士兵杀敌(三) RMQ ST 题目链接:http://acm.nyist.net/JudgeOnline/problem.php?pid=119 思路: ST在线 预处理O(nlog ...

  8. 51Nod1136--欧拉函数

    1136 欧拉函数 基准时间限制:1 秒 空间限制:131072 KB 分值: 0 难度:基础题  收藏  关注 对正整数n,欧拉函数是少于或等于n的数中与n互质的数的数目.此函数以其首名研究者欧拉命 ...

  9. Linux学习之在搭建java开发环境

    首先,在官网上下载你需要的JDK 然后 解压包  tar -zxvf 包名 配置环境变量 vim /etc/profile 如果权限不够,就使用sudo vim /etc/profile 在profi ...

  10. SQL Server学习之路(五):“增删改查”之“改”

    0.目录 1.前言 2.通过SSMS修改数据 3.通过SQL语句修改数据 3.1 修改单列数据 3.2 修改多列数据 1.前言 增删改查都是对数据的操作,其中"改"对应的SQL语句 ...