简体   繁体   English

如何将元素的重复线性渐变转换为 base64 图像或任何其他格式?

[英]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.我似乎找不到将repeat-linear-gradient转换为 base64 图像格式的方法。

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.我的问题是我想用html2canvasjsPDF打印 HTML 页面,但由于html2canvas支持repeat-linear-gradient ,我想知道是否有办法将值转换为 base64。

Also, since the background image is rendered by the gantt-chart library, I can't change how it is set另外,由于背景图像是由gantt-chart图库渲染的,我无法更改它的设置方式

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:您正在处理+-45deg并且最后一个颜色停止是10px所以最小部分是10px*sqrt(2) = 14.14px的高度和宽度:

 .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:您将其保存为图像并使用任何将 png 转换为 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>

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM