24

ユーザーのクリップボードから画像を取得するための貼り付けハンドラーを実装しようとしています。これをGoogleChromeでのみ実行したいのですが、他のブラウザでは心配していません。

これは私がインターネットで見つけた方法の一部であり、私はそれを適応させようとしています。

// Get the items from the clipboard
var items = e.clipboardData.items;
    if (items) {
    // Loop through all items, looking for any kind of image
        for (var i = 0; i < items.length; i++) {
            if (items[i].type.indexOf("image") !== -1) {
                // We need to represent the image as a file,
                var blob = items[i].getAsFile();
                // and use a URL or webkitURL (whichever is available to the browser)
                // to create a temporary URL to the object
                var URLObj = window.URL || window.webkitURL;
                var source = URLObj.createObjectURL(blob);
                createImage(source);
                }
            }
        }

このメソッドは機能し、「ソース」を画像オブジェクトのsrcとして使用すると、画像を表示できます。問題は、グーグルクロームの画像ソースが次のようになることです:blob:http://localhost:8080/d1328e65-ade2-45b3-a814-107cc2842ef9

このイメージをサーバーに送信する必要があるため、base64バージョンに変換したいと思います。例えば:

...iCIBWnh+P9w9C+9eMzvhCl1iOElK09ruc2wqGhfH/uKEV30FlJkmRZJklydFuW/FdwhYFCkCBBggQJEuS/gWC4FCRIkCBBggQZlmCgECRIkCBBggQZlmCgECRIkCBBggQZFmzhwoXXWoYgQYIECRIkyHUK5vF4rrUMQYIECRIkSJDrFHLktYOCBAkSJEiQIP/NkLt3777WMgT5thLstwoSJEiQ7zxYsEUhyJWxbdu2u++++1pLESRIkCBBvl6Csx6CBAkSJEiQIMPy3dkMOsg3T7A5KkiQIEG+8wQDhSBXTjBQCBIkSJDvPMGuhyBBggQJEiTIsFwXLQr9H6bOjtYeP2mONbOj2Hut9y6/x+nlJSBCQnXkgG3Brh8Q4lqbOpAmPDqUGShex9lPDlfB4sU5I97b/8kuevygYUgYsAksAPg9fkbDQN/e1kNvVw76nfYeiTCG6sjLd5fv58rsFmxRCBIkSJDvPP8f+HtxbDVRPI8AAAAASUVORK5CYII=

コードの最初の部分には、ファイルを表すblobオブジェクトがあります。いくつかの方法を試しましたが、正しい表現が得られません。これを使用してbase64表現を作成するにはどうすればよいですか?

4

1 に答える 1

34

このページでのNickRetallackの回答クリップボードからの画像の貼り付け機能は、GmailおよびGoogle Chrome 12以降でどのように機能しますか?私がやりたいことを正確に行います。

したがって、新しいコードは次のとおりです。

var items = e.clipboardData.items;
if (items) {
// Loop through all items, looking for any kind of image
    for (var i = 0; i < items.length; i++) {
        if (items[i].type.indexOf("image") !== -1) {
            // We need to represent the image as a file,
            var blob = items[i].getAsFile();

            var reader = new FileReader();
                reader.onload = function(event){
                    createImage(event.target.result); //event.target.results contains the base64 code to create the image.
                };
                reader.readAsDataURL(blob);//Convert the blob from clipboard to base64
            }
        }
    }
于 2012-08-08T17:47:02.560 に答える