猿问

html5 Canvas 如何自适应屏幕大小?

html5 Canvas 如何自适应屏幕大小?


慕婉清6462132
浏览 299回答 3
3回答

撒科打诨

可以用JS监控屏幕大小,然后调整Canvas的大小。在代码中加入JS1234567$(window).resize(resizeCanvas);&nbsp;function&nbsp;resizeCanvas()&nbsp;{&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;canvas.attr("width",&nbsp;$(window).get(0).innerWidth);&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;canvas.attr("height",&nbsp;$(window).get(0).innerHeight);&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;context.fillRect(0,&nbsp;0,&nbsp;canvas.width(),&nbsp;canvas.height());&nbsp;};&nbsp;resizeCanvas();就可以了。<canvas> 标签只是图形容器,您必须使用脚本来绘制图形。&nbsp;

肥皂起泡泡

用JS调制屏幕大小。1.CSS 方面:去掉所有元素的外间距、内边距,html 和 body 宽高设为 100%,canvas 元素 display 设为 block。2.JS 方面:监听窗口的 resize 事件,在窗口大小改变的同时调整 canvas 的大小。3.完整代码这里我们使用 jQuery 来处理窗口尺寸改变事件响应,以及属性设置。4.同时使用 $(window).get(0).innerHeight 获取窗口高度,而不是 $(window).height()。是因为后者效果并不完美,无法返回所有浏览器窗口的完整高度值,这样浏览器窗口中 canvas 元素和滚动条的四周可能会仍存在白色区域。5.代码公式:<!DOCTYPE html><html><head><meta charset="utf-8"><title></title><script src="jquery-3.1.1.js"></script><style>* {margin: 0;padding: 0;}html, body {height: 100%;width: 100%;}canvas {display: block;background: #D6F8FF;}</style><script type="text/javascript">$(function() {//添加窗口尺寸改变响应监听$(window).resize(resizeCanvas);//页面加载后先设置一下canvas大小resizeCanvas();})//canvasfunctionresizeCanvas{$("#myCanvas").attr("width"$(window).get(0).innerWidth);$("#myCanvas").atr("height", $(window).get(0).innerHeight);};</script></head<body<canvas id="myCanvas" width="400" height="200"></body>。</html>&nbsp;

慕田峪4524236

只有内嵌css有效,外部css会出现拉伸的情况,所以有两种方案var myCanvas = "<canvas id='myCanvas' width='" + screen.availWidth + "px' height='"+ screen.availHeight + "px'></vanvas>";document.body.insertAdjacentHTML("beforeEnd", myCanvas);或者这种做法var myCanvas = document.createElement("canvas");myCanvas.setAttribute("width", screen.availWidth);myCanvas.setAttribute("height", screen.availHeight);myCanvas.setAttribute("id", "myCanvas");document.body.appendChild(myCanvas);两种方案的共性都是在把元素添加进DOM前设置他的大小&nbsp;
随时随地看视频慕课网APP

相关分类

Html5
我要回答