Canvas Scrollbar Not Working
I created canvas inside the div tag and add background image to the canvas. Here is the code:
Solution 2:
That seems a lot of extra code to do something that seems simple using css and normal html. However, as was stated above, you'll have to size your canvas via code for each image loaded. We're doing the same thing setting the canvas to the image size via jQuery.
You need to account for the scrollbar width when you set the width of your wrapper div. You should also set this width in your code based on browser. The only issue is the scrollbar width is different between different browser rendering engines.
Here's a link talking about that: http://www.sitepoint.com/rwd-scrollbars-is-chrome-better/
Here's code that simplifies scrolling using just html and css.
<!doctype html>
<html>
<head>
<link type="text/css" media="all" href="css/reset.css" /> <!-- reset css -->
<script src="http://code.jquery.com/jquery-1.9.1.js"></script>
<script src="http://code.jquery.com/ui/1.10.1/jquery-ui.js"></script>
<style>
body{ background-color: ivory; }
div, canvas {
position:absolute;
}
.wrapper {
top:10px;
left:10px;
width: 318px; /* adjusted hard-coded scrollbar width; you should set this with js */
height: 300px;
border: 2px solid black;
margin:30px 0 2;
overflow-y: scroll; /* scrolling vertical only */
overflow-x: hidden; /* hiding horizontal scrollbar */
background-color: green;
}
#mycanvas {
left:0px;
top:0px;
}
</style>
<script>
$(function(){
var canvas = document.getElementById("mycanvas");
var ctx = canvas.getContext("2d");
var wrapper;
var canvasHeight;
var img = new Image();
img.onload = function () {
canvas.width = this.width;
canvas.height = this.height;
ctx.drawImage(this, 260, 0, 300, this.height, 0, 0, 300, this.height);
}
img.src = "http://sciencedude.blog.ocregister.com/files/2008/02/zot1-copy.jpg";
}); // end $(function(){});
</script>
</head>
<div class="wrapper" id="canvaswrapper">
<canvas id="mycanvas" width="300px" height="300px" />
</div>
</body>
</html>
Post a Comment for "Canvas Scrollbar Not Working"