Search code examples
javascripthtmlcssbackground-imagehtml2canvas

How to convert repeating-linear-gradient of an element to a base64 image or any other format?


I can't seem to find a way to convert the repeat-linear-gradient to a base64 image format.

background-image: repeating-linear-gradient(-45deg, transparent, transparent 5px, white 5px, white 10px);

My problem is I want to print an HTML page with html2canvas and jsPDF but since html2canvas doesn't support support repeat-linear-gradient, I would like to know if there is a way to convert the value to base64.

Also, since the background image is rendered by the gantt-chart library, I can't change how it is set


Solution

  • Since it's a repeating gradient, you can identify the smallest portion that you can export as image and that will allow you to have the same background by repeating this image.

    You are dealing with +-45deg and the last color stop is 10px so the smallest portion is 10px*sqrt(2) = 14.14px for the height and width:

    .box {
      height: 14.14px;
      width: 14.14px;
      background: repeating-linear-gradient(-45deg, transparent, transparent 5px, blue 5px, blue 10px);
    }
    <div class="box"></div>

    You save this as an image and you use any online tool that convert a png to base64:

    .box {
      height: 100px;
      margin: 5px;
      background: url('');
    }
    <div class="box"></div>
    
    <div class="box" style="background:repeating-linear-gradient(-45deg, transparent, transparent 5px, blue 5px, blue 10px)"></div>


    For a dynamic solution I will consider the code used in this previous answer

    var box = document.querySelector(".box");
    
    domtoimage.toPng(box)
      .then(function(dataUrl) {
        console.log(dataUrl)
        var image = new Image();
        image.onload = function() {
            document.body.appendChild(image);
        };
        image.src = dataUrl;
      })
    .box {
      height: 100px;
      margin:5px;
      background: repeating-linear-gradient(-45deg, transparent, transparent 5px, blue 5px, blue 10px);
    }
    <script type="text/javascript" src="https://css-challenges.com/wp-content/themes/ronneby_child/js/dom-to-image.js"></script>
    
    <div class="box"></div>

    Also like this:

    var box = document.querySelector(".box");
    
    domtoimage.toPng(box)
      .then(function(dataUrl) {
        console.log(dataUrl);
        document.querySelector(".alt").style.background='url('+dataUrl+')';
      })
    .box {
      height: 14.14px;
      width: 14.14px;
      background: repeating-linear-gradient(-45deg, transparent, transparent 5px, blue 5px, blue 10px);
    }
    
    .alt {
      height:100px;
      margin:5px;
    }
    <script type="text/javascript" src="https://css-challenges.com/wp-content/themes/ronneby_child/js/dom-to-image.js"></script>
    
    <div class="box"></div>
    
    <div class="alt"></div>