- objective-c - iOS 5 : Can you override UIAppearance customisations in specific classes?
- iphone - 如何将 CGFontRef 转换为 UIFont?
- ios - 以编程方式关闭标记的信息窗口 google maps iOS
- ios - Xcode 5 - 尝试验证存档时出现 "No application records were found"
有没有办法不在彼此之上应用多个投影?我正在尝试使用投影来模拟元素周围的笔划。我需要使用投影,因为当我们有蒙版或带有透明点的图像时我需要它来工作,但我找不到另一种方法来完成同样的事情。使用背景颜色的另一种方法不适用于具有透明度的 png 图像。
问题是,例如,当我为左侧和顶部定义投影时,它实际上并没有很好地重叠,而是对重叠的元素应用了额外的投影。这最终得到了平坦的边缘,而不是像它们应该的那样是圆形的。请注意,虽然这是一张圆形图像,但我们允许用户定义自己的蒙版并上传 png,因此它几乎可以是任何形状。
这是问题的 jsfiddle 示例:https://jsfiddle.net/a67fqne2/17/
代码本身:
<div style="width: 391.6px; height: 369.6px; left: 239.6px; top: 28.9px; position: absolute; cursor: default; z-index: 52;">
<div class="imageOuterStyleWrapper">
<div class="imageMiddleStyleWrapper" style="filter: drop-shadow(rgb(139, 69, 19) 19.6px 0px 0px) drop-shadow(rgb(139, 69, 19) 0px 19.6px 0px) drop-shadow(rgb(139, 69, 19) -19.6px 0px 0px) drop-shadow(rgb(139, 69, 19) 0px -19.6px 0px); width: calc(100% - 39.16px); height: calc(100% - 39.16px); padding: 19.58px;">
<div class="imageInnerStyleWrapper" style="clip-path: url("#Mask-2");"><img style="width: 100%; height: 133.083%; left: 0%; top: -16.5415%;" src="https://plicimgstaging-d6d.kxcdn.com?url=https%3A%2F%2Fplic-staging.s3.amazonaws.com%2Fphotos%2F4dbf8644-0751-4e9f-afaf-f5c4a00f6bae%2Foriginal%2FAbdulKarim-Naeemah-01195-00007.JPG%3FX-Amz-Algorithm%3DAWS4-HMAC-SHA256%26X-Amz-Credential%3DAKIAIZ3GLWGI2FROIRRA%252F20180712%252Fus-east-1%252Fs3%252Faws4_request%26X-Amz-Date%3D20180712T165503Z%26X-Amz-SignedHeaders%3DHost%26X-Amz-Expires%3D604800%26X-Amz-Signature%3Dd32c01d8dd7f82206b5f15028fc90a1ff6d5aadd71738648d8e477799e27816b&op=resize,rotate&deg=auto&mode=clip&filter=bilinear&q=90&w=450&plic-ref=plic-books-dev&sig=4ee24d37aa0356fe61c9500d370ca81944338fe5"></div>
</div>
</div>
</div>
<svg width="0" height="0" id="globalMaskDefinitions">
<defs>
<clipPath id="Mask-2" clipPathUnits="objectBoundingBox">
<circle x="0" y="0" width="1" height="1" cx=".5px" cy=".5px" r=".5px"/>
</clipPath>
</defs>
</svg>
最佳答案
问题与在本例中为圆形的形状有关,因此堆叠所有这些具有不同位置的 drop-shadow
将不会保持圆形。
如果您更改颜色,这里可以更好地说明问题:
div,
img {
width: 100%;
height: 100%;
box-sizing: content-box;
}
.imageOuterStyleWrapper {
width: 391.6px;
height: 369.6px;
}
.imageMiddleStyleWrapper {
filter: drop-shadow(red 19.6px 0px 0px)
drop-shadow(blue 0px 19.6px 0px)
drop-shadow(green -19.6px 0px 0px)
drop-shadow(yellow 0px -19.6px 0px);
width: calc(100% - 39.16px);
height: calc(100% - 39.16px);
padding: 19.58px;
}
.imageInnerStyleWrapper {
clip-path: url("#Mask-2");
}
<div class="imageOuterStyleWrapper">
<div class="imageMiddleStyleWrapper">
<div class="imageInnerStyleWrapper" style=""><img src="http://wiesmann.codiferes.net/share/bitmaps/test_pattern.svg"></div>
</div>
<svg width="0" height="0">
<defs>
<clipPath id="Mask-2" clipPathUnits="objectBoundingBox">
<circle x="0" y="0" width="1" height="1" cx=".5px" cy=".5px" r=".5px"/>
</clipPath>
</defs>
</svg>
但如果形状是正方形,你就不会有这个问题,它会完美地工作:
div,
img {
width: 100%;
height: 100%;
box-sizing: content-box;
}
.imageOuterStyleWrapper {
width: 391.6px;
height: 369.6px;
}
.imageMiddleStyleWrapper {
filter: drop-shadow(red 19.6px 0px 0px)
drop-shadow(blue 0px 19.6px 0px)
drop-shadow(green -19.6px 0px 0px)
drop-shadow(yellow 0px -19.6px 0px);
width: calc(100% - 39.16px);
height: calc(100% - 39.16px);
padding: 19.58px;
}
<div class="imageOuterStyleWrapper">
<div class="imageMiddleStyleWrapper">
<div class="imageInnerStyleWrapper" style=""><img src="http://wiesmann.codiferes.net/share/bitmaps/test_pattern.svg"></div>
</div>
修复的一个想法是使用 SVG 并依靠 stroke 来获得你想要的东西:
<svg width="200" height="200">
<defs>
<pattern id="img" patternUnits="userSpaceOnUse" width="200" height="200">
<image xlink:href="http://wiesmann.codiferes.net/share/bitmaps/test_pattern.svg" x="0" y="0" width="200" height="200" />
</pattern>
</defs>
<circle fill="url(#img)" cx="100px" cy="100px" r="80px" stroke="rgb(139, 69, 19)" stroke-width="10"/>
</svg>
我在这里使用了一个圆圈,但你可以很容易地使用任何一种形状:
<svg width="200" height="200">
<defs>
<pattern id="img" patternUnits="userSpaceOnUse" width="200" height="200">
<image xlink:href="http://wiesmann.codiferes.net/share/bitmaps/test_pattern.svg" x="0" y="0" width="200" height="200" />
</pattern>
</defs>>
<polygon points="190,10 60,100 160,190" fill="url(#img)" stroke="rgb(139, 69, 19)" stroke-width="10" />
</svg>
关于CSS:不要在彼此之上应用多个投影,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51311604/
不要 重复自己* 如何为现代机器学习设计开源库 🤗 Transformers 设计理念 “不要重复自己 (Don’t Repeat Yourself)” ,或 DR
我有这种情况。我有 2 个分支,master 和 develop。 在开发分支上我有一些文件,比如说 tools.js .如果我需要更改这个文件,提交它并将其推送到 Github 开发分支。 一切完成
我要上传图片但首先我想查看图像预览,然后当用户单击另一个 asp:button 时,保存图像。 对于预览部分,我使用以下代码: jQuery(document).ready(functi
我是一名编程初学者,现在从 Python 切换到 Clojure。我正在研究一个质数代码,但我没有弄错。我也想练习递归 (defn true-division [n i] (= (/ n i) (
运行 Python 2.7 执行时: $ python client.py get_emails -a "åäö" 我得到: usage: client.py get_emails [-h] [-a
根据我对“告诉-不要-询问”原则的理解,我的其他类不应该能够调用存储在任何其他类中的数据。因此,根据这一原则, setter/getter 是不受欢迎的。为了防止访问数据,它们通常写为: class
我在寻找什么: 我想使用SIMPLE模式最小化的出色功能,同时仅禁用一项特定功能(禁用内联本地功能)。 更新:答案是否定的,根据我的设置是不可能的。 但对于我来说,鉴于我正在使用Grails,有一种解
根据我对“告诉-不要-询问”原则的理解,我的其他类不应该能够调用存储在任何其他类中的数据。因此,根据这一原则, setter/getter 是不受欢迎的。为了防止访问数据,它们通常写为: class
是否可以不 float 具有样式 UITableViewStylePlain 的 UITableView 的节标题? 我正在 build AcaniChat, an open-source versi
当二进制文件、swfs、jar 和 flvs 在本地更改时,我尝试 pull 入更改,git 尝试 merge 它们并报告冲突。 然后,我分支到一个临时分支,提交本地更改的二进制文件,并在 pull
我正在尝试使用 Pex 来测试一些代码。我有一个具有四个具体实现的抽象类。我为四种具体类型中的每一种都创建了工厂方法。我还为抽象类型创建了一个,除了 this nice thread。说明,Pex 不
我正在将 asp.net mvc 3 和 razor 用于一个项目。在某些情况下,我需要从 Controller 序列化一个数组,将其放入 View 数据并将其分配给一个 js 对象。但是当我使用 输
是否可以让一个 webpack 开发服务器配置多个入口点(网站上有多个页面),每个入口点都有不同的配置? 具体来说,我希望将一个条目(页面的 JS 代码)分成 block ,但不要将另一个条目(带有已
我需要使用 hibernate 将 InputStream 或 byte[] (个人资料图像)保存在表中。这里的代码: @Override public void actualizarFotoPerf
我在一个 android 项目中同时拥有 GMS 和 HMS。 GMS 版本有效,但 HMS 不调用 onMapReady 回调。这是代码: private var mMap: HuaweiM
我有一个单元测试文件: module X04PatMatTest where import AssertError import Test.HUnit import X04PatMat ... 和 h
是否可以将 c++ 库包装到 c 中? 我该怎么做? 有现成的工具吗? (需要访问现有的 c++ 库,但只能使用 C) 最佳答案 您可以用 C 编写面向对象的代码,因此如果它是面向对象的 C++ 库,
我有一个 JSP 页面,它接受 SQL 查询,执行它们然后将结果返回到一个表中。一些结果偶尔会在其中包含 HTML 标记,即 - 结果将返回: This is the returned result!
我有一个问题。 我需要帮助。我一直在寻找解决方案大约 5 个小时。不幸的是没有成功。 我的问题是我有几个 Storyboard并且没有使用 Segue 创建。 我希望将选定的 Tableviewcel
当我尝试运行以下代码时: #include void main() { char *a[10] = {"hi", "hello", "how"}; int i = 0, j = 0;
我是一名优秀的程序员,十分优秀!