在显示用户添加的图像时,经常需要调整它们的大小以使其适合页面的特定区域。不这样做可能会导致图像破坏页面布局。问题在于,如果您绝对调整图像的大小,则会倾向于挤压图像并使图像变形。
以下功能可用于将图像的宽度和高度计算为正确的宽高比,当打印输出时将保留内容。该函数利用了该getimagesize()函数,该函数作为PHP的GD库的一部分提供。
/** * Calculates the aspect ratio of an image returns a formatted string * containing the width and height of the image to a fixed width. * * @param string The name of the file * @param integer The width of the image (optional) * * @return string The image dimentions. */ function img_aspect_ratio($file, $width = 200){ if (!file_exists($file)){ // 文件不存在,返回false。 return ''; } // 获取图像尺寸 $image_size = getimagesize($file); if ($image_size === false) { // 无法获取图像尺寸,返回宽度 return ' width="' . $width . '"'; } // 将高度除以宽度以获得长宽比。 $aspect_ratio = $image_size[1] / $image_size[0]; // 根据宽高比更改高度 $height = (int)($aspect_ratio * $width) . "px"; // 返回格式化的宽度和高度的字符串 return ' height="' . $height . '" width="' . $width . '"'; }
您可以使用如下功能:
$image_file = 'example_image.png'; echo '<img' . img_aspect_ratio($image_file, 150) . ' xx_src="' . $image_file . '" />';
我应该指出,这种解决方案远非完美,因此不应在所有情况下都使用。最适合调整图像而仅需稍作调整。例如,在画廊中调整缩略图的大小而不必再次重新生成所有缩略图。
不应使用此功能将大图像缩小为小尺寸,因为您的用户在浏览器中调整大小之前仍然需要下载完整大小的图像。在这种情况下,您应该重新生成图像的较小版本,然后将其用作浏览器中图像的源。
问题内容: 我有这段代码(在字符串中打印所有排列的出现) 我想打印字符串可变项中所有出现的排列。 由于排列的长度不同,因此我想固定宽度并以一种不太好的方式打印它: 我该如何使用呢? 问题答案: 编辑2013-12-11- 这个答案很老。它仍然是有效且正确的,但是关注此问题的人们应该更喜欢新格式的语法。 您可以使用以下字符串格式: 基本上: 该字符运筹学蟒蛇它将不得不替代的东西令牌 该字符运筹学蟒蛇
问题内容: 假设我们有一个多边形坐标为polygon = [(x1,y1),(x2,y2),…],下面的代码显示该多边形: 默认情况下,它会尝试调整纵横比,以使多边形(或其他任何图)适合窗口内部,并自动更改它,以便即使在调整大小后也适合。在许多情况下,这非常好,除非您尝试通过视觉估算图像是否失真。如何将长宽比固定为严格的1:1? (不确定“长宽比”是否在这里是正确的术语,如果不是这样- 我需要X和
我有一个试图加载到imageView中的图像的URI。 图像以全分辨率加载(高达2100万像素,导致内存不足异常)。我的应用程序不需要使用全分辨率图像,因此我希望以这种方式缩小图像,以便满足以下条件: > 如果图像高度大于宽度(即纵向),则将宽度缩放至1024像素,并将高度缩放至适当值以保持纵横比。 如果图像宽度大于高度(即横向),则将高度缩放到1024像素,并将宽度缩放到适当的值以保持纵横比。
问题内容: 有人可以告诉我如何修改此使用matplotlib的Python代码,以便无论绘制多少分,条的宽度都将保持恒定吗?先感谢您! 问题答案: 条的宽度相同!它们看起来不一样的原因是因为您正在使用以下行: 这将更改您的x值,从而更改x轴的比例。为了抵消这种影响,您可以更改x轴的限制,也可以使条形宽度取决于分数的数量,例如,如果0.35的宽度适用于10个分数,那么如果将分数的数量加倍,条宽度的一
问题内容: 我是Java Swing的新手,对下一个代码感到困惑。 我的目标是制作带有 2个JTextPane的 垂直可滚动面板 。具有父面板固定宽度70%的第一个JTextPane和具有固定宽度30%的第二个JTextPane。因为这两个JTextPane具有固定的宽度,所以它们只能在垂直方向上扩展更多文本。 我使用此解决方案,因为我只想为此2个JTextPane使用一个滚动条。 我的初始化代码
我是Java Swing的新手,我对下一个代码感到困惑。 null