gpt4 book ai didi

html - 透明背景在图像调整大小时变为白色

转载 作者:塔克拉玛干 更新时间:2023-11-02 22:13:23 27 4
gpt4 key购买 nike

我有一个 HTML 页面,我需要在其中呈现 3 个图像,一个在彼此之上。

<div id="preview">
<img src="transparent-image">
</div>

使用以下 CSS

#preview{
background-image:url(layer0-image), url(layer1-image);
background-size:100%, 100px;
background-blend-mode: multiply;
width: 820px;
height: 350px;
}

前 2 张图像使用 CSS 属性 background-blend-mode: multiply 混合在一起,在此之上我将最后一张图像(透明图像)与透明背景(想象一张房间的照片,墙壁区域是透明的)。

结果正是我想要的但是当我尝试放置

#preview{
width:100%
}

使其响应;它工作完美,但在 ios 上透明性丢失了。我在 Chrome、Safari 和 Firefox (iOS) 上测试了这种行为。在 OSX、Android、Windows 上的 Chrome、Safari、Firefox 上完全没有问题。

有什么我想念的吗?感谢您的宝贵时间。

编辑:

layer0-image 和 transparent-image 是相同的图像,layer0-image 没有透明度并与 layer1-image 相乘,然后在这个混合图像之上放置透明图像。

我试着把transparent-image换成另一个,问题似乎是layer0-image和layer1-image之间的混合,但由于layer0-image和transparent-image是一样的,一开始我认为存在透明度问题。

透明度是有的,但是 div #preview 的高度是 0px

#preview{
width:100%;
height:auto;
}

没有混合。

EDIT2:

我正在添加一个示例来显示和复制错误:https://jsfiddle.net/dyqnghdo/3/

最佳答案

好的,我终于找到问题了。拥有:

#preview{
background-image:url(layer0-image), url(layer1-image);
background-size:100%, 100px;
background-blend-mode: multiply;
width: 820px;
height: 350px;
}

然后设置:

#preview{
width:100%;
}

导致错误。为了修复它,我尝试设置:

#preview{
width:100%;
background-size:cover, 100px;
}

即使我不清楚问题发生的原因,问题也已解决。

关于html - 透明背景在图像调整大小时变为白色,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42767279/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com