从剪贴板粘贴图像

时间:2013-07-10 09:34:31

标签: java html html5 applet clipboard

我正在尝试从我的网站中的剪贴板粘贴图像(如复制和粘贴)。感谢是否有人可以就此提出建议。我可以使用HTML 5或applet或任何方式实现此目的。任何建议或任何参考链接都非常感谢。

3 个答案:

答案 0 :(得分:2)

使用JavaScript进行管理。

<强>的JavaScript

if (!window.Clipboard) {
   var pasteCatcher = document.createElement("apDiv1");
   pasteCatcher.setAttribute("contenteditable", "");
   pasteCatcher.style.opacity = 0;
   document.body.appendChild(pasteCatcher);
   pasteCatcher.focus();
   document.addEventListener("click", function() { pasteCatcher.focus(); });
} 

window.addEventListener("paste", onPasteHandler);

function onPasteHandler(e)
{
    if(e.clipboardData) {
        var items = e.clipboardData.items;
        if(!items){
            alert("Image Not found");
        }
        for (var i = 0; i < items.length; ++i) {
        if (items[i].kind === 'file' && items[i].type === 'image/png') {
            var blob = items[i].getAsFile(),
                source = window.webkitURL.createObjectURL(blob);

            pastedImage = new Image();
            pastedImage.src = source;

            pasteData();
            }
        }
    }
}

function pasteData()
{
    drawCanvas = document.getElementById('drawCanvas1');
    ctx = drawCanvas.getContext( '2d' );
    ctx.clearRect(0, 0, 640,480);
    ctx.drawImage(pastedImage, 0, 0);
}

DIV

<div id="apDiv1" contenteditable='true'>Paste Test</div>

答案 1 :(得分:0)

即使applet未签名,也可以使用JNLP API。

ClipboardService cs = (ClipboardService)ServiceManager.lookup("javax.jnlp.ClipboardService");
Image c = (Image)cs.getContents().getTransferData(DataFlavor.imageFlavor);

答案 2 :(得分:0)

首先制作文件(图像)服务器。

然后使用js来监听粘贴事件。 代码关键字:

addEventListener 'paste' clipboard image

然后使用ajax上传到文件服务器。 ajax resp the url。

最后通过网址制作img标签。

小程序已过期......忽略。