<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。。。。。的更多相关文章

  1. 查询oracle数据库,返回的数据是乱码。 PL/SQL正常。

    查询oracle数据库,返回的数据是乱码. PL/SQL正常. 解决方案如下:

  2. vmware workstation 上创建的centos 7.2 ,新添加一块网卡。无法找到配置文件。

    在vmware workstation 11上,新建一个centos 7.2系统. 初装带有一个块网卡:能够在/etc/sysconfig/network-scripts/目录下找到相应的网卡配置文件 ...

  3. 分配给 主机的 Evaluation Mode 许可证已过期。建议升级许可证。

    参考文献 http://247its.wordpress.com/2012/04/02/new-build-esxi-5-complaints-licence-has-expired/ http:// ...

  4. 解决ftp连接出现 无法从控制 Socket 读取。Socket 错误 = #10054。

    ftp连接会显示以下错误信息 无法从控制 Socket 读取.Socket 错误 = #10054 或者是这样的信息 Opening data channel for directory list.T ...

  5. asp.net C# 未能加载文件或程序集或它的某一个依赖项。需要强名称程序集。的解决办法

    asp.net C# 未能加载文件或程序集或它的某一个依赖项.需要强名称程序集.的解决办法 出现这个错误是原因:是有签名的DLL引用了无签名的DLL 如上图所示,就是因为引用Entity.MVCEnt ...

  6. 存储区更新、插入或删除语句影响到了意外的行数(0)。实体在加载后可能被修改或删除。刷新 ObjectStateManager 项。

    在用asp.net MVC3 的MusicStore时候 Edit某个数据项时提示下面的错误: 存储区更新.插入或删除语句影响到了意外的行数(0).实体在加载后可能被修改或删除.刷新 ObjectSt ...

  7. (转)要“jquery”ScriptResourceMapping。请添加一个名为 jquery (区分大小写)的 ScriptResourceMapping。”的解决办法。

    要“jquery”ScriptResourceMapping.请添加一个名为 jquery (区分大小写)的 ScriptResourceMapping.”的解决办法. 1.先将aspnet.scri ...

  8. web系列教程之php 与mysql 动态网站 。检索 与更新。

    接着上次WEb 系列开发之php 与mysql动态网站入门. 个人觉得,学习技术就像一棵大树,主干很重要,枝叶其次.对于学习技术,我们应该分清主次关系.怎么学?为什么要学?有一个较好的分寸. 有时候觉 ...

  9. 保存项目文件“XXX.csprj”时出错。类没有注册。

    [出错提示]保存项目文件“XXX”时出错.类没有注册.正在查找具有CLSID的对象:{D9B3211D-E57F-4426-AAEF-30A806ADD397}. [解决办法] 需要安装:MSXML_ ...

  10. 2. SharePoint Online 开发,请联系qq512800530。加好备注。(不要发站内信。。。)

    ///(不要发站内信...) <meta name="keywords" content="SharePoint Online, SP Online, SPO, S ...

随机推荐

  1. C#WPF的多屏显示问题

    如果想让窗口在第二个屏幕中显示 public MainWindow() { InitializeComponent(); Screen[] _screens = Screen.AllScreens; ...

  2. iOS技术管理思路

    iOS技术管理思路

  3. nginx+php,nginx+tomcat动静分离实战

    1. 动静分离实战 1.1.1 nginx+tomcat 动静分离 主机 用途 10.0.0.63 tomcat服务器 10.0.0.64 nginx服务器 1.1.2 安装 java+tomcat环 ...

  4. iOS MonkeyDev 尝试体验(非越狱开发)

    一.前言 随着iOS系统的逐渐开放,iOS越狱需求的人越来越少,那么在非越狱系统上面开发越狱插件那将是一个不错的选择,在github上面发现一个开源的Xcode工程模板. 整合了越狱开发的工具.重签名 ...

  5. 面试官:说说Netty对象池的实现原理?

    Netty 作为一个高性能的网络通讯框架,它内置了很多恰夺天工的设计,目的都是为了将网络通讯的性能做到极致,其中「对象池技术」也是实现这一目标的重要技术. 1.什么是对象池技术? 对象池技术是一种重用 ...

  6. memo(自带)

    React.memo()是一个高阶函数,它与 React.PureComponent类似,但是一个函数组件而非一个类.如果你的组件在相同 props的情况下渲染相同的结果,那么你可以通过将其包装在 R ...

  7. Javascript高级程序设计第一章 | ch1 | 阅读笔记

    什么是JavaScript 历史回顾 JavaScript实现 完整的JavaScript实现包括 核心 ECMAScript -> 语法.类型.关键字.保留字...(规范) 文档对象模型 DO ...

  8. jdk17+spring6下打jar包

    由于特定情况,本机下有多个jdk,而JAVA_HOME又只有一个. 本人习惯在命令行下一个命令编译打包程序,如何解决这个问题? 研究了不少时间,得到了两个解决方案: 1.使用bat   --  非常烂 ...

  9. ZYNQ Linux使用SPI驱动

    --- title: ZYNQ Linux使用SPI驱动 EntryName: xilinx-zynq-using-spi-driver-in-linux date: 2020-10-14 10:02 ...

  10. 下载 Linux 内核的脚本

    介绍 在 类UNIX 环境下运行比较好(基于wget) 包括了 2.6 ~ 4.x 内核的地址. 5.x 因为 还在更新因此不做记录. 脚本下载地址: https://files.cnblogs.co ...