zoukankan      html  css  js  c++  java
  • wPaint在线绘图插件

    wPaint在线绘图插件

    一、总结

    一句话总结:

    1、搜画图插件的时候关键词应该搜什么?

    jquery画图插件

    js画图插件

    jquery绘图插件

    这些

    二、在线绘图插件--wPaint 的实际应用

    wPaint 网址: http://wpaint.websanova.com/#websanova

    在实际应用中, 这是一个不错的在线实时绘图jQuery插件.

    最重要的一个功能是 支持将绘的图进行保存.

    一个实现的demo(JAVA).

    1. 在HTML页面上定义一个wPaint的容器.

    <div id="wPaint"></div>

    最好对容器设置样式.

            #wPaint {
                position: relative;
                 680px;
                height: 600px;
                background: #CACACA;
                border: solid black 1px;
                margin-bottom: 10px;
                margin-top: 10px;
                margin-left: 5px;
                float: left;
            }

    引入JS,CSS.

        <!-- wColorPicker -->
        <link rel="Stylesheet" type="text/css" href="/js/jquery/wPaint/inc/wColorPicker.css"/>
        <script type="text/javascript" src="/js/jquery/wPaint/inc/wColorPicker.js"></script>
    
        <!-- wPaint -->
        <link rel="Stylesheet" type="text/css" href="/js/jquery/wPaint/wPaint.css"/>
        <script type="text/javascript" src="/js/jquery/wPaint/wPaint.js"></script>



    2. 初始化wPaint.JS代码

                $('#wPaint').wPaint({
                    fillStyle: "#ffffff",
                    image:"${dataDto.base64Image}",
                    strokeStyle: "#333333"
                });

    黑色部分

    ${dataDto.base64Image}

    是绘图容器的背景图片数据(png格式), base64格式的图片数据.

    ...

    如果不需要背景,则不需要设置.

    在JAVA中,我们可以使用 BASE64Encoder类来转化.

        public static String imageToBase64(byte[] imageBytes) {
            BASE64Encoder encoder = new BASE64Encoder();
            return encoder.encode(imageBytes);
        }


    3. 在绘制图片完成后, 需要保存绘制的图片.

    3.1 获取wPaint的image属性值可获取base64格式的图片数据

    var imageData = $("#wPaint").wPaint("image");


    3.2 在JAVA后台可使用BASE64Decoder 类将base64数据转化为byte数组.

        public static byte[] base64ToBytes(String bast64Str) {
            BASE64Decoder decoder = new BASE64Decoder();
            try {
                byte[] bytes = decoder.decodeBuffer(bast64Str);
                //调整异常数据
                for (int i = 0; i < bytes.length; ++i) {
                    if (bytes[i] < 0) {
                        bytes[i] += 256;
                    }
                }
                return bytes;
            } catch (IOException e) {
                throw new IllegalStateException("Convert base64 data error", e);
            }
        }


    OK. 至此结束.




     
  • 相关阅读:
    蛇形填数
    A Famous Music Composer
    Java用筛子法求素数
    素数求和问题
    Java中数组的快排
    大数阶乘
    Binary String Matching
    括号配对问题
    Android Studio安装和使用
    Android Studio使用手册
  • 原文地址:https://www.cnblogs.com/Renyi-Fan/p/9244086.html
Copyright © 2011-2022 走看看