html5 canvas 的涂鸦画板,可以加载图片进行涂鸦,也可以下载
服务器使用的php
上传的图片不能超过1M,只能是jpg或者png 格式的
演示地址的服务器网速不怎么样,读取文件可能很慢,到达100%的时候点击读取文件,如果没显示就多点几次
​1. [代码]主页面

<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>涂鸦画板</title>
<script type="text/javascript" src="jquery-1.8.3.js"></script>
<script type="text/javascript" src="jquery.form.js"></script>
<link href="index.css" rel="stylesheet" type="text/css">
 
</head>
<body>
    <div id="chooseColor"></div>
    <div id="chooseSize"></div>
    <div id="paint">
        <canvas id="pad" width="800" height="600" />
    </div>
    <input type="button" id="download" value="下载" />
    <!-- 上传图片  -->
    <input type="file" name="mypic" id="chooseFile" />
    <input type="button" value="读取文件" id="load" />
    <!-- 进度条 -->
    <div class="progress">
        <span class="bar"></span><span class="percent">0%</span >
    </div>
    <!-- 隐藏区域 -->
    <img id="tulip" src="" alt="加载显示区" />
</body>
<script type="text/javascript" src="index.js"></script>
</html>
2. [代码]页面的简单排版     
body,input {
    font-size: 9pt;
}
 
#paint,#chooseSize {
    clear: both;
}
 
.option {
    float: left;
    width: 20px;
    height: 20px;
    border: 2px solid #cccccc;
    margin-right: 4px;
    margin-bottom: 4px;
}
 
.active {
    border: 2px solid black;
}
 
.lw {
    text-align: center;
    vertical-align: middle;
}
 
img.output {
    border: 1px solid green;
}
 
#pad {
    border: 2px solid gray;
    cursor: arrow;
}
 
#chooseFile {
    float: left;
    width: 140px;
}
 
#tulip {
    display: none;
}
 
#download {
    margin-left: 550px;
}
 
#load {
    float: left;
    width: 80px;
}
3. [代码]画图,上传,下载处理

$(document).ready(function() {
    paint();
    downloadPic();
    loadImg();
    uploadImg();
});
 
/**
 * 绘画
 */
function paint() {
    chooseColor();
    chooseSize();
    canvas();
}
 
/**
 * 颜色选择器
 */
function chooseColor() {
    var colors = "red;orange;yellow;green;blue;indigo;purple;black;white".split(';');
    var sb = [];
    $.each(colors,function(i,v){
        sb.push("<div class='option' style='background-color:" + v + "'></div>");
    });
    $("#chooseColor").html(sb.join("\n"));
}
 
/**
 * 大小选择器
 */
