2 quicksilvery quicksilvery 于 2016.01.29 23:31 提问

将canvas的画append给body充当背景图,但出现奇怪效果

这是初始的样子,我想要的效果是这颗心不随滚动条滚动
图片说明

当我拖动滚动条的时候,这颗心跟着移动了,但原位置固定了另一颗心。
图片说明

继续拖动滚动条,
图片说明
由此可见,初始页面的心会随着滚动条移动,但同时有另一个心被固定在中间。
我只想要让这个心被固定在中心。不会因为滚动条的移动而出现另一颗心。

我通过JS建立canvas并将画设为背景图,JS代码如下:
var canvas = document.createElement('canvas');
var canvas_width = $("body").css("width").split("p")[0];
var canvas_height = $("body").css("height").split("p")[0];

document.body.appendChild(canvas);
canvas.id='homePageCanvas';
canvas.width = canvas_width; 
canvas.height = canvas_height;
//canvas.style.backgroundColor = '#F9D1D4';

drawHeartCurve(); //画出了一个心
document.body.style.background = "url('"+homePageCanvas.toDataURL()+"')";

document.body.style['background-attachment']='fixed';

HTML/CSS只有一个很高的div让滚动条出现。

2个回答

danielinbiti
danielinbiti   Ds   Rxr 2016.01.30 00:01
已采纳

用圆点模拟了一下,实现效果如下

 <!DOCTYPE HTML>
<html>
<head>
<title>背景固定居中</title>
</head>
<body>
<table width="318" height="3081" border="0" cellpadding="0" cellspacing="0">
  <tr>
    <td>&nbsp;</td>
  </tr>
</table>
<canvas id="myCanvas" width="200" height="100" style="border:1px solid #c3c3c3;display:none;">
Your browser does not support the canvas element.
</canvas>
<p>
<script>
var c=document.getElementById("myCanvas");
var cxt=c.getContext("2d");
cxt.fillStyle="#FF0000";
cxt.beginPath();
cxt.arc(70,18,15,0,Math.PI*2,true);
cxt.closePath();
cxt.fill();

</script>
  <script language="javascript">
document.body.style.backgroundImage="url('"+myCanvas.toDataURL()+"')";
document.body.style.backgroundPosition="center";
document.body.style.backgroundRepeat="no-repeat";
document.body.style.backgroundAttachment="fixed";
  </script>
</p>
</body>
</html>
quicksilvery
quicksilvery 解决了。把宽高传递给ctx,然后填充即可。ctx.fillStyle="#F9D1D4"; ctx.fillRect(0,0,wid,hei); 困扰了一天的问题圆满解决,非常开心。再次感谢
接近 2 年之前 回复
quicksilvery
quicksilvery 解决了。把宽高传递给ctx,然后填充即可。ctx.fillStyle="#F9D1D4"; ctx.fillRect(0,0,wid,hei); 困扰了一天的问题圆满解决,非常开心。再次感谢
接近 2 年之前 回复
quicksilvery
quicksilvery 谢谢你。根据你的回答,我找到原因了。 只要设置了 display:none 就能阻止这种情况发生。 但这样的话,canvas的背景颜色就不显示了。 请问canvas有没有什么办法可以在这种情况下给画布实现“背景颜色”这种效果(下面这句代码)呢? canvas.style.backgroundColor = '#F9D1D4';
接近 2 年之前 回复
asd2603934
asd2603934   2016.01.30 00:33

加油加油加油加油咯咯哈你咯咯咯咯哈你名字我图片说明图片说明图片说明图片说明图片说明图片说明图片说明图片说明图片说明图片说明图片说明图片说明图片说明

Csdn user default icon
上传中...
上传图片
插入图片
准确详细的回答,更有利于被提问者采纳,从而获得C币。复制、灌水、广告等回答会被删除,是时候展现真正的技术了!