Şimdi Ara

html son

Daha Fazla
Bu Konudaki Kullanıcılar: Daha Az
2 Misafir - 2 Masaüstü
5 sn
18
Cevap
0
Favori
626
Tıklama
Daha Fazla
İstatistik
  • Konu İstatistikleri Yükleniyor
0 oy
Öne Çıkar
Sayfa: 1
Giriş
Mesaj
  • mesela bir input olsun fdsfds yazılı(en fazla 5 karakter yazılsın)

    oluştur tuşuna tıklandığında


    x resmi içinde fdsfds yazılı bir resim indirsin boyut 512x512


    harbi çok şey istedim bea yeter artık hadi ben kaçarım.



  • İstediğin olayı direkt tarayıcı üzerinden halletmek istiyorsan canvas kullanman lazım, bu özelliği iyi araştır. W3School ve MDN'de epey döküman var bununla ilgili. İndirme işlemi için HTML5'in download özelliği iş görür(IE'de çalışmayabilir) Örnek olması açısından kabataslak bir şeyler hazırladım. Kodu ihtiyacına göre editlemek sana kalmış.


    <!DOCTYPE html>
    <html lang="tr">
    <head>
    <meta charset="UTF-8">
    <title>Document</title>
    <script>
    function drawCanvas() {

    var canvas = document.createElement("canvas");
    canvas.width = 512;
    canvas.height = 512;

    var context = canvas.getContext("2d");
    var val = document.getElementById("txt").value;

    context.font = "bold 32px Arial";
    context.fillStyle = "#000000";
    context.fillText(val, 220, 240);

    var dl = document.getElementById("download");
    dl.href = canvas.toDataURL();
    dl.download = val + ".png";

    if ( !("download" in document.createElement("a")) ) {
    dl.target = "_blank";
    dl.style.display = 'inline';
    } else dl.click();

    return false;
    }
    </script>
    </head>
    <body>
    <form action="" onsubmit="return drawCanvas()">
    <input type="text" id="txt" maxlength="5" placeholder="Buraya yazı gelecek">
    <input type="submit" value="Oluştur">
    </form>
    <a data-test="test" rel="nofollow" style="word-wrap: break-word; text-decoration: underline;" target="_blank" onclick="return dhExternalLinkRedirect(this)" href="/ExternalLinkRedirect?module=pgdcode&messageId=134582445&url=#" id="download" style="display: none; margin-top: 10px;" data-href="#" id="download" style="display: none; margin-top: 10px;">İndir</a>
    </body>
    </html>


    Edit: Donanımhaber koddaki a elementine onclick="return dhExternallinkRedirect(this)" href="/ExternalLinkRedirect?url=#" gibi otomatik bir şeyler ekliyor forumda bug var sanırım. Orayı sil.



    < Bu mesaj bu kişi tarafından değiştirildi Revolution -- 22 Ağustos 2018; 19:36:20 >




  • dl.href = canvas.toDataURL(); kısmına
    data:text/html;base64,PGh0bWw+DQo8aGVhZD48dGl0bGU+MzAxIE1vdmVkIFBlcm1hbmVudGx5PC90aXRsZT48L2hlYWQ+DQo8Ym9keSBiZ2NvbG9yPSJ3aGl0ZSI+DQo8Y2VudGVyPjxoMT4zMDEgTW92ZWQgUGVybWFuZW50bHk8L2gxPjwvY2VudGVyPg0KPGhyPjxjZW50ZXI+bmdpbng8L2NlbnRlcj4NCjwvYm9keT4NCjwvaHRtbD4NCg==
    datasını ekliyorum
    The file you asked for does not exist

    resimi dataya dönüştürdüğümdeyse uzun bir data oluyor
  • OktayYeni kullanıcısına yanıt
    toDataURL() metodu PNG formatında bir dataURl çıktılar. Alternatif olarak toDataURL("image/jpeg") yazarsan da jpeg formatında çıktı verir. Sendeki data text/html resim formatı değil o.
    uzun datalar ile uğraşmak istemiyorsan kısaltmanın yöntemi var:


    <!DOCTYPE html>
    <html lang="tr">
    <head>
    <meta charset="UTF-8">
    <title>Document</title>
    <script>

    function dataURItoBlob(dataURI) {
    // convert base64 to raw binary data held in a string
    var byteString = atob(dataURI.split(',')[1]);

    // separate out the mime component
    var mimeString = dataURI.split(',')[0].split(':')[1].split(';')[0];

    // write the bytes of the string to an ArrayBuffer
    var arrayBuffer = new ArrayBuffer(byteString.length);
    var _ia = new Uint8Array(arrayBuffer);
    for (var i = 0; i < byteString.length; i++) {
    _ia[i] = byteString.charCodeAt(i);
    }

    var dataView = new DataView(arrayBuffer);
    var blob = new Blob([dataView], { type: mimeString });
    return blob;
    }

    function drawCanvas() {

    var canvas = document.createElement("canvas");
    canvas.width = 512;
    canvas.height = 512;

    var context = canvas.getContext("2d");
    var val = document.getElementById("txt").value;

    context.font = "bold 32px Arial";
    context.fillStyle = "#000000";
    context.fillText(val, 220, 240);

    var dl = document.getElementById("download");
    dl.href = URL.createObjectURL(dataURItoBlob(canvas.toDataURL())); // datayı kısa url haline getirdik
    dl.download = val + ".png";

    if ( !("download" in document.createElement("a")) ) {
    dl.target = "_blank";
    dl.style.display = 'inline';
    } else dl.click();

    return false;
    }
    </script>
    </head>
    <body>
    <form action="" onsubmit="return drawCanvas()">
    <input type="text" id="txt" maxlength="5" placeholder="Buraya yazı gelecek">
    <input type="submit" value="Oluştur">
    </form>
    <a href="#" id="download" style="display: none; margin-top: 10px;" >İndir</a>
    </body>
    </html>



    < Bu mesaj bu kişi tarafından değiştirildi Revolution -- 23 Ağustos 2018; 0:16:21 >




  • data yerine link kullanma yolu yok değil mi?
  • quote:

    Orijinalden alıntı: OktayYeni

    data yerine link kullanma yolu yok değil mi?
    datayı kısa linke çeviriyor zaten dataURI ile işin kalmıyor. İndir linkinin adresini chrome devtools'dan inceleyebilirsin. Tarayıcı önbelleğinde local bir adres oluşturuyor verdiğim URL.createObjectURL metodu. Şunu dene daha rahat görürsün:

    <!DOCTYPE html> 
    <html lang="tr">
    <head>
    <meta charset="UTF-8">
    <title>Document</title>
    <script>

    function dataURItoBlob(dataURI) {
    // convert base64 to raw binary data held in a string
    var byteString = atob(dataURI.split(',')[1]);

    // separate out the mime component
    var mimeString = dataURI.split(',')[0].split(':')[1].split(';')[0];

    // write the bytes of the string to an ArrayBuffer
    var arrayBuffer = new ArrayBuffer(byteString.length);
    var _ia = new Uint8Array(arrayBuffer);
    for (var i = 0; i < byteString.length; i++) {
    _ia[i] = byteString.charCodeAt(i);
    }

    var dataView = new DataView(arrayBuffer);
    var blob = new Blob([dataView], { type: mimeString });
    return blob;
    }

    function drawCanvas() {

    var canvas = document.createElement("canvas");
    canvas.width = 512;
    canvas.height = 512;

    var context = canvas.getContext("2d");
    var val = document.getElementById("txt").value;

    context.font = "bold 32px Arial";
    context.fillStyle = "#000000";
    context.fillText(val, 220, 240);

    var dl = document.getElementById("download");
    dl.href = URL.createObjectURL(dataURItoBlob(canvas.toDataURL())); // datayı kısa url haline getirdik
    dl.download = val + ".png";
    dl.target = "_blank";
    dl.style.display = 'inline-block';

    return false;
    }
    </script>
    </head>
    <body>
    <form action="" onsubmit="return drawCanvas()">
    <input type="text" id="txt" maxlength="5" placeholder="Buraya yazı gelecek">
    <input type="submit" value="Oluştur">
    </form>
    <a href="#" id="download" style="display: none; margin-top: 5px;" >İndir</a>
    </body>
    </html>




  • data ile pek aram yoktur

    

    yaptım çalışmadı




  • OktayYeni kullanıcısına yanıt
    Yazığın datayı dl.href = kısmına aktarırken tırnak kullandın mı? Çünkü bu haliyle string bir ifade olduğu için tırnak içinde kullanmazsan javascript syntax hatası verecektir. Console'dan görebilirsin hatayı.
  • evet

    dl.href = URL.createObjectURL(dataURItoBlob(canvas.toDataURL("
    ")));


    yaptım olmadı




  • OktayYeni kullanıcısına yanıt
    Onu kastetmedim. O şekilde zaten çalışmaz. toDataURL metodunun amacı zaten canvas çizimini png veya jpeg dataURI'ye çevirmektir.

    Şu şekilde dene:
    dl.href = URL.createObjectURL(dataURItoBlob("...")); // Bu sekilde koyduğun dataURI kısa linke dönüştürülüyor

    veya direkt:
    dl.href = "...";


    Edit: ayrıca niye harici bir data yerleştirmeye çalışıyorsun ki orayı anlamadım. Yapmak istediğin yazdığını resme çevirmek değil mi?

    Ayrıca ilk verdiğim dataURItoBlob fonksiyonunu github'dan bulmuştum fakat IE'de çalışmıyor. Onun yerine şunu kullanabilirsin:https://stackoverflow.com/questions/12168909/blob-from-dataurl

    function dataURItoBlob(dataURI) {
    // convert base64 to raw binary data held in a string
    // doesn't handle URLEncoded DataURIs - see SO answer #6850276 for code that does this
    var byteString = atob(dataURI.split(',')[1]);

    // separate out the mime component
    var mimeString = dataURI.split(',')[0].split(':')[1].split(';')[0]

    // write the bytes of the string to an ArrayBuffer
    var ab = new ArrayBuffer(byteString.length);

    // create a view into the buffer
    var ia = new Uint8Array(ab);

    // set the bytes of the buffer to the correct values
    for (var i = 0; i < byteString.length; i++) {
    ia[i] = byteString.charCodeAt(i);
    }

    // write the ArrayBuffer to a blob, and you're done
    var blob = new Blob([ab], {type: mimeString});
    return blob;

    }



    < Bu mesaj bu kişi tarafından değiştirildi Revolution -- 23 Ağustos 2018; 1:19:44 >




  • ben hiç bilmiyorum galiba

    dl.href = "
    ";




  • aslında yapmak istediğin arkaplana foto eklemek
  • hiç bilgimin olmadı yerlere neden girişiyorum bilmiyorum
  • OktayYeni kullanıcısına yanıt
    Sondaki \n karakterini kaldır(enter'i yani). String düz yazılmalı tırnağın içine:

    dl.href = "..."; // doğrusu

    dl.href = "...
    "; // sona böyle enter atarsan yine syntax hatası verir.
  • teşekkürler



    < Bu mesaj bu kişi tarafından değiştirildi OktayYeni -- 23 Ağustos 2018; 1:38:22 >
  • Revolution kullanıcısına yanıt
    bu sefer yazı gözükmedi



    < Bu mesaj bu kişi tarafından değiştirildi OktayYeni -- 23 Ağustos 2018; 1:37:59 >
  • OktayYeni kullanıcısına yanıt
    O şekilde yazı zaten gider. Sadece sabit bir dataURI'yi image olarak çıktılamayı göstermek istedim. Ne istediğini baştan düzgün anlatsan uğraşmamıza gerek kalmazdı. Yazıya arkaplan da eklemek istiyorsun. Aynı canvas'a 2 kere çizim yaptırman gerekiyor. Önce arkaplan olacak resmi sonra da yazıyı. Al doküman:

    Image:
    https://www.w3schools.com/tags/canvas_drawimage.asp
    https://developer.mozilla.org/en-US/docs/Web/API/CanvasRenderingContext2D/drawImage

    Text:
    https://www.w3schools.com/tags/canvas_filltext.asp
    https://developer.mozilla.org/en-US/docs/Web/API/CanvasRenderingContext2D/fillText

    HTML'yi tam bilmiyorsan istediğini zaten yapamazsın. Tavsiyem önce canvas nesnesi nedir ve çizim nasıl yapılıyor onu araştır.




  • 
Sayfa: 1
- x
Bildirim
mesajınız kopyalandı (ctrl+v) yapıştırmak istediğiniz yere yapıştırabilirsiniz.