CSS3-canvas绘制线性渐变
<!doctype html>
<html>
<head>
<meta charset="utf-8">
<title>canvas绘制线性渐变-高级函数</title>
</head>
<body onLoad="draw('canvas')">
<canvas id="canvas" width="1300" height="500" />
<script type="text/javascript">
function draw(id){
var canvas = document.getElementById(id);
if (canvas == null)
return false;
var context = canvas.getContext('2d');
context.fillStyle = "#f0f0f0";
context.fillRect(0, 0, 1300, 500);/*填充矩形背景色*/
var gl = context.createLinearGradient(0, 0, 1300, 500);/*定义渐变的方向吧,0,0是渐变起点的坐标,300,300是重点的坐标,这样写是一个正方形的对角线渐变。如果是0,0,0,300,则是由上自下的一个垂直渐变*/
gl.addColorStop(0, 'rgb(155, 0, 255)' );/*指定渐变的颜色额,两个值(offset, color)其中,color值可以有fillstyle的四种一样额形式#十六进制、rgb、rgba、英文单词等都可以,而前边的offset值只可以在0-1之间,是指颜色离开渐变点的偏移量。。addColorStop可以不止两个,可以定义很多次,但是,最少有两个,用以定义开始颜色和结束颜色。而且,开始的偏移值必须为0,结束的偏移值必须为1 ,中间的必须在0-1之间*/
<!--另外,createLinearGradient和addColorStop一定是紧接着写的-->
gl.addColorStop(1, 'rgb(255, 0, 255)');
context.fillStyle = gl;/*fillStyle不止填充颜色一种形式,这里呢,填充渐变是另一种形式,还有填充图像和文字等。但是,这个填充渐变,不是直接写的是,而是用一个变量gl代替context.createLinearGradient的形式,然后style再等于变量gl就可以了*/
context.fillRect(0, 0, 1300, 500);/*画出要填充的范围*/
<!--/*---------------------------------------以上为背景的渐变------------------------------------------------*/-->
var g2 = context.createLinearGradient(0, 0, 0, 400);/*这样是垂直的渐变*/
g2.addColorStop(0, 'rgba(154, 255, 0, 0.25)');
g2.addColorStop(0.5, 'rgba(100, 255, 60, 0.35)');
g2.addColorStop(1, 'rgba(60, 255, 173, 0.55)');
for (var i=0; i<10; i++){
context.beginPath();
context.arc(i * 25, i * 25, i * 25, 0, Math.PI * 2, true);
context.closePath();
context.fillStyle = g2;
context.fill();
}
<!--这个效果是先定义一个线性渐变样式,再设置渐变的颜色,这里设置了三个,然后用一个for循环,做出十个圆形,最后填充圆形的样式和颜色-->
}
</script>
</body>
</html>
CSS3-canvas绘制线性渐变的更多相关文章
- 深入理解css3中的线性渐变
css3中的线性渐变 线性渐变公式: background-image: linear-gradient( [ <angle> | <side-or-corner> ]?, & ...
- CSS3中颜色线性渐变实战
css3线性渐变可以设置3个参数值:方向.起始颜色.结束颜色.最简单的模式只需要定义起始颜色和结束颜色,起点.终点和方向默认自元素的顶部到底部.下面举例说明: CSS Code复制内容到剪贴板 .te ...
- Canvas绘制渐变
1.绘制线性渐变 Canvas提供了用于创建线性渐变的函数createLinearGradient(x0,y0,x1,y1),坐标点(x0,y0)是起点 ,(x1,y1)是终点 创建一个渐变色 var ...
- 再说CSS3渐变——线性渐变
渐变背景一直以来在Web页面中都是一种常见的视觉元素.但一直以来,Web设计师都是通过图形软件设计这些渐变效果,然后以图片形式或者背景图片的形式运用到页面中.Web页面上实现的效果,仅从页面的视觉效果 ...
- Canvas使用渐变之-线性渐变详解
在canvas里面,除了使用纯色,我们还能把填充和笔触样式设置为渐变色:线性渐变和径向渐变. 线性渐变 createLinearGradient(x0,y0,x1,y1) 返回 CanvasGrad ...
- CSS3渐变——线性渐变
渐变背景一直以来在Web页面中都是一种常见的视觉元素.但一直以来,Web设计师都是通过图形软件设计这些渐变效果,然后以图片形式或者背景图片的形式运用到页面中.Web页面上实现的效果,仅从页面的视觉效果 ...
- HTML5 Canvas ( 线性渐变, 升级版的星空 ) fillStyle, createLinearGradient, addColorStop
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...
- Canvas 绘制矩形,圆形,不规则图形(线条),渐变等图像效果
绘制矩形: getContext("2d") 对象是内建的 HTML5 对象,拥有多种绘制路径.矩形.圆形.字符以及添加图像的方法. fillStyle 方法将其染成红色,fill ...
- 使用canvas来完成线性渐变和径向渐变的功能
fillStyle的第二种使用情况就是渐变色的填充.渐变色就分为线性渐变色和径向渐变色. 线性渐变:大致分为两步 这里又会使用到canvas的两个新的函数. 第一步 : 使用一个新的函数cre ...
随机推荐
- 如何解决Windows 10系统下设备的声音问题
如何解决Windows 10系统下设备的声音问题? 请阅读下面的说明来解决Windows 10设备上的声音问题. 1. 检查设备管理器 打开开始菜单,键入设备管理器, 从出现的结果中选择并打开它. 在 ...
- android之短信拦截器
下面通过短信拦截器来介绍短信中的广播 布局文件 在布局文件中可以设置需要拦截的号码 <?xml version="1.0" encoding="utf-8" ...
- MVC 中的 ispostback
总之呢就是在MVC中试下 ispostback那种效果, 环境就是:登录验证loinger, if (Request.HttpMethod == "POST"){} 没理解透彻 源 ...
- vs2012 发布网站,
如图这样选择就没有可以得到一个不包括 *.aspx.cs 的网站了.
- Linux服务器配置git服务
前言 Git是一个非常著名的分布式版本控制系统,而广大开发者更是习惯在最大的远程仓库GitHub上提交自己的代码.但是有时候,一些小项目不值得放到GitHub上去,或是由于隐私问题不好在GitHub的 ...
- [转]hibernate在eclipse的逆向工程生成hbm.xml和bean类
原文地址:http://www.xuebuyuan.com/210489.html 以前一直用myelipse,在myeclipse做hibernate逆向工程倒是很顺手了. 可是最近改用eclips ...
- [转] EJB到底是什么,真的那么神秘吗??
原文地址:http://blog.csdn.net/jojo52013145/article/details/5783677 1. 我们不禁要问,什么是"服务集群"?什么是&quo ...
- Swift开发小技巧--自定义转场动画
自定义转场动画 个人理解为重写了被弹出控制器的modal样式,根据自己的样式来显示modal出来的控制器 例:presentViewController(aVC, animated: true, co ...
- Mysql-windows下修改密码
忘记密码修改(以下各种方法视情况而使用,本人测试,有些都是案情况才可行,但都是有设置成功过) 注:修改密码成功后一定要记得刷新下权限(否则将导致不能使用当前用户连接) mysql>FLUSH P ...
- C#-WinForm-Timer控件
比如在窗体中显示时间: 错误思路一:我在窗体结构函数中写入一个死循环,每隔一秒显示一次当前时间 public Form6() { InitializeComponent(); while (true) ...