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
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>