画布轴线的厚度正在增加

时间:2015-08-04 06:38:30

标签: html5-canvas html2canvas c3

我正在使用html5画布将svg(条形图)转换为画布,然后转换为image.But,同时转换x轴和y轴线的厚度正在增加。

这是我的代码

var html = d3.select(
                    '#div2 #' + $scope.selectedoption + ' svg')
                    .attr("version", 1.1).attr("xmlns",
                            "http://www.w3.org/2000/svg")
                    .node().parentNode.innerHTML;

            // d3.select("#mycanvas").style("display", "none");

            var canvasval = document.getElementById('mycanvas');

            if (canvasval != null)
                document.getElementById('mycanvas').remove();


            var newcanvas = document.createElement('canvas');
            newcanvas.setAttribute('id', "mycanvas");
            newcanvas.setAttribute('width', "900");
            newcanvas.setAttribute('height', "900");



            var olddiv = document.getElementById('drawcanvas');
            olddiv.appendChild(newcanvas);

            // console.log(document.getElementById('mycanvas'))
            var canvas = document.getElementById("mycanvas"), context = canvas
                    .getContext("2d");


            // build the query selector for the desired canvas



            context.lineWidth = 0.0;


            var DOMURL = window.URL;

            var img = new Image();
            var svg = new Blob([ html ], {
                type : 'image/svg+xml;base64;charset=UTF-8;'
            });
            var url = DOMURL.createObjectURL(svg);

            img.onload = function() {
                context.drawImage(img, 0,0);
                DOMURL.revokeObjectURL(url);
            }

            img.src = url;
            img.Timeout=0;

            var flag = 0;

            /*
             * var olddiv =
             * document.getElementById('drawcanvas');
             * olddiv.appendChild(newcanvas);
             */

            // $scope.hidevalue=false;
        }
        html2canvas(
                document.getElementById(canvaseleid),
                {
                    onrendered : function(canvas) {
                        var imgData = canvas
                                .toDataURL('image/png');

                        var a = document.createElement("a");
                        a.download = "rept.png";
                        a.href = imgData;
})

我无法弄清楚它的原因。我也试过设置几个css属性。

谢谢

1 个答案:

答案 0 :(得分:1)

您需要将轴设置为透明(您看到的粗线实际上是填充)。您需要添加笔触颜色(以显示一条线)

您必须在内联CSS中执行此操作 - 您可以使用d3添加这些样式,如此(在SVG中绘制图表之后,以及在调用html2canvas之前)

d3.selectAll(".domain")
    .style("stroke", "black")
    .style("fill", "transparent");