使用canvas画图并充当背景图片,但出现奇怪效果

quicksilvery 2016-01-29 11:14:15
这是初始的样子,我想要的效果是这颗心不随滚动条滚动


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


继续拖动滚动条,

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


我通过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让滚动条出现。
<body>
<div id="a" style="width:100px;height:3000px;background:yellow;position:absolute;"></div>
</body>

...全文
651 8 打赏 收藏 转发到动态 举报
写回复
用AI写文章
8 条回复
切换为时间正序
请发表友善的回复…
发表回复
weixin_36419876 2018-12-20
  • 打赏
  • 举报
回复
引用 7 楼 quicksilvery 的回复:
已解决。 要增添下列语句: canvas.style.display="none";
最简单的解决办法
quicksilvery 2016-01-30
  • 打赏
  • 举报
回复
已解决。 要增添下列语句: canvas.style.display="none";
天际的海浪 2016-01-30
  • 打赏
  • 举报
回复

<!doctype html>
<html lang="en">
<head>
	<meta charset="UTF-8" />
	<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1" />
	<title> 页面名称 </title>
<style type="text/css">
html,body {
	height: 100%;
}
</style>
</head>
<body>
<div id="a" style="width:100px;height:3000px;background:yellow;position:absolute;"></div>
<script type="text/javascript">
    var canvas = document.createElement('canvas');
    var canvas_width = document.body.offsetWidth;
    var canvas_height = document.body.offsetHeight;
    canvas.id='homePageCanvas';
    canvas.width = canvas_width;
    canvas.height = canvas_height;
    var context = canvas.getContext("2d");
    context.arc(400,400,100,0,2*Math.PI,true);
    context.fill();
    document.body.style.background = "url('"+canvas.toDataURL()+"')";
    document.body.style['background-attachment']='fixed';
</script>
</body>
</html>
天际的海浪 2016-01-29
  • 打赏
  • 举报
回复
你引用元素时不要用id “homePageCanvas”,直接用 var canvas = document.createElement('canvas');这行定义的 canvas变量就可以了
quicksilvery 2016-01-29
  • 打赏
  • 举报
回复
引用 3 楼 ShenShiampMoYi 的回复:
建议加个alart调试看看, 会不会是代码重复执行了。
我在画心的函数里加了alert(1),只弹出一次1....
  • 打赏
  • 举报
回复
建议加个alart调试看看, 会不会是代码重复执行了。
quicksilvery 2016-01-29
  • 打赏
  • 举报
回复
引用 1 楼 jslang 的回复:
document.body.appendChild(canvas);这行删除
不行,这样子画出来的东西就没了。
天际的海浪 2016-01-29
  • 打赏
  • 举报
回复
document.body.appendChild(canvas);这行删除

61,112

社区成员

发帖
与我相关
我的任务
社区描述
层叠样式表(英文全称:Cascading Style Sheets)是一种用来表现HTML(标准通用标记语言的一个应用)或XML(标准通用标记语言的一个子集)等文件样式的计算机语言。
社区管理员
  • HTML(CSS)社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