- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我如何得到图像后面的黑圈(阴影)?
我将 background
与图像 sprite 一起使用,以在 span 标签上放置圆形按钮图像。我希望在每个图像后面放置一个阴影以获得视觉效果,但无法将黑点放在按钮图像后面。
虽然如果我颠倒过来,将黑点放在 span 标签上,将按钮图片放在图像标签上,它会起作用,有很多这样的按钮,黑点同时出现,并在几秒钟后出现按钮图像全部同时出现在点的顶部。有效,但看起来像废话。
因此,我需要一个解决方案,将按钮图像保留在 span 标签上,并以某种方式在 span 标签背景图像后面放置一个模糊的黑色圆圈(阴影)。
这是我尝试过的方法(注意禁用的尝试使用 ::before
伪类。
HTML:
<div class="container"></div>
<div class="TabMenu">
<span id="sml_1"><img class="smallIconSprite" src="blank.png" width="40" height="40" /></span>
<span id="sml_2"><img class="smallIconSprite" src="blank.png" width="40" height="40" /></span>
<span id="sml_3"><img class="smallIconSprite" src="blank.png" width="40" height="40" /></span>
<span id="sml_4"><img class="smallIconSprite" src="blank.png" width="40" height="40" /></span>
<span id="sml_5"><img class="smallIconSprite" src="blank.png" width="40" height="40" /></span>
<span id="sml_6"><img class="smallIconSprite" src="blank.png" width="40" height="40" /></span>
</div>
CSS:
.container{width:800px;height:620px;padding-left:108px;margin-left:-400px;}
.container{background-image:url(background.jpg);background-repeat:no-repeat;}
.TabMenu{position:absolute;left:0;top:50px;z-index:1;}
.TabMenu{width:200px;height:700px;margin-left:320px;margin-top:55px;}
.TabMenu span{display:inline-block;height:35px;width:31px;margin:1px 7px;padding:5px 0px 0px 10px;}
.TabMenu span{background-image:url(button_icons.gif);background-repeat:no-repeat;}
.TabMenu span:hover{opacity:0.8;cursor:pointer;}
xxx.TabMenu span::after{width:46px;height:46px;content:url(blackdot.png);position:relative;top:-55px;left:-18px;}
.smallIconSprite{position:relative;top:-10px;left:-15px;width:45px;height:45px;}
.smallIconSprite{background-image:url(blackdot.png);background-repeat:no-repeat;background-position:-5px -5px;}
#sml_1{background-position:0px 0px;}
#sml_2{background-position:-40px 0px;}
#sml_3{background-position:-80px 0px;}
#sml_4{background-position:0px -40px;}
#sml_5{background-position:-40px -40px;}
#sml_6{background-position:-80px -40px;}
最佳答案
最简单的修复:在图像上使用 z-index: -1;
。这会将它们定位在图标后面。所以添加
img.smallIconSprite { z-index: -1; }
但我认为,完全没有 img 标签会更好。毕竟,它们仅用于背景,在文档中没有任何语义值(value)。您的 HTML 可能如下所示:
<div class="TabMenu">
<span id="sml_1"></span>
<span id="sml_2"></span>
<span id="sml_3"></span>
<span id="sml_4"></span>
....
您可以使用 ::before
和 ::after
伪元素,而不是在 span 上设置图像,在 img 标签中设置背景.这样就可以在after
设置图片,在before
设置背景,图片自动置顶。 span 本身仅用于定位,(在本例中)没有任何可见的特征。
通过使用伪元素,您甚至根本不需要 img 标签,这很好,因为它仅用于阴影,不会为文档添加语义值。
只要将position: relative
添加到span 中,就可以对前后元素使用absolute
位置。
在这种情况下,我仍然使用您的阴影图像,但您也可以尝试使用 CSS 阴影。此外,您可以将阴影作为 sprite 添加到按钮图像,这样您就只有一个背景图像。
.container{
width:800px;height:620px;padding-left:108px;margin-left:-400px;
background-image: url(http://goodwinstudio.com/_dev/images/bg_filmprojects.jpg);
background-repeat: no-repeat;
}
.TabMenu{position:absolute;left:0;top:50px;z-index:1;}
.TabMenu{width:200px;height:700px;margin-left:320px;margin-top:55px;}
/* Position the buttons */
.TabMenu span{
display:inline-block;
height:40px;
width:40px;
margin:7px 7px;
position: relative;
}
/* Images are positioned at 0,0 inside the span */
.TabMenu span:after{
content: "";
display: block;
position: absolute;
top: 0;
left: 0;
height:100%; /* Or just 40px */
width:100%;
background-image: url(http://goodwinstudio.com/_dev/img/btns5.gif);
background-repeat:no-repeat;
}
.TabMenu span:hover:after{opacity:0.8;cursor:pointer;}
/* Shadow image has a slightly negative offset */
.TabMenu span::before{
width: 46px;
height:46px;
content: url(http://goodwinstudio.com/_dev/images/bgactive2.png);
position:absolute;
top:-6px;
left:-6px;
}
#sml_1:after{background-position:0px 0px;}
#sml_2:after{background-position:-40px 0px;}
#sml_3:after{background-position:-80px 0px;}
#sml_4:after{background-position:0px -40px;}
#sml_5:after{background-position:-40px -40px;}
#sml_6:after{background-position:-80px -40px;}
<div class="container"></div>
<div class="TabMenu">
<span id="sml_1"></span>
<span id="sml_2"></span>
<span id="sml_3"></span>
<span id="sml_4"></span>
<span id="sml_5"></span>
<span id="sml_6"></span>
</div>
<button>Toggle Black Dot</button>
关于css - 使用 css::before 将模糊的圆圈放在图像后面,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29324362/
我当前项目中的许多类都有几个只能从类本身内部调用的属性和方法。此外,根据类(class)的当前状态,它们可能会扰乱类(class)的工作。 目前,所有这些接口(interface)都在 .h 文件的主
我想使用ngbTabSet将nav-pills in card-header 和tab-content in card-body。但我不知道该怎么做。 这是我尝试实现的示例(使用 bootstrap.
我正在浏览文档以查找如何允许放置在停靠栏图标上。据我所知,建议您使用 LSItemContentTypes,因为 CFBundleTypeOSTypes 已弃用。但是,我无法让 LSItemConte
我正在尝试在书签中使用 jquery UI 作为 slider 。并且 jquery ui 要求在普通 jquery 文件之后包含该文件。 所以到目前为止我所尝试的只是将脚本附加到 header ,同
您好,我尝试了广泛的谷歌搜索,但似乎没有任何帮助。 这是我的场景: 公司 Logo 存储在外部域/网址(矩形)中。 带有谷歌地图的 Ionic 应用程序,将这些 Logo 作为标记放置在 map 上。
我今天在阅读我的一些 C# 代码时发现了这一行: if (ProgenyList.ItemContainerGenerator.Status != System.Windows.Controls.Pr
我刚遇到this question在 Go FAQ 中,它让我想起了困扰我一段时间的事情。不幸的是,我真的不明白答案是什么。 似乎几乎所有非 C 类语言都将类型放在变量名之后,如下所示: var :
这是有效的 HTML 吗? 最佳答案 作为元素可以包含 phrasing content ,以及属于该组,则有效。 从语义上(并且具有一些常识),如果唯一的内容是 , 不;如果它同时包含文本和图像
这是有效的 HTML 吗? 最佳答案 作为元素可以包含 phrasing content ,以及属于该组,则有效。 从语义上(并且具有一些常识),如果唯一的内容是 , 不;如果它同时包含文本和图像
我有两本 T.Parr 写的关于 ANTLR 的书,我到处都看到美元符号和符号的引用。它也对我有用: term : IDENT -> { new TokenNode($IDENT) }; 或更复杂的东
我在实现段控制时遇到了一些问题。因为我希望它是一个固定的标题,所以当我滚动时我总是可以看到它,我已经在 - (UIView *)tableView:(UITableView *)tableView v
我有一个 20x36px (10x18pt) 的箭头图像,当我选择一个 UIImageView 时,将它拖到我的 View Controller 上然后设置图像,它总是模糊的。我只在我的项目中包含 @
How can I put background image when I hover a link Insert Bg in this a when hov
我需要在我的 .container 中添加(最新的第一个)新分区,但在 .controls (按钮)之后。可能吗? 注意:添加新的分区来保存按钮下方的前置控件对我来说不是一个选择。 HTML 需要保持
我是一名优秀的程序员,十分优秀!