HTML5 Canvas 自定义笔刷

1. [图片] QQ截图20120715095110.png


?
?2. [代码][HTML]代码

<!DOCTYPE html>
<html lang="en" >
    <head>
        <meta charset="utf-8" />
        <title>HTML5 canvas - 自定义笔刷</title>
      <style>
      .container {
          color: #000;
          margin: 20px auto;
          overflow: hidden;
          position: relative;
          width: 800px;
      }
       
      /* custom styles */
      .column1 {
          float:left;
          width:500px;
      }
      .column2 {
          float:left;
          padding-left:20px;
          width:170px;
      }
      #panel {
          border:1px #000 solid;
          box-shadow:4px 6px 6px #444444;
          cursor:crosshair;
          display:block;
          margin:0 auto;
          height:600px;
          width:1000px;
      }
      #color {
          border:1px #000 solid;
          box-shadow:0px 4px 6px #444444;
          cursor:crosshair;
      }
      .column2 > div {
          margin-bottom:10px;
      }
      #preview, #pick {
          background-color:rgb(0, 195, 135);
          border:1px #000 solid;
          box-shadow:2px 3px 3px #444444;
          height:40px;
          width:80px;
       
          border-radius:3px;
          -moz-border-radius:3px;
          -webkit-border-radius:3px;
      }
 
      </style>
        <script src="http://code.jquery.com/jquery-latest.min.js"></script>
  </head>
    <body>
 
        <div class="container">
            <div class="column1">
                <canvas id="color" width="500" height="128"></canvas>
            </div>
            <div class="column2">
                <div>颜色预览:</div>
                <div id="preview"></div>
                <div id="pick"></div>
            </div>
            <div ></div>
        </div>
        <canvas id="panel" width="1000" height="600"></canvas>
    </body>
</html>
3. [代码][JavaScript]代码

var canvas;
var canvasColor;
var ctx;
var ctxColor;
var bMouseDown = false;
var selColorR = 0;
var selColorG = 195;
var selColorB = 135;
 
var BubbleBrush = {
    // inner variables
    iPrevX : 0,
    iPrevY : 0,
 
    // initialization function
    init: function () {
        ctx.globalCompositeOperation = ‘source-over‘; //‘lighter‘ is nice too
        ctx.lineWidth = 1;
        ctx.strokeStyle = ‘rgba(0, 0, 0, 0.2)‘;
        ctx.lineWidth = 2;
    },
 
    startCurve: function (x, y) {
        this.iPrevX = x;
        this.iPrevY = y;
        ctx.fillStyle = ‘rgba(‘ + selColorR + ‘, ‘ + selColorG + ‘, ‘ + selColorB + ‘, 0.9)‘;
    },http://www.huiyi8.com/qzone/?
 
    draw: function (x, y) {qq背景
        var iXAbs = Math.abs(x - this.iPrevX);
        var iYAbs = Math.abs(y - this.iPrevY);
        iXAbs = (iXAbs > 30) ? 30 : iXAbs;
        iYAbs = (iYAbs > 30) ? 30 : iYAbs;
 
        if (iXAbs > 10 || iYAbs > 10) {
            ctx.beginPath();
            ctx.arc(this.iPrevX, this.iPrevY, (iXAbs + iYAbs) * 0.5, 0, Math.PI*2, false);
            ctx.fill();
            ctx.stroke();
            this.iPrevX = x;
            this.iPrevY = y;
        }
    }
};
 
