使用JS的画布制作一个瞄准镜
<canvas width="600" height="500" id="myCanvas"></canvas>
<script type="text/javascript">
//获取Canvas对象(画布)
var canvas = document.getElementById("myCanvas");
//获取对应的CanvasRenderingContext2D对象(画笔)
var ctx = canvas.getContext("2d");
//简单地检测当前浏览器是否支持Canvas对象,以免在一些不支持html5的浏览器中提示语法错误
if (ctx) {
//开始一个新的绘制路径
ctx.beginPath();
//设置弧线的颜色为渐变色
var gradient = ctx.createLinearGradient(0, 0, 170, 0);
gradient.addColorStop("0", "#986f0f");
gradient.addColorStop("0.5", "yellow");
gradient.addColorStop("1.0", "orange"); ctx.strokeStyle = gradient;
ctx.lineWidth=5;
var circle = {
x: 100, //圆心的x轴坐标值
y: 100, //圆心的y轴坐标值
r: 50 //圆的半径
};
//沿着坐标点(100,100)为圆心、半径为50px的圆的顺时针方向绘制弧线
ctx.arc(circle.x, circle.y, circle.r, 0, Math.PI * 2, false);
//按照指定的路径绘制弧线
ctx.stroke();
//横线
ctx.moveTo(23,100);
ctx.lineTo(90,100);
ctx.stroke();
ctx.moveTo(106, 100);
ctx.lineTo(180, 100);
ctx.stroke();
//竖线
ctx.moveTo(98,23);
ctx.lineTo(99,88);
ctx.stroke();
ctx.moveTo(98, 110);
ctx.lineTo(99, 175);
ctx.stroke();
}
</script>
使用JS的画布制作一个瞄准镜的更多相关文章
- D3.js(v3)+react   制作 一个带坐标与比例尺的柱形图 (V3版本)
		现在用D3.js + react做一个带坐标轴和比例尺的柱形图.我已经尽力把代码全部注释上了,最后我也会把完整柱形图代码奉上.如果还有疑惑的,可以去翻看一下我之前介绍的方法,以下方法都有介绍到. 还有 ... 
- three.js cannon.js物理引擎制作一个保龄球游戏
		关于cannon.js我们已经学习了一些知识,今天郭先生就使用已学的cannon.js物理引擎的知识配合three基础知识来做一个保龄球小游戏,效果如下图,在线案例请点击博客原文. 我们需要掌握的技能 ... 
- js笔记(制作一个简单的计数器)
		首先编写静态页中的按钮: <input id="result" type="button" value="该程序已经运行了0秒!"/ ... 
- D3.js(v3)+react 制作 一个带坐标轴与比例尺的折线图
		本章使用路径生成器来绘制一个折线图.以中国和日本的GDP数据为例: //数据 var dataList = [ { coountry : "china", gdp : [ [2 ... 
- D3.js(v3)+react 制作 一个带坐标与比例尺的散点图 (V3版本)
		上一章做了柱形图,https://www.cnblogs.com/littleSpill/p/10835041.html 这一章做散点图. 散点图(Scatter Chart),通常是一横一竖 ... 
- 用JS制作一个信息管理平台完整版
		前 言 JRedu 在之前的文章中,介绍了如何用JS制作一个实用的信息管理平台. 但是那样的平台功能过于简陋了,我们今天来继续完善一下. 首先我们回顾一下之前的内容. 1.JSON的基础知识 ... 
- JS制作一个创意数字时钟
		通过js代码制作一个创意数字时钟 通过JS代码实现创意数字时钟效果如下:由数字化的卡通形象图片取代常规的数字显示当前实时北京时间.具体效果示例: 核心重点: (1)Date方法的初步了解 (2)构建模 ... 
- three.js 制作一个三维的推箱子游戏
		今天郭先生发现大家更喜欢看我发的three.js小作品,今天我就发一个3d版本推箱子的游戏,其实webGL有很多框架,three.js并不合适做游戏引擎,但是可以尝试一些小游戏.在线案例请点击博客原文 ... 
- three.js 利用uv和ThreeBSP制作一个快递柜
		最近有three网友,问我要不要学习blender,其实我感觉学习一下也无妨,不过花大量时间精通,尚可不必,术业有专攻给别人留一条路吧,哈哈.那我我们就是用ThreeBSP和uv贴图的知识来制作一个定 ... 
随机推荐
- 常用的Elasticseaerch检索技巧汇总
			本篇博客是对前期工作中遇到ES坑的一些小结,顺手记录下,方便日后查阅. 0.前言 为了讲解不同类型ES检索,我们将要对包含以下类型的文档集合进行检索: . title 标题: . authors 作者 ... 
- Linux 基础命令(一)
			Linux 基础: https://www.cnblogs.com/linhaifeng/articles/6045600.html Linux 比 Windows 更稳定做服务器,开发出来的软件需要 ... 
- php 生成图片,只获取字节数据,不以图片格式输出
			提示:与直接将结果输出到浏览器的任何内容一样,可以使用输出控制函数(http://www.php.net/./en/ref.outcontrol.php)捕获此函数的输出,并将其保存在字符串(例如)中 ... 
- codeforces986F Oppa Funcan Style Remastered【线性筛+最短路】
			容易看出是用质因数凑n 首先01个因数的情况可以特判,2个的情况就是ap1+bp2=n,b=n/p2(mod p1),这里的b是最小的特解,求出来看bp2<=n则有解,否则无解 然后剩下的情况最 ... 
- kettle的使用(ETL,数据仓库技术)
			本周项目上用到了kettle并且需要做任务调度,听老师说用kettle自带的调度不大稳定于是便baidu了下,参照这篇文章完成了通过kitchen的调度,简单说就是通过windows的计划任务来调用. ... 
- MPlayer 常用操作和快捷键列表
			MPlayer,一款强大的老牌开源播放器,非常适合命令行重度用户和极简主义者.很多时候它是作为其他著名播放器的后端存在的,直接使用基于命令行的本身对于很多新手来说就一头雾水了.比如播放视频的时候,窗口 ... 
- SQLServer数据库表字段超长,找到超长字段脚本
			平时开发系统时偶尔会遇到数据超长导致往数据库中保存时出错. 使用下边的脚本可以方便的找出超长的字段. 1.通过正式表创建临时表,修改临时表中varchar.nvarchar的长度为max ); ); ... 
- 持续集成~Jenkins构建GitHub项目的实现
			有了前两讲的基础,这回我们就可以把github上的项目做到CI(jenkins)里了,让它自动去集成部署,持续集成~Jenkins里的NuGet和MSBuild插件,持续集成~Jenkins里的pow ... 
- 语义分割丨PSPNet源码解析「测试阶段」
			引言 本文接着上一篇语义分割丨PSPNet源码解析「网络训练」,继续介绍语义分割的测试阶段. 模型训练完成后,以什么样的策略来进行测试也非常重要. 一般来说模型测试分为单尺度single scale和 ... 
- java类在eclipse上打jar包,Linux上成功运行的实例
			1 eclipse下的java项目结构如下图所示: 2 打包的步骤如下: 3 修改minifest.mf文件: 4 .上传需要的三方jar包们和主类打的jar(案例是topV.jar)并且执行jav ... 
