Rr_Jin 2022-05-24 14:23 采纳率: 28.6%
浏览 17

关于上传图片,使用max-width后导致图片像素改变的问题

html部分代码

 <div class="pic-res">
        <div class="pic">
                <img  id="picture"  src="./img/demo.svg" alt="">
        </div>
</div>

css部分代码

.pic-res .pic #picture {
    max-width: 100%;
    max-height: 100%;
}

上传图片的代码

    var file = fileDOM.files[0];
    var reader = new FileReader();
    reader.readAsDataURL(file);
    reader.onload = function (e)
    {
        document.getElementById("picture").src = this.result;
    }

使用canvas获取像素数据

    var img = document.getElementById("picture");
    var canvas = document.createElement("canvas");
    var context = canvas.getContext("2d");
    var width = img.width;
    var height = img.height;
    canvas.width = width;
    canvas.height = height;
    context.drawImage(img, 0, 0, width, height);
    var imageData = context.getImageData(0, 0, width, height);
    console.log("图片像素数据:");
    console.log(imageData);

这里上传的图片都是黑白像素的二维码,255或0的像素
发现当上传的图片没有超过 .pic 盒子的时候,像素不会改变

img

但是如果超过.pic 盒子,缩小后,使用canvas获取的像素会有0-255的中间值

img

求解决~

  • 写回答

1条回答 默认 最新

  • 你好!机器人 2022-05-24 14:34
    关注

    .pic固定下宽高

    评论

报告相同问题?

问题事件

  • 创建了问题 5月24日

悬赏问题

  • ¥15 preLaunchTask"C/C++: aarch64- apple-darwin22-g++-14 生成活动 文件”已终止,退出代码为-1。
  • ¥18 关于#贝叶斯概率#的问题:这篇文章中利用em算法求出了对数似然值作为概率表参数,然后进行概率表计算,这个概率表是怎样计算的呀
  • ¥20 C#上传XML格式数据
  • ¥15 elementui上传结合oss接口断点续传,现在只差停止上传和继续上传,各大精英看下
  • ¥100 单片机hardfaulr
  • ¥20 手机截图相片分辨率降低一半
  • ¥50 求一段sql语句,遇到小难题了,可以50米解决
  • ¥15 速求,对多种商品的购买力优化问题(用遗传算法、枚举法、粒子群算法、模拟退火算法等方法求解)
  • ¥100 速求!商品购买力最优化问题(用遗传算法求解,给出python代码)
  • ¥15 虚拟机检测,可以是封装好的DLL,可付费