Beizer。。。。。
<html>
<head>AS</head>
<script>
var cvs;
var context;
//context.fill();//填充
//context.stroke();//绘制边框
//context.fillStyle = "#FF0000";
//context.fillRect(20,20,200,200); function DrawBezier(p0,p1,p2)
{
context.strokeStyle = "#000000";
context.beginPath(); for(var i = 0;i < 1;i += 0.001)
{
var x0 = (1 - i) * (1-i) * p0.x;
var y0 = (1 - i) * (1-i) * p0.y;
var x1 = (1 - i) * 2*i * p1.x;
var y1 = (1 - i) * 2*i* p1.y;
var x2 = i * i * p2.x;
var y2 = i * i * p2.y;
if(i == 0)
context.moveTo(x0+x1+x2,y0+y1+y2);
else
context.lineTo(x0+x1+x2,y0+y1+y2);
}
//context.closePath();
context.stroke();
}
// p1,p2为控制点
function DrawBezier3(p0,p1,p2,p3)
{
context.strokeStyle = "#000000";
context.beginPath(); for(var i = 0;i < 1;i += 0.001)
{
var a = 1 - i;
var x0 = a * a * a * p0.x;
var y0 = a * a * a * p0.y;
var x1 = 3 * i * i * a * p1.x;
var y1 = 3 * i * i * a * p1.y;
var x2 = 3 * i * a * a * p2.x;
var y2 = 3 * i * a * a * p2.y;
var x3 = i * i * i * p3.x;
var y3 = i * i * i * p3.y;
var x = x0 + x1 + x2 + x3;
var y = y0 + y1 + y2 + y3;
if(i == 0)
context.moveTo(x,y);
else
context.lineTo(x,y);
}
//context.closePath();
context.stroke();
}
function DrawPoint(x,y,rad)
{
context.fillStyle = "#FF0000";
context.beginPath();
//ctx.arc(开始原点x,开始原点y,半径,起始弧度,终止弧度,true表示逆时针动画)
context.arc(x, y, rad, rad, Math.PI * 2, true);
context.closePath();
context.stroke();
context.fill();
}
function DrawP(p)
{
DrawPoint(p.x,p.y,5);
} var pA = {"x":20,"y":280};
var pB = {"x":120,"y":280};
var pC = {"x":220,"y":20};
var pD = {"x":120,"y":20}; window.onload = function()
{
cvs = document.getElementById("cvs");
context = cvs.getContext("2d");
context.lineWidth="1";
context.strokeStyle = "#00000";
DrawBezier(pA,pB,pC);
DrawBezier3(pA,pB,pD,pC);
DrawP(pA);
//DrawP(pB);
DrawP(pC);
//DrawP(pD);
};
var id = 0;
function onChange(v)
{
id = v;
}
function onClick(v)
{
var x = document.getElementById("x").value;
var y = document.getElementById("y").value;
console.log(x+","+y);
if(id == "0")
{
pA.x = parseInt(x);
pA.y = parseInt(y);
}else if(id == "1")
{
pB.x = parseInt(x);
pB.y = parseInt(y);
}else if(id == "2")
{
pC.x = parseInt(x);
pC.y = parseInt(y);
}else if(id == "3")
{
pD.x = parseInt(x);
pD.y = parseInt(y);
}
//cvs.height = height;
context.clearRect(0,0,cvs.width,cvs.height);
DrawBezier(pA,pB,pC);
DrawBezier3(pA,pB,pD,pC);
DrawP(pA);
DrawP(pB);
DrawP(pC);
DrawP(pD);
} </script>
<body>
<div>
<input type="text" id="id" onchange="onChange(this.value)">
<input type="text" id="x" onchange="">
<input type="text" id="y" onchange="">
<button onclick="onClick()">click</button>
</div>
<canvas id="cvs" width="800px" height="800px"></canvas> </body>
</html>
<script> </script>
Beizer。。。。。的更多相关文章
- 查询oracle数据库,返回的数据是乱码。 PL/SQL正常。
查询oracle数据库,返回的数据是乱码. PL/SQL正常. 解决方案如下:
- vmware workstation 上创建的centos 7.2 ,新添加一块网卡。无法找到配置文件。
在vmware workstation 11上,新建一个centos 7.2系统. 初装带有一个块网卡:能够在/etc/sysconfig/network-scripts/目录下找到相应的网卡配置文件 ...
- 分配给 主机的 Evaluation Mode 许可证已过期。建议升级许可证。
参考文献 http://247its.wordpress.com/2012/04/02/new-build-esxi-5-complaints-licence-has-expired/ http:// ...
- 解决ftp连接出现 无法从控制 Socket 读取。Socket 错误 = #10054。
ftp连接会显示以下错误信息 无法从控制 Socket 读取.Socket 错误 = #10054 或者是这样的信息 Opening data channel for directory list.T ...
- asp.net C# 未能加载文件或程序集或它的某一个依赖项。需要强名称程序集。的解决办法
asp.net C# 未能加载文件或程序集或它的某一个依赖项.需要强名称程序集.的解决办法 出现这个错误是原因:是有签名的DLL引用了无签名的DLL 如上图所示,就是因为引用Entity.MVCEnt ...
- 存储区更新、插入或删除语句影响到了意外的行数(0)。实体在加载后可能被修改或删除。刷新 ObjectStateManager 项。
在用asp.net MVC3 的MusicStore时候 Edit某个数据项时提示下面的错误: 存储区更新.插入或删除语句影响到了意外的行数(0).实体在加载后可能被修改或删除.刷新 ObjectSt ...
- (转)要“jquery”ScriptResourceMapping。请添加一个名为 jquery (区分大小写)的 ScriptResourceMapping。”的解决办法。
要“jquery”ScriptResourceMapping.请添加一个名为 jquery (区分大小写)的 ScriptResourceMapping.”的解决办法. 1.先将aspnet.scri ...
- web系列教程之php 与mysql 动态网站 。检索 与更新。
接着上次WEb 系列开发之php 与mysql动态网站入门. 个人觉得,学习技术就像一棵大树,主干很重要,枝叶其次.对于学习技术,我们应该分清主次关系.怎么学?为什么要学?有一个较好的分寸. 有时候觉 ...
- 保存项目文件“XXX.csprj”时出错。类没有注册。
[出错提示]保存项目文件“XXX”时出错.类没有注册.正在查找具有CLSID的对象:{D9B3211D-E57F-4426-AAEF-30A806ADD397}. [解决办法] 需要安装:MSXML_ ...
- 2. SharePoint Online 开发,请联系qq512800530。加好备注。(不要发站内信。。。)
///(不要发站内信...) <meta name="keywords" content="SharePoint Online, SP Online, SPO, S ...
随机推荐
- Java 8 中Stream用法
Stream是Java 8新增的接口,Stream可以认为是一个高级版本的 Iterator. 废话不多说直接上代码 package com.example.demo; import org.juni ...
- insert into select [SQL]
insert into `d_mx_think`.`su_article` (id,catid,title,url) select id,catid,title,url from d_mx_phpcm ...
- NOIP模拟63
T1 电压机制 解题思路 先找出这个图的一个生成树,然后没有称为树边的边就都是返祖边了. 对于一个边是合法的当且仅当它属于所有的奇数环并且不属于任何一个偶数环. 可以利用树上差分进行修改,更改一个返祖 ...
- grid 布局兼容性问题
低版本的安卓机上是不生效的 代码 .grid_4 { display: grid; grid-template-columns: repeat(4, 1fr); grid-template-rows: ...
- Linux 提权-Cron Jobs
本文通过 Google 翻译 Cron Jobs – Linux Privilege Escalation - Juggernaut-Sec 这篇文章所产生,本人仅是对机器翻译中部分表达别扭的字词进行 ...
- LeetCode 685. Redundant Connection II 冗余连接 II (C++/Java)
题目: In this problem, a rooted tree is a directed graph such that, there is exactly one node (the roo ...
- edge 书签栏 收藏夹栏 字体大小
WIN10中,edge收藏夹栏字体太大,如果收藏数目多,得多翻好几页. 解决方法: 地址栏中输入: edge://flags/#edge-pc-ui-integration Enable Window ...
- ElasticSearch基于安装包方式安装
1.下载地址 https://artifacts.elastic.co/downloads/elasticsearch/elasticsearch-6.5.4.tar.gz2.解压 tar -zxvf ...
- Mysql性能优化(详解)
引言 今天,数据库的操作越来越成为整个应用的性能瓶颈了,这点对于Web应用尤其明显.关于数据库的性能,这并不只是DBA才需要担心的事,而这更是我们程序员需要去关注的事情.当我们去设计数据库表结构,对操 ...
- LocalDateTime日期相互转换字符串
/** LocalDateTime日期相互转换字符串 * 默认的时间日期样式 */ public static final String YYYYMMDDHHMMSSS_PATTERN = " ...