- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
主要编辑: 好吧,我只是意识到有一百种不同的情况,您可以按照我的意愿行事,但使用不同的规则,所以我将不得不描述我的具体情况。基本上我正在使用 this image popup ( code here )
如果在弹出窗口打开时缩小窗口的大小,您会注意到弹出窗口不会缩小以适合窗口,这会带来糟糕的用户体验,尤其是在智能手机的横向模式下
我希望我的弹出窗口根据屏幕的两个维度缩小,而不改变图像的纵横比。 (保持平方)
到目前为止,我已经做了这些改变:
.focus {
z-index: 10;
max-width: 500px;
max-height: 500px;
display: none;
}
.focus.enabled .container {
max-width: 500px;
max-height: 500px;
}
如果你尝试 there使用 Firebug ,它使图像在缩小宽度时响应,但在缩小窗口高度时不响应...如何使两个尺寸都响应,同时保持图像的良好纵横比?
------------ 上一个问题(仅供历史引用):----------------
我想在浏览器窗口中严格保留最大尺寸为 500x500 的元素(在这种情况下为图片),同时保持其纵横比。这是一些 html:
<html>
<head>
</head>
<body>
<img src="myimage.png" class="image" />
</body>
</html>
还有一些CSS:
.image {
max-height: 500px;
max-width: 500px;
height: 100%;
width: 100%;
}
现在使用此 css,图像保留在窗口内,但当窗口的其中一个尺寸小于 500px 时图像会变形。要固定比率,我可以去掉两个 100%
规则之一:
.image {
max-height: 500px;
max-width: 500px;
height: 100%;
/*width: 100%;*/
}
但是,比例确实保持不变,但是当窗口宽度小于 500px 时图像会被裁剪!对于这个看似基本的问题,什么是纯粹而简单的 css 解决方案?
最佳答案
这是 vmin 单位 的一个很好的用例:
1/100th of the minimum value between the height and the width of the viewport. (source : MDN)
相关 CSS:
img {
width: 70vmin;
height: 70vmin;
max-width: 500px;
max-height: 500px;
}
使用这些单位的缺点是浏览器支持,IE8 不支持它们-(see canIuse 了解更多信息)
对于 IE9 支持,您需要指定 vm
而不是 vmin
示例:
width:70vm;
width: 70vmin;
height:70vm;
height: 70vmin;
如果您不能使用这些单位,我就没有办法根据高度使用 CSS 来保持 div 的纵横比。您可以使用许多帖子中描述的填充技术根据宽度保持 div 的纵横比 this one .
对于图像,您可以使用我在之前的回答中描述的 CSS 规则,但您无法将图像的大小限制为任意数量的像素。
--------上一个答案--------------------
如果图像的自然大小是 500x500px
,则不需要指定 500px 最大宽度/高度。
您可以将该属性用于 100% 最大宽度/高度,并为宽度/高度赋予 auto
属性以保持图像的纵横比并且永远不会超过 100% 或 500px 宽度/高度:
HTML :
<img src="http://lorempixel.com/output/nature-q-c-500-500-5.jpg" alt="" />
CSS:
img {
max-width:100%;
max-height:100%;
width:auto;
height:auto;
}
关于image - 将弹出图像保持在窗口内并保持纵横比,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24992545/
当我调用 png.Decode(imageFile) 时,它返回类型 image.Image。但我找不到将其转换为 image.NRGBA 或 image.RGBA 的记录方式,我可以在其上调用 At
image/jpeg 和 image/png 包有 Decode 和 Encode 函数,可以读取和写入 jpeg 和 png 图像,但 image/gif 包没有 - 只有 Decode 和 Dec
我正在尝试从一系列任意的非调色板图像创建动画 GIF。为了创建调色板图像,我需要以某种方式想出一个调色板。 // RGBA, etc. images from somewhere else var f
我在今年夏天的空闲时间使用 Go 镜像包进行一些练习。 package main import ( "os" "image" "image/png" "image/co
关闭。这个问题需要debugging details .它目前不接受答案。 想改进这个问题?将问题更新为 on-topic对于堆栈溢出。 1年前关闭。 Improve this question 今天
我正在尝试在 TilePane 中列出图像。当我尝试创建图像 new ImageView("address"); 时出现错误,地址如下: "file:D:/Chrysanthemum.jpeg/" 以
我有一个用于为画廊选择图像的表单,我希望允许用户仅选择 jpg、gif 和 png 图像格式。 现在,为了测试,我将图像的扩展名更改为 .bmp,例如“image1.bmp”,当我在输入文件中单击以选
我有创建图像的代码:(m_img 是 javafx.scene.image.Image) Image m_img = new Image("file:" + p_Fil.getAbsoluteFile
假设我有一个这样的 8 位灰度图像: var pixels []byte = ... width := 100 height := 100 如何将其转换为实现 image.Image 的东西? 最佳答
这段代码是我在localhost:8088 URL上的索引/主页的一部分,如果我想将用户发送到url localhost:8088/image/1,我应该写href='image/{{$image->
我正在尝试对图像进行简单的裁剪。这是代码 from PIL.Image import Image def get_image_half(image, half="upper"): if hal
我在这个问题上花了一整天,但在堆栈溢出中没有看到答案! 我试过了但是没用: >> pil_image = Image.frombytes('RGBA', wand_image.size, wa
所以,我是那些以始终使用最新版本的浏览器而自豪的人之一(当然 Internet Explorer 除外 - 我说的不是那个浏览器)。 我遇到了 this awesome CSS3 website详细介
如果 image_tag 无法从 url 加载图像,我想呈现默认图像: 因此,如果 image_tag 无法从 url 加载图像: 然后呈现默认值: 这将生成结果 HTML: 关于image -
我正在创建一个类似横幅的组件,并将图像设置为组件的背景,但我无法让它工作。我尝试了网上发布的不同建议,但没有成功,目前我不确定我的错误是否在 react 代码中,或者是 webpack 没有正确加载文
如何解决 Dart 中的这种歧义错误。 import 'dart:io'; import 'package:flutter/material.dart'; import 'package:camera
Center( child: CachedNetworkImage( imageUrl: "http:/ sosme link he
设置 www.website.com/sds/(index.htm) 以便鼠标悬停在不同位置时显示图像。 出于某种原因,当您将鼠标悬停在蓝色气球上时,图像 2.jpg 和 3.jpg(在蓝色气球上来回
社交网络在共享 URL 时可以很好地从网站中提取标题和描述,但对于图像,仍然需要创建自定义元标记:property="og:image" name="twitter:image" itemprop="
我正在尝试写一个简短的,它将读取一个 PNG 文件,并将一个 channel 与另一个 channel (R,G,B) 交换作为可能的选择。 但是,我无法找到如何从 image.At(x,y) 返回的
我是一名优秀的程序员,十分优秀!