2012-06-26 23 views
20

के रूप में कैनवास सहेजना मैं बेस 64-एन्कोडेड छवि के रूप में इसे एक नई विंडो में खोलने के बिना, कैनवास को पीएनजी के रूप में सहेजना चाहता हूं।एक पीएनजी या जेपीजी

jQuery("#btnPreview").click(function(){ 
     if (!fabric.Canvas.supports('toDataURL')) { 
      alert('Sorry, your browser is not supported.'); 
     } 
     else { 
      canvas.deactivateAll(); 
      canvas.forEachObject(function(o){ 
       if(o.get("title") == "||Watermark||"){ 
        canvas.bringToFront(o); 
       } 
      }); 
      window.open(canvas.toDataURL('png'), ""); 
      canvas.forEachObject(function(o){ 
       if(o.get("title") == "||Watermark||"){ 
        canvas.sendToBack(o); 
       } 
      }); 
      canvas.renderAll(); 
     } 

    }); 

मैं बटन एक PNG या JPG के रूप में छवि को बचाने बनाना चाहते:

मैं इस कोड का इस्तेमाल किया।

+0

संभव दो प्रतियों में: gif के रूप में [कब्जा एचटीएमएल कैनवास/jpg/png/pdf?] (http://stackoverflow.com/questions/923885/capture-html-canvas-as-gif-jpg-png-pdf) – Alexander

+0

मुझे नहीं लगता कि यह इस ques का डुप्लिकेट है tion। –

+0

मुझे नहीं लगता कि मैं क्या खोज रहा हूं :( – UXX1

उत्तर

4

canvas.toDataURL('png') एक स्ट्रिंग ला ला  प्रदान करता है। आप इसे <a href="%dataURI%" download>download</a> में रख सकते हैं (संभवतः तत्व पर एक क्लिक ईवेंट ट्रिगर करें)। Downloading resources in HTML5: a[download]

वर्तमान में केवल Google क्रोम द्वारा समर्थित है।

+0

नहीं, मैं चाहता हूं कि बटन इसे डाउनलोड करें – UXX1

13

मैं अपने jQuery पर इस का उपयोग करें:

var image = canvas.toDataURL("image/png").replace("image/png", "image/octet-stream"); 

$('.save').attr({ 
    'download': 'YourProduct.png', /// set filename 
    'href' : image    /// set data-uri 
}); 
1

script.js में दाखिल

$(document).on('click','#btnPreview',function(){ 
    var img =$scope.canvas.toDataURL('image/png'); 
    $.ajax({ 
       type: "POST", 
       url: 'ajax.php', 
       data: {'img':img}, 
       success: function(data) { 
        $("#loader_message").html("Image saved successfully"); 
       } 
      }); 
    }); 

ajax.php

$encodedData=explode(',', $_POST["img"]); 
    $data = base64_decode($encodedData[1]); 
    $urlUploadImages = $_SERVER['DOCUMENT_ROOT'].$projName.'/images/canvas/'; 
    $nameImage = "test.png"; 
    $img = imagecreatefromstring($data); 
    if($img) { 
     imagepng($img, $urlUploadImages.$nameImage, 0); 
     imagedestroy($img); 
     echo "OK"; 
    } 
    else { 
     echo 'ERROR'; 
    } 
+0

यह क्लाइंट-साइड को सहेज रहा है, टी नहीं वह सर्वर ... – Kaiido

+0

'कैनवास' नामक सर्वर फ़ोल्डर पर इसकी बचत – saad

+0

मेरा मतलब है कि सवाल "स्थानीय रूप से कैसे सहेजना है"। मुझे पता है कि आपका कोड क्या करना है, यही कारण है कि मैं यह इंगित कर रहा हूं कि यह वास्तव में प्रश्न का उत्तर नहीं देता है। – Kaiido

संबंधित मुद्दे