<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Document</title>
</head>
<style>
#canvas-wrapper{
width: 1200px;
height: 800px;
position: relative;
margin:50px auto;
}
#canvas{
border: 1px #ddd solid;
}
#controller{
position: absolute;
top:30px;
left:30px;
background:rgba(0,85,116,0.7);
padding:5px 20px 25px 20px;
border-radius: 10px 10px;
}
#controller h1{
color: white;
font-weight: bold;
font-family: "Microsoft Yahei";
}
#controller #canvas-btn{
display: inline-block;
background: #8b0;
color: white;
font-size: 14px;
padding: 5px 15px;
}
#controller #canvas-btn:hover{
text-decoration: none;
background:#7a0;
}
#controller .color-btn{
display: inline-block;
padding:5px 15px;
border-radius: 6px 6px;
font-size: 14px;
margin-top: 10px;
margin-right: 5px;
text-decoration: none;
}
#controller .color-btn:hover{
text-decoration: none;
}
#controller #white-color-btn{
background-color: white;
}
#controller #black-color-btn{
background-color: black;
}
</style>
<body>
<div id="canvas-wrapper">
<canvas id="canvas">
当前游览器不支持Canvas,请更换游览器再试!
</canvas>
<div id="controller">
<h1>Canvas 绘图之旅</h1>
<a href="#" id="canvas-btn">stop</a>
<a href="#" class="color-btn" id="white-color-btn">white</a>
<a href="#" class="color-btn" id="black-color-btn">black</a>
</div>
</div> <script>
var balls = [];
var isMoving = true;
var themeColor = "white";
var canvas = document.getElementById("canvas"); window.onload = function(){ canvas.width = 1200;
canvas.height = 800; if(canvas.getContext('2d')){
var context = canvas.getContext('2d'); // 产生100个小球
for(var i=0;i<100;i++){
var R = Math.floor(Math.random()*255);
var G = Math.floor(Math.random()*255);
var B = Math.floor(Math.random()*255);
var radius = Math.random()*50+20; aBall = {
color : "rgb(" + R + "," + G + "," + B + ")",
radius : radius,
x : Math.random()*(canvas.width-2*radius) + radius,
y : Math.random()*(canvas.height-2*radius) + radius,
vx : (Math.random()*5 + 5) * Math.pow(-1,Math.floor(Math.random()*100)),
vy : (Math.random()*5 + 5) * Math.pow(-1,Math.floor(Math.random()*100)),
} balls[i] = aBall;
} // 绘制并运动
setInterval(function(){
draw(context);
if(isMoving){
update(canvas.width,canvas.height)
}
},50) // stop
document.getElementById("canvas-btn").onclick = function(event){
if(isMoving){
isMoving = false;
this.text = "start";
}else{
isMoving = true;
this.text = "stop";
}
return false;
} // white
document.getElementById("white-color-btn").onclick = function(event){
themeColor = "white";
return false;
} // black
document.getElementById("black-color-btn").onclick = function(event){
themeColor = "black";
return false;
}
}else{
alert("当前游览器不支持Canvas,请更换游览器再试!")
}
} function draw(cxt){
// var canvas = cxt.canvas;
cxt.clearRect(0,0,canvas.width,canvas.height); if(themeColor == "black"){
console.log("black theme");
cxt.fillStyle = "black";
cxt.fillRect(0,0,canvas.width,canvas.height)
} for(var i=0;i<balls.length;i++){
cxt.fillStyle = balls[i].color;
cxt.beginPath();
cxt.arc(balls[i].x,balls[i].y,balls[i].radius,0,Math.PI*2);
cxt.closePath();
cxt.fill();
}
} function update(){
for(var i=0;i<balls.length;i++){
balls[i].x += balls[i].vx;
balls[i].y += balls[i].vy; // 边缘检测
if(balls[i].x - balls[i].radius <= 0){
balls[i].vx = -balls[i].vx;
balls[i].x = balls[i].radius;
} if(balls[i].x + balls[i].radius >= canvas.width){
balls[i].vx = -balls[i].vx;
balls[i].x = canvas.width - balls[i].radius;
} if(balls[i].y - balls[i].radius <= 0){
balls[i].vy = -balls[i].vy;
balls[i].y = balls[i].radius;
} if(balls[i].y + balls[i].radius >= canvas.height){
balls[i].vy = -balls[i].vy;
balls[i].y = canvas.height - balls[i].radius;
}
}
}
</script>
</body>
</html>

