示例代码使用Python 的PIL和Tkinter库。根据屏幕大小按照原图片长宽比例进行无拉伸的等比例缩放。预设屏幕方向为竖屏(1080 * 4096),仅是为了适应手机图片。图片缩放比例对照原图的长宽比例,分多次进行,包含快速调整、精确微调以及适应性调整。

# ...
from PIL import Image, ImageTk
# ...
# 预设竖屏图片尺寸
I_WIDTH = 1080
I_HEIGHT = 4096def image_resize(path, screen_width=0, screen_height=0):image = Image.open(path)if screen_width <= 0:screen_width = I_WIDTHif screen_height <= 0:screen_height = I_HEIGHTraw_width, raw_height = image.size[0], image.size[1]max_width, max_height = raw_width, screen_height        min_width = max(raw_width, max_width)# 按照比例缩放min_height = int(raw_height * min_width / raw_width)# 第1次快速调整while min_height > screen_height:min_height = int(min_height * .9533)# 第2次精确微调while min_height < screen_height:min_height += 1# 按照比例缩放min_width = int(raw_width * min_height / raw_height)# 适应性调整   while min_width > screen_width:min_width -= 1# 按照比例缩放min_height = int(raw_height * min_width / raw_width)return image.resize((min_width, min_height))

Python + PIL + Tkinter: 图片原比例缩放相关推荐

  1. html图片缩放6,四款css 图片按比例缩放实例(兼容ie6,7,firefox)

    使用max-width,max-height:或者min-width,min-height的css属性即可.如: 代码如下 img{max-width:100px;max-height:100px;} ...

  2. CSS实战笔记(十二) 图片等比例缩放

    1.背景 在网页展示图片是一个很常见的需求,大多数情况下,展示区域的大小是固定的,原图片的大小也是固定的 如果展示区域的宽高和原图片的宽高不等比例,那么在默认情况下很可能会压缩或拉伸图片以适应区域大小 ...

  3. html5表格图片按比例缩放,JS图片等比例缩放方法完整示例

    本文实例讲述了JS图片等比例缩放方法.分享给大家供大家参考,具体如下: /p> "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional ...

  4. 理解CSS3中的background-size(对响应性图片等比例缩放)

    理解CSS3中的background-size(对响应性图片等比例缩放) 阅读目录 background-size的基本属性 给图片设置固定的宽度和高度的 固定宽度400px和高度200px-使用ba ...

  5. jquery实现图片等比例缩放,解决max-width在ie中不兼容问题

    上次用原生的JavaScript实现的图片等比例缩放,max-width和max-height在ie6中不兼容问题,今天用jQuery实现了这些问题 jQuery部分代码 <script typ ...

  6. 用JavaScript实现网页图片等比例缩放

    如何让网页中的图片等比例缩放呢,我参考了一些代码并自己写了个图片缩放的脚本,可以点击放大,同时用鼠标滑轮自由缩放,希望提出不同意见. 首先看看resizeimg函数的源代码: function res ...

  7. html img图片等比例缩放_我掏空了各大搜索引擎,整理了HTML图片标签笔记,满满干货...

    img标签介绍 介绍 img: 英文全称 image(图像),代表的是一张图片. 如果要想在网页中显示图像,就可以使用img 标签,它是一个单标签.语法如下: <img src="图片 ...

  8. html图片等比例拉伸,CSS控制图片等比例缩放

    我们经常会需要把用户上传的图片等比例缩放在我们的网页上显示,下面我来介绍利用css控制图片比例缩放与javascript实现的方法,有需要了解的朋友可参考参考. 按比例缩小或者放大到某个尺寸,对于标准 ...

  9. androidstudio图片居中_Android imageView图片按比例缩放-Fun言

    android:scaleType可控制图片的缩放方式,示例代码如下:说明:centerInside表示按比例缩放图片,使得图片长 (宽)的小于等于视图的相应维度.注意:控制的图片为资源而不是背景,即 ...

最新文章

  1. centos升级python_CentOS 升级Python3
  2. vue插槽样式_vue 插槽简介及使用示例
  3. java ee6教程_《Java EE 6 企业级应用开发教程》怎么样_目录_pdf在线阅读 - 课课家教育...
  4. 平台积分体系设计方案
  5. php调http接口,2步教你解决http协议php接口调用
  6. 初识Python之安装—anaconda pycharm区别
  7. 机器 – 程序 – 人 (2)
  8. 移动终端开发必备知识(转载)
  9. opencv 处理黑夜_基于 opencv图像去噪
  10. FOSCommentBundle功能包:指南索引页
  11. TransE算法的整理
  12. 混合app--Hybrid App定位
  13. 智能云仓库存管理 v1.2.0
  14. 三目表达式的个人总结
  15. 计算机公式里qf是什么,计算公式
  16. Win10编译OpenJDK源码
  17. 期末C语言不挂科之选择题
  18. 基于AM5728 DSP+ARM平台的嵌入式车牌识别
  19. 新年第一天 | 恶补新一季《黑镜》的同时,营长又深入扒了扒它那擅长机器学习的新爸爸是如何赚钱的
  20. 【Unity 3D 从入门到实战】Unity 3D 组件总结

热门文章

  1. 查看HDFS文件系统数据的三种方法
  2. vue 孙子组件获取祖先组件数据
  3. 判断piv_str1是否包含在piv_str2中,成功返回值大于1,失败返回0
  4. clip python_python中numpy模块下的np.clip()的用法
  5. java中将毫秒值转换为小数点形式(几点几格式)的方法
  6. 基础篇 | 15 C++ 科学计算 - OpenBLAS的安装与使用
  7. kanban系统wekan安装
  8. 用户sa登陆失败时,应该如何解决
  9. 2022年个人Java面试总结
  10. 写了一个疫苗信息管理系统!(附源码)