function chooseSize(){
    sb = [];
    for (var i = 1; i <= 9; i++) sb.push("<div class='option lw'>" + "<div style='margin-top:#px;margin-left:#px;width:%px;height:%px'></div></div>".replace(/%/g, i).replace(/#/g, 10 - i / 2));
    $("#chooseSize").html(sb.join('\n'));
}
 
/**
 * 画图
 */
function canvas(){
    var $clrs = $("#chooseColor .option");
    var $lws = $("#chooseSize .option");
    $clrs.click(function(){
        $clrs.removeClass("active");
        $(this).addClass("active");
        p_color = this.style.backgroundColor;
        $lws.children("div").css("background-color",p_color);
    }).first().click();
     
    //点选线条粗细选项时切换焦点并取得宽度存入p_width
    $lws.click(function(){
        $lws.removeClass("active");
        $(this).addClass("active");
        p_width = $(this).children("div").css("width").replace("px","");
         
    }).eq(3).click();
     
    // 取得canvas context
    var $canvas = $("#pad");
    var ctx = $canvas[0].getContext("2d");
    ctx.lineCap = "round";
    ctx.fillStyle = "white"; //整个canvas涂上白色的背景,避免PNG的透明底色效果
    ctx.fillRect(0,0,$canvas.width(),$canvas.height());
    var drawMode = false;
     
    // canvas点选,移动,放开按键时进行绘图动作
    $canvas.mousedown(function(e){
        ctx.beginPath();
        ctx.strokeStyle = p_color;
        ctx.lineWidth = p_width;
        ctx.moveTo(e.pageX - $canvas.position().left, e.pageY - $canvas.position().top);
        drawMode = true;
    }).mousemove(function(e){
        if(drawMode){
            ctx.lineTo(e.pageX - $canvas.position().left, e.pageY - $canvas.position().top);
            ctx.stroke();
        }
    }).mouseup(function(e){
        drawMode = false;
    });
}
 
/**
 * 下载当前所绘制的图像
 */
function downloadPic(){
    // 使用toDataURL()将图转换成png文件
    var saveFile = function(data, filename) {
        var save_link = document.createElementNS('http://www.w3.org/1999/xhtml', 'a');
        save_link.href = data;
        save_link.download = filename;
        var event = document.createEvent('MouseEvents');
        event.initMouseEvent('click', true, false, window, 0, 0, 0, 0, 0, false, false, false, false, 0, null);
        save_link.dispatchEvent(event);婚纱摄影
    };http://www.huiyi8.com/hunsha/​
    $("#download").click(function() {
        var myCanvas = document.getElementById("pad");
        var image = myCanvas.toDataURL("image/png").replace("image/png", "image/octet-stream");
        // window.location.href=image;
        var filename = 'paint_' + (new Date()).getTime() + '.png';
        saveFile(image, filename);
    });
}
 
 
//获取当前文件名
function ch_(url){  
    url=url.split("\\");//这里要将 \ 转义一下
    var filename = url[url.length-1];
    return filename;
}
 
 
//加载隐藏模块中的图片
function loadImg(){
    $('#load').click(function(){
        // 加载到canvas
        var c= document.getElementById("pad");
        var ctx = c.getContext("2d");
        var img=document.getElementById("tulip");
        ctx.drawImage(img,0,0);
    });
}
 
/**
 * 上传图片
 */
function uploadImg(){
    var bar = $('.bar');
    var percent = $('.percent');
    var showimg = $('#showimg');
    var progress = $(".progress");
    $("#chooseFile").wrap("<form id='myupload' action='upload.php' method='post' enctype='multipart/form-data'></form>");
    $("#chooseFile").change(function(){
        $("#myupload").ajaxSubmit({
            dataType: 'json',
            uploadProgress: function(event, position, total, percentComplete) {
                var percentVal = percentComplete + '%';
                bar.width(percentVal);
                percent.html(percentVal);
            },
            success: function(data){
                // alert('上传成功');
                var file = $('#chooseFile').val();
                var filename = ch_(file);
                var src = 'paint/' + filename;
                $('#tulip').attr('src',src);
            },
            error: function(xhr){
                alert('上传失败');
            }
        });
    });
}
4. [代码]服务器上传处理   
<?php
$picname = $_FILES ['mypic'] ['name'];
$picsize = $_FILES ['mypic'] ['size'];
if ($picname != '') {
    if ($picsize > 1024000) {
        echo '图片的大小不能超过1M';
        exit ();
    }
    $type = strstr ( $picname, '.' );
    if ($type != '.jpg' && $type != '.png') {
        echo '图片格式不对';
        exit ();
    }
    $pics = $picname;
    // 上传路径
    $pic_path = 'paint/' . $pics;
    move_uploaded_file ( $_FILES ['mypic'] ['tmp_name'], $pic_path );
}
$size = round ( $picsize / 1024, 2 );
$arr = array (
        'name' => $picname,
        'pic' => $pics,
        'size' => $size
);
echo json_encode ( $arr );
?>

html5 canvas 涂鸦画板的更多相关文章

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

    今天给各网友分享一款基于HTML5 Canvas的画板涂鸦动画.记得之前我们分享过一款HTML5 Canvas画板工具,可以切换不同的笔刷,功能十分强大.本文今天要再来分享一款基于HTML5 Canv ...

  2. HTML5 canvas自制画板

    找到一个画板的插件,很好用,点击下载  ,页面很简单,但是呢,貌似不适用于手机端,,,

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

    HTML5非常强大,尤其是Canvas技术的应用,让HTML5几乎可以完成所有Flash能完成的效果.本文精选了8个经典炫酷的HTML5 Canvas动画欣赏,每一个都提供全部的源代码,希望对你有所帮 ...

  4. 基于HTML5 Canvas的网页画板实现教程

    HTML5的功能非常强大,尤其是Canvas的应用更加广泛,Canvas画布上面不仅可以绘制任意的图形,而且可以实现多种多样的动画,甚至是一些交互式的应用,比如网页网版.这次我们要来看的就是一款基于H ...

  5. html5 canvas 画板

    <!doctype html> <head> <meta http-equiv="Content-Type" content="text/h ...

  6. Atitit html5 Canvas 如何自适应屏幕大小

    Atitit  html5 Canvas 如何自适应屏幕大小     可以用JS监控屏幕大小,然后调整Canvas的大小.在代码中加入JS 1 2 3 4 5 6 7 $(window).resize ...

  7. HTML5 canvas 在线画笔绘图工具(三)

    组装画板(TDrawBuilder) 在这一小节中我们要把工具条和画板组装起来,让他们可以协同进行工作. 画板通过一个命名为TDrawBuilder来进行组装.在详细讲解TDrawBuilder对象之 ...

  8. HTML5实现涂鸦板

    原文:HTML5实现涂鸦板 最近闲的,看了看html5,强大的绘图功能让我惊奇,于是,写了个小玩意---涂鸦板,能实现功能有:画画,改色,调整画笔大小 html5的绘图可以分为点,线,面,圆,图片等, ...

  9. HTML5 canvas画图

    HTML5 canvas画图 HTML5 <canvas> 标签用于绘制图像(通过脚本,通常是 JavaScript).不过,<canvas> 元素本身并没有绘制能力(它仅仅是 ...

随机推荐

  1. Ubuntu 16.04安装MongoDB的GUI工具RoboMongo

    一.下载: https://robomongo.org/download 离线版本:(链接: https://pan.baidu.com/s/1mirFi56 密码: y3t2) 二.安装: -lin ...

  2. 分布式文件系统 FastDFS 5.0.8 & Linux CentOS 6.7 安装配置

    原文:http://blog.csdn.net/wlwlwlwl015/article/details/52619851 前言 项目中用到文件服务器,有朋友推荐用fastdfs,所以就了解学习了一番, ...

  3. Android(java方法)上实现mp4的分割和拼接 (一)

       最近正在处理android上的mp4切割问题.学习了很多mp4的知识,mp4文件按照编码类型,分为mpeg-4,avc这两种:这两种类型的mp4在后面的处理中会有不同的地方. 在Android系 ...

  4. 权重轮询调度算法(WeightedRound-RobinScheduling)-Java实现

    权重轮询调度算法(WeightedRound-RobinScheduling)-Java实现 import java.math.BigInteger; import java.util.ArrayLi ...

  5. mysql_config_editor使用简介

      原文 : http://blog.itpub.net/29773961/viewspace-1817640/   ----------------------------------------- ...

  6. Nginx 第三方模块的安装以及一致性哈希算法的使用

    Nginx 第三方模块的安装以及一致性哈希算法的使用 第三方模块安装方法总结: 以ngx_http_php_memcache_standard_balancer-master为例 1:解压 到 pat ...

  7. android中的MD5、Base64、DES/3DES/ADES加解密

    MD5摘要算法: <span style="font-size:18px;">主要代码: String s = edit.getText().toString(); i ...

  8. div和img之间的缝隙问题

    这次做的项目,客户说.banner图的上下之间不要留有空隙,细致一看才发现,上下居然都有空隙.审查元素,发现全部的div,img的padding和margin都是0,对于这个间隙到底是假设产生的真的是 ...

  9. Introducing Gradle (Ep 2, Android Studio)

    https://www.youtube.com/watch?v=cD7NPxuuXYY    Introducing Gradle (Ep 2, Android Studio) https://www ...

  10. pandas-数据分析

    pandas是一个强大的python数据分析的工具包 pandas是基于numpy构建的 pandas的主要功能: 具备对其功能的数据结构DataFrame.Series 集成世间序列功能 提供丰富的 ...