$(function(){
    // creating canvas objects
    canvas = document.getElementById(‘panel‘);
    ctx = canvas.getContext(‘2d‘);
 
    canvasColor = document.getElementById(‘color‘);
    ctxColor = canvasColor.getContext(‘2d‘);
 
    drawGradients(ctxColor);
 
    BubbleBrush.init();
 
    $(‘#color‘).mousemove(function(e) { // mouse move handler
        var canvasOffset = $(canvasColor).offset();
        var canvasX = Math.floor(e.pageX - canvasOffset.left);
        var canvasY = Math.floor(e.pageY - canvasOffset.top);
 
        var imageData = ctxColor.getImageData(canvasX, canvasY, 1, 1);
        var pixel = imageData.data;
 
        var pixelColor = ‘rgba(‘+pixel[0]+‘, ‘+pixel[1]+‘, ‘+pixel[2]+‘, ‘+pixel[3]+‘)‘;
        $(‘#preview‘).css(‘backgroundColor‘, pixelColor);
    });
 
    $(‘#color‘).click(function(e) { // mouse click handler
        var canvasOffset = $(canvasColor).offset();
        var canvasX = Math.floor(e.pageX - canvasOffset.left);
        var canvasY = Math.floor(e.pageY - canvasOffset.top);
 
        var imageData = ctxColor.getImageData(canvasX, canvasY, 1, 1);
        var pixel = imageData.data;
 
        var pixelColor = ‘rgba(‘+pixel[0]+‘, ‘+pixel[1]+‘, ‘+pixel[2]+‘, ‘+pixel[3]+‘)‘;
        $(‘#pick‘).css(‘backgroundColor‘, pixelColor);
 
        selColorR = pixel[0];
        selColorG = pixel[1];
        selColorB = pixel[2];
    }); 
 
    $(‘#panel‘).mousedown(function(e) { // mouse down handler
        bMouseDown = true;
        var canvasOffset = $(canvas).offset();
        var canvasX = Math.floor(e.pageX - canvasOffset.left);
        var canvasY = Math.floor(e.pageY - canvasOffset.top);
 
        BubbleBrush.startCurve(canvasX, canvasY, false, false, false, false, false, false, canvasX, canvasY, 0, 0);
    });
    $(‘#panel‘).mouseup(function(e) { // mouse up handler
        bMouseDown = false;
    });
    $(‘#panel‘).mousemove(function(e) { // mouse move handler
        if (bMouseDown) {
            var canvasOffset = $(canvas).offset();
            var canvasX = Math.floor(e.pageX - canvasOffset.left);
            var canvasY = Math.floor(e.pageY - canvasOffset.top);
 
            BubbleBrush.draw(canvasX, canvasY, false, false, false, false, false, false, canvasX, canvasY, 0, 0);
        }
    });
});
 
function drawGradients() {
    var grad = ctxColor.createLinearGradient(20, 0, canvasColor.width - 20, 0);
    grad.addColorStop(0, ‘red‘);
    grad.addColorStop(1 / 6, ‘orange‘);
    grad.addColorStop(2 / 6, ‘yellow‘);
    grad.addColorStop(3 / 6, ‘green‘);
    grad.addColorStop(4 / 6, ‘aqua‘);
    grad.addColorStop(5 / 6, ‘blue‘);
    grad.addColorStop(1, ‘purple‘);
    ctxColor.fillStyle=grad;
    ctxColor.fillRect(0, 0, canvasColor.width, canvasColor.height);
}

时间: 2024-07-30 05:58:19

HTML5 Canvas 自定义笔刷的相关文章

ZBrush&#174;自定义笔刷教程

在使用ZBrush雕刻的过程中,总是需要我们花费很多时间去找各种笔刷,而笔刷又非常的多,一方面比较的麻烦,另一方面特别费时.ZBrush®十分人性化的给用户提供了自定义笔刷界面的功能,省时又省力.而ZBrush®自定义笔刷界面的过程非常简单,下面小编给大家讲讲如何自定义笔刷界面. 1.点击ZBrush®菜单栏中的Preferences,单击Config,激活Enable Customize按钮. 2.点击ZBrush®菜单栏中的Brush界面,按住左上角的箭头小图标,把笔刷界面拖动到右边的面板上

Image1.Canvas画图笔刷

如何背景透明 unit Unit1; interface uses  Winapi.Windows, Winapi.Messages, System.SysUtils, System.Variants, System.Classes, Vcl.Graphics,  Vcl.Controls, Vcl.Forms, Vcl.Dialogs, Vcl.ExtCtrls; type  TForm1 = class(TForm)    Image1: TImage;    procedure Image

