Javascript Html2Canvas调整大小
我正在使用html2canvas获取网页的屏幕截图,并将其呈现为缩略图(嗯,400x300,不完全是缩略图) 基于,除了缩略图部分外,其他一切都很好 如何将图像大小设置为400x300?在firebug中,我将属性定位为:Javascript Html2Canvas调整大小,javascript,html,canvas,screenshot,html2canvas,Javascript,Html,Canvas,Screenshot,Html2canvas,我正在使用html2canvas获取网页的屏幕截图,并将其呈现为缩略图(嗯,400x300,不完全是缩略图) 基于,除了缩略图部分外,其他一切都很好 如何将图像大小设置为400x300?在firebug中,我将属性定位为:。但是,我无法在我的代码(如下)或html2canvas.js中找到400x300参数的硬编码位置 screenshot.html: <html> <head> <title>Screenshot</title> <!-
。但是,我无法在我的代码(如下)或html2canvas.js中找到400x300参数的硬编码位置
screenshot.html:
<html>
<head>
<title>Screenshot</title>
<!--[if lt IE 9]>
<script src="//html5shim.googlecode.com/svn/trunk/html5.js">
</script>
<![endif]-->
</head>
<body>
<div class=container> </div>
<script src="//ajax.googleapis.com/ajax/libs/jquery/1.7.1/jquery.min.js"></script>
<script type="text/javascript" src="js/html2canvas.js"></script>
<script type="text/javascript">
var date=new Date();
var message,timeoutTimer,timer;
var proxyUrl="http://html2canvas.appspot.com";
function addRow(a,c,d){var b=$("<tr />").appendTo($(a));b.append($("<td />").css("font-weight","bold").text(c)).append($("<td />").text(d))}function throwMessage(b,a){window.clearTimeout(timeoutTimer);timeoutTimer=window.setTimeout(function(){message.fadeOut(function(){message.remove()})},a||2000);$(message).remove();message=$("<div />").html(b).css({margin:0,padding:10,background:"#000",opacity:0.7,position:"fixed",top:10,right:10,fontFamily:"Tahoma",color:"#fff",fontSize:12,borderRadius:12,width:"auto",height:"auto",textAlign:"center",textDecoration:"none"}).hide().fadeIn().appendTo("body")}$(function(){$("#recommended a").click(function(c){c.preventDefault();$("#url").val(this.href);$("button").click()});var a,b;$('input[type="button"]').click(function(){$(a.contentWindow).unbind("load");$(a).contents().find("body").html2canvas({canvasHeight:b.body.scrollHeight,canvasWidth:b.body.scrollWidth,logging:true})});$("#getscreenshot").click(function(d){d.preventDefault();$(this).prop("disabled",true);var c=$("#url").val();$("#content").append($("<img />").attr("src","loading.gif").css("margin-top",40));var f=document.createElement("a");f.href=c;$.ajax({data:{xhr2:false,url:f.href},url:proxyUrl,dataType:"jsonp",success:function(e){a=document.createElement("iframe");$(a).css({visibility:"hidden"}).width($(window).width()/2).height($(window).height()/2);$("#content").append(a);b=a.contentWindow.document;b.open();$(a.contentWindow).load(function(){var g=$(a).contents().find("body"),h={onrendered:function(j){$("#content").empty().append(j);$("#getscreenshot").prop("disabled",false);$("base").attr("href","")},allowTaint:true,taintTest:false,flashcanvas:"src/flashcanvas.min.js"},i=html2canvas(g,h)});$("base").attr("href",f.protocol+"//"+f.hostname+"/"+f.pathname);e=e.replace("<head>","<head><base href='"+f.protocol+"//"+f.hostname+"/"+f.pathname+"' />");if($("#disablejs").prop("checked")){e=e.replace(/\<script/gi,"<!--<script");e=e.replace(/\<\/script\>/gi,"<\/script>-->")}b.write(e);b.close()}})})});
</script>
<form class="well form-search">
<label for=url>Website URL:</label>
<input type=url id=url value="http://www.yahoo.com" class="input-medium search-query"/>
<button class=btn id=getscreenshot>Get screenshot!</button>
</form>
<div id=content></div>
</body>
</html>
截图
变量日期=新日期();
var消息、定时器、定时器;
var proxyUrl=”http://html2canvas.appspot.com";
函数addRow(a,c,d){var b=$(“”).appendTo($(a));b.append($(“”).css(“字体重量”,“粗体”).text(c)).append($(“”).text(d))}函数throwMessage(b,a){window.clearTimeout(timeoutTimer);timeouttimeout=window.setTimeout(函数(){message.fadeOut(函数(){message.remove());$(message.2000);(message.remove();message=$).html(b).css({边距:0,填充:10,背景:#000,不透明度:0.7,位置:“固定”,顶部:10,右:10,fontFamily:“Tahoma”,颜色:#fff,fontSize:12,边框半径:12,宽度:“自动”,高度:“自动”,文本对齐:“中心”,文本装饰:“无”).hide().fadeIn().appendTo(“body”)$(函数(){$(“#推荐a”)。单击(函数(c){c.preventDefault()$(“#url”).val(this.href)$(“按钮”).click()});var a,b;$('input[type=“button”]”)。click(函数(){$(a.contentWindow)。解除绑定('load”);$(a.contents().find(“body”).html2canvas({canvasHeight:b.body.scrollHeight,canvasWidth:b.body.scrollWidth,logging:true});$(“#获取屏幕截图”)。click(函数(d){d.preventDefault()$(this)。prop(“disabled”,true);var=(“#url()”)。).append($(“”,“”);if($(“#disablejs”).prop(“选中”){e=e.replace(/\您可以使用缩略图尺寸创建其他新的
,并使用drawImage()在此新
上缩小它的比例
drawImage()可以将
读取为图像
源,您可以设置目标宽度和高度
您可以使用getContext('2d')
方法从画布上下文获取引用,然后将返回的上下文分配给变量(例如ctx
),您可以使用contextscale
方法将画布上下文缩放到所需大小。此外,您可以使用style属性定义画布大小,并通过将实际图像大小除以所需缩略图大小来设置stylewidth
和height
属性的大小。在最后一步中您将生成的数字放入ctx.scale(width,height);
方法中。基于Mikkos提示,我想到了以下几点
window.html2canvas([$('body')[0]], {
onrendered: function(canvas) {
var extra_canvas = document.createElement("canvas");
extra_canvas.setAttribute('width',70);
extra_canvas.setAttribute('height',70);
var ctx = extra_canvas.getContext('2d');
ctx.drawImage(canvas,0,0,canvas.width, canvas.height,0,0,70,70);
var dataURL = extra_canvas.toDataURL();
var img = $(document.createElement('img'));
img.attr('src', dataURL);
// insert the thumbnail at the top of the page
$('body').prepend(img);
},
});
我对你的问题采用了类似的方法,部分基于其他答案:)
由于如果图像是实际图像,则调整图像大小更容易,因此下面是我的代码:
var img = new Image();
img.src = canvas.toDataURL("image/png");
img.width = 500;
document.getElementsByClassName('modal-body')[0].appendChild(img);
canvas
是html2canvas函数的输出;然后我创建了一个img
用img数据(画布的base64编码)设置其源代码。其余的是标准的好的旧javascript:设置img宽度,附加到div元素…发现这种方式对我来说不合适(后来我发现了它为什么这样做)。只需在位置属性之后添加一些属性,如下面的doc.addImage(img,'JPEG',20,20,200,250)
,最后两个数字可以让您调整img的大小。这对我来说非常有用
html2canvas(document.getElementById("divTextOrig"), { allowTaint: true,
scrollX:0, scrollY: -window.scrollY}).then(function(canvas)
{
document.getElementById("divText1").appendChild(canvas);
$('canvas').css("width",txtWidth);
$('canvas').css("height",txtHeight);
});
您好,您的代码让我如此接近成功,只是缺少了一些与ctx我有一个图像未知的宽度和高度。我希望它适合(保持其纵横比)在让我们说800x500像素,但当图像是宽度我得到了一个不希望的裁剪:(任何想法如何设置一个适当的适合?提前感谢