canvas-a11htmlANDcanvas.html的更多相关文章

  1. html5 canvas常用api总结(三)--图像变换API

    canvas的图像变换api,可以帮助我们更加方便的绘画出一些酷炫的效果,也可以用来制作动画.接下来将总结一下canvas的变换方法,文末有一个例子来更加深刻的了解和利用这几个api. 1.画布旋转a ...

  2. 【探索】利用 canvas 实现数据压缩

    前言 HTTP 支持 GZip 压缩,可节省不少传输资源.但遗憾的是,只有下载才有,上传并不支持.如果上传也能压缩,那就完美了.特别适合大量文本提交的场合,比如博客园,就是很好的例子. 虽然标准不支持 ...

  3. 简单入门canvas - 通过刮奖效果来学习

    一 .前言 一直在做PC端的前端开发,从互联网到行业软件.最近发现移动端已经成为前端必备技能了,真是不能停止学习.HTML5新增的一些东西,canvas是用的比较多也比较复杂的一个,简单的入门了一下, ...

  4. 获取Canvas当前坐标系矩阵

    前言 在我的另一篇博文 Canvas坐标系转换 中,我们知道了所有的平移缩放旋转操作都会影响到画布坐标系.那在我们对画布进行了一系列操作之后,怎么再知道当前矩阵数据状态呢. 具体代码 首先请看下面的一 ...

  5. Canvas坐标系转换

    默认坐标系与当前坐标系 canvas中的坐标是从左上角开始的,x轴沿着水平方向(按像素)向右延伸,y轴沿垂直方向向下延伸.左上角坐标为x=0,y=0的点称作原点.在默认坐标系中,每一个点的坐标都是直接 ...

  6. Canvas绘图之平移translate、旋转rotate、缩放scale

    画布操作介绍 画布绘图的环境通过translate(),scale(),rotate(), setTransform()和transform()来改变,它们会对画布的变换矩阵产生影响. 函数 方法 描 ...

  7. 用html5的canvas和JavaScript创建一个绘图程序

    本文将引导你使用canvas和JavaScript创建一个简单的绘图程序. 创建canvas元素 首先准备容器Canvas元素,接下来所有的事情都会在JavaScript里面. <canvas ...

  8. html5标签canvas函数drawImage使用方法

    html5中标签canvas,函数drawImage(): 使用drawImage()方法绘制图像.绘图环境提供了该方法的三个不同版本.参数传递三种形式: drawImage(image,x,y):在 ...

  9. 使用 JavaScript 和 canvas 做精确的像素碰撞检测

    原文地址:Pixel accurate collision detection with Javascript and Canvas 译者:nzbin 我正在开发一个需要再次使用碰撞检测的游戏.我通常 ...

  10. H5项目开发分享——用Canvas合成文字

    以前曾用Canvas合成.裁剪.图片等<用H5中的Canvas等技术制作海报>.这次用Canvas来画文字. 下图中"老王考到驾照后"这几个字是画在Canvas上的,与 ...

随机推荐

  1. 终端(命令行)连接MySQL

    语法: mysql -h 主机名(ip) -u 用户名 -P 端口 -p 说明: -h: 主机名,表示要连接的数据库的主机名或者IP -u: 用户名,表示连接数据库的用户名 -P: 端口,表示要连接的 ...

  2. eclipse如何使用log4j详解,你get了吗???

    1.下载log4j    jar包 log4j下载地址 http://logging.apache.org/log4j/2.x/download.html 2.log4j   jar包引入项目 接下来 ...

  3. AI - 机器学习常见算法简介(Common Algorithms)

    机器学习常见算法简介 - 原文链接:http://usblogs.pwc.com/emerging-technology/machine-learning-methods-infographic/ 应 ...

  4. .net core dump分析

    服务器上如果出现cpu内存饱满,找不到原因,那么dump文件分析必不可少. 起初是想在linux下调试.net core 的dump,但是环境一直无法安装 搞了许久没搞出来,其次文章太少了,googl ...

  5. 'QueryDict' object is not callable 错误解析

    我把request内置库和 requests库  给搞混了 requests使用来发送请求的, request 而是用来获取数据的 别看只有一个单词只差,却让我找了大半天 requests.post( ...

  6. 使用 SonarQube 来分析 .NET Core 项目代码问题

    0.介绍 Sonar 是一款开源的代码分析工具,可能有很多人已经用过,本篇文章主要是讲解如何在 Docker 里面安装 Sonar 并且用其来分析 .Net Core 项目. Sonar 是一个用于代 ...

  7. AspNetCore微服务下的网关-Kong(一)

    Kong是Mashape开源的高性能高可用API网关和API服务管理层.它基于OpenResty,进行API管理,并提供了插件实现API的AOP.Kong在Mashape 管理了超过15,000 个A ...

  8. Mybatis 源码简述

    转载请注明来自:http://www.cnblogs.com/xmzJava/p/8578399.html 日常开发中,mybatis如果报错了调错起来会比较麻烦,因为一层套着一层,如果没有对myba ...

  9. 一个前端开发者换电脑的过程(node & 淘宝镜像篇)

    当然,在我们安装了git和vscode之后,我们这个项目,在本地仍然是跑不起来的对吗?这句“npm run dev”就提示着我们需要有一个npm,npm是一个很强大的包管理工具,就像是安卓的应用商店, ...

  10. github提交代码contributions不显示小绿块

    问题描述: 最近发现一个问题就是不管是提交新增的代码还是修改后提交的代码在github的contributions上都不显示贡献小绿块. 于是我在 github help 里面找到了答案: 官方链接如 ...