ZBrush 4R7中自定义笔刷

为了便于雕刻,ZBrush?很人性化地设计了自定义笔刷.随着ZBrush软件版本不断更新,功能也在不断完善.只是在笔刷面板ZBrush软件就为用户提供了上百种之多,如果我们想要用某种笔刷,一个个找起来是不是很麻烦,所以ZBrush完美地给用户解决了这一问题,使用自定义笔刷的功能,帮助用户省下很多找笔刷的时间.自定义笔刷的方法很简单,步骤如下. ZBrush 4R8中文版软件下载:http://wm.makeding.com/iclk/?zoneid=18156 01 单击Preferences[

ZBrush 4R7中为笔刷设置快捷键

为了便于雕刻.提高雕刻速度,ZBrush?不仅很人性化地设计了自定义笔刷,用户还可以自行设置笔刷快捷键,步骤如下. ZBrush 4R8下载:http://wm.makeding.com/iclk/?zoneid=18156 ZBrush中文视频教程:http://www.zbrushcn.com/shipin/ 01 同时按Alt+Ctrl键,不松手,单击需自定义笔刷的图标.这时笔刷已进入自定义快捷键模式,按照自己的习惯设置快捷键,如图所示. [小提示]:快捷键只限于字母键盘上方的1-0键.

HTML5 Canvas绘文本动画(使用CSS自定义字体)

一.HTML代码: <!DOCTYPE html> <html> <head> <title>Matrix Text - HTML5 Canvas Demo</title> <script type="text/javascript" src="matrixtext.js"></script> <style> @font-face { font-family: 'Matr

8个经典炫酷的HTML5 Canvas动画欣赏

HTML5非常强大,尤其是Canvas技术的应用,让HTML5几乎可以完成所有Flash能完成的效果.本文精选了8个经典炫酷的HTML5 Canvas动画欣赏,每一个都提供全部的源代码,希望对你有所帮助. 1.HTML5 Canvas可拖动的弹性大树摇摆动画 今天让我们继续来分享一个炫酷的HTML5动画,它是一款基于HTML5 Canvas的大树摇摆动画,这款HTML5动画的特点是我们可以拖拽树枝,从而让整棵树摇摆起来,这样就真实地模拟了大树从摇摆到静止的整个过程,相当逼真. 在线演示     

Html5 canvas 钟表

原文:Html5 canvas 钟表 看到有不少人用canvas写钟表,今天也来加入他们,自己实现个. 效果图: 实现代码如下: <html> <head> <title>Html5 canvas 钟表</title> <style type="text/css"> canvas{ border:2px solid Gray; background-color:Gray;} </style> </head&g

一款基于HTML5 Canvas的画板涂鸦动画

今天给各网友分享一款基于HTML5 Canvas的画板涂鸦动画.记得之前我们分享过一款HTML5 Canvas画板工具,可以切换不同的笔刷,功能十分强大.本文今天要再来分享一款基于HTML5 Canvas的画板涂鸦动画应用,功能和之前那个类似,但是新增了回撤和清空画板的操作,实现思路也基本类似.实现的效果图如下: 在线预览   源码下载 实现的代码. html代码: <div class="wrap"> <canvas id="canvas" cl

使用html5+canvas+Jquery实现的纯代码连线题Demo

前端一直是令众等小牛们胆怯的领域,但一旦涉足,技术自然也是蹭蹭蹭的往上涨,荷包也就自然的bingo了. 然而在这万千世界加之资料满街撒的时代,却仍然在我们开发过程中总有那么一丢丢的技术点难以找到合适自身的demo,故而引发了众生牛牛们的不满和抱怨,于是乎苦逼的从后端到前端的探险历程,走上了一条漫漫人生路. 随着我们业务应用场景的广泛化,衍生了众多华丽的前端艺术及产品,接下来则分享一份使用html5+canvas实现的草稿版连线题demo,希望有助于奋斗在一线前端的开发人员们,也多多提供一些改良意