html canvas 等比放大缩小,Canvas等比例缩放图片,Canvas保存为图片

html框架,包括css

通过 .container的样式将canvas影藏起来,从而实现在选择上传时默默缩小文件的大小,而不让用户察觉

canvas转化后的图片为base64格式,可转为file对象上传至服务器

Document

.container{

width: 0;

height: 0;

overflow: hidden;

}

canvas {

border: 1px solid #000;

}

JavaScript,可将下面代码放到body中,也可放在单独的js文件中,然后在body引入

var from = document.querySelector('#btn')

from.onchange = function (e) {

var imgurl = window.URL.createObjectURL(from.files[0])

console.log(imgurl)

var image = new Image()

image.onload = function () {

var myCanvas = document.querySelector('canvas')

var ctx = myCanvas.getContext('2d')

var imageWidth = image.width

var imageHeight = image.height

//定义压缩后的宽度,也可封装后调用时传入

var img_width = 750 //此处的750是压缩后图片的宽度,也是canvas画布的宽度

//宽度750 ,通过计算可得出缩放后的高

myCanvas.height = img_width*imageHeight/imageWidth

myCanvas.width = img_width

ctx.drawImage(image, 0, 0, imageWidth, imageHeight, 0, 0, img_width,img_width*imageHeight/imageWidth)

var imageData = new Image();

// canvas.toDataURL 返回的是一串Base64编码的URL

// 指定格式 PNG

imageData.src = myCanvas.toDataURL("image/png");

}

image.src = imgurl

}

Canvas保存为图片到本地,可以将代码粘贴到方法中,通过点击事件执行

//myCanvas是html中的canvas标签对象,可通过 document.querySelector('xxx')获取

var bloburl = myCanvas.toDataURL();

console.log('bloburl', bloburl);

var anchor = document.createElement('a');

if ('download' in anchor) {

anchor.style.visibility = 'hidden';

anchor.href = bloburl;

anchor.download = name;

document.body.appendChild(anchor);

var evt = document.createEvent('MouseEvents');

evt.initEvent('click', true, true);

anchor.dispatchEvent(evt);

document.body.removeChild(anchor);

} else {

location.href = bloburl;

}

base64图片转file对象

//将base64转换为blob

dataURLtoBlob: function(dataurl) {

var arr = dataurl.split(','),

mime = arr[0].match(/:(.*?);/)[1],

bstr = atob(arr[1]),

n = bstr.length,

u8arr = new Uint8Array(n);

while (n--) {

u8arr[n] = bstr.charCodeAt(n);

}

return new Blob([u8arr], { type: mime });

},

//将blob转换为file

blobToFile: function(theBlob, fileName){

theBlob.lastModifiedDate = new Date();

theBlob.name = fileName;

return theBlob;

},

//调用

var blob = dataURLtoBlob(bloburl);

var file = blobToFile(blob, imgName);

要实现在 Android WindowManager 中添加 View 并对该 View 进行等比放大缩小,您可以按照以下步骤进行: 1. 创建一个自定义的 View,并实现对应的逻辑,例如等比放大缩小的逻辑。 2. 创建一个 WindowManager.LayoutParams 对象,用于设置添加的 View 的属性,如宽度、高度、位置等。 3. 调用 WindowManager.addView() 方法将 View 添加到 WindowManager 中。 下面是一个简单的示例代码,仅供参考: ``` // 创建一个自定义的 View MyView myView = new MyView(context); // 创建 WindowManager.LayoutParams 对象 WindowManager.LayoutParams params = new WindowManager.LayoutParams(); params.width = WindowManager.LayoutParams.WRAP_CONTENT; params.height = WindowManager.LayoutParams.WRAP_CONTENT; params.gravity = Gravity.TOP | Gravity.LEFT; params.x = 100; params.y = 100; // 将 View 添加到 WindowManager 中 WindowManager windowManager = (WindowManager) getSystemService(WINDOW_SERVICE); windowManager.addView(myView, params); ``` 在自定义的 View 中,您可以通过重写 onDraw() 方法实现等比放大缩小的逻辑。例如,可以在 onDraw() 方法中使用 Canvas.scale() 方法对 View 进行缩放: ``` @Override protected void onDraw(Canvas canvas) { super.onDraw(canvas); canvas.save(); canvas.scale(scaleFactor, scaleFactor, getWidth() / 2, getHeight() / 2); // 绘制 View 的内容 canvas.restore(); } ``` 在这个示例中,scaleFactor 变量表示缩放比例,getWidth() 和 getHeight() 方法获取 View 的宽度和高度。通过调用 Canvas.scale() 方法,可以对 View 进行等比缩放
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值