- 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/
我的 FAB 将显示在 android studio 的设计窗口中,但在我实际运行应用程序时不会显示。 此外,我有一个 ListView 项目,我指定它应该位于工具栏下方,但当我运行该应用程序时,它部
我的Nginx服务器位于haproxy之后,后者位于Varnish之后: 请求网页=> Varnish => HaProxy => Nginx 我的问题是我无法检索客户端的IP地址,在Nginx日志中
我正在尝试在用户点击的图像上显示一些上下文信息。 我正在为此使用 vtkTextActor。我正在使用 python 绑定(bind)。 问题是因为它在图像上很难阅读,所以我想在它后面画一些背景。 (
我创建了一个 flutter 小部件,它由几个组成应用栏和选项卡的条子组成,在其下方,我有 TabBarView。 1) 选项卡和主体 ScrollView 之间有过多的填充,但我不确定是什么元素导致
当我在 Xcode 4.3.3 上运行我的 cocoa 应用程序时。使用 Lion 10.7.4。应用程序启动并出现在 Xcode 后面。前面几次出现,不知道发生了什么。有人遇到过这样的问题吗?我的主
我需要将一些文本相对于“dropzone”(div)水平和垂直居中放置。它适用于以下解决方案:Inject a text above a div centered horizontally and v
我正在尝试在列表上使用匹配的几何效果,并且至少对于详细 View 的动画来说,它的工作方式与预期的一样。问题是从详细 View 返回列表单元格的动画似乎在列表后面。 我怎样才能让它正常工作,以便详细
我正在尝试在列表上使用匹配的几何效果,并且至少对于详细 View 的动画来说,它的工作方式与预期的一样。问题是从详细 View 返回列表单元格的动画似乎在列表后面。 我怎样才能让它正常工作,以便详细
我对此有点挣扎。在对 Google 进行研究后,我创建了以下计时器例程,该例程在调用时效果良好 // play move method public static void playMove() {
我正在编写一款Android游戏,用户可以购买在购买后动态创建的建筑物。创建它们后,用户可以将它们拖放到任何想要的地方,只要它们在地面上即可。我将天空和地面作为两种不同的框架布局,但天空占据顶部的 2
我有一个包装 div,在那个 div 里面有一些带有下拉按钮的按钮,包装应该有一个最大高度和一个自动滚动。 问题是如果我点击一个按钮,现在下拉菜单总是放在包装器后面,有没有办法让下拉菜单放在包装器的顶
我在 Bootstrap 3 中有一个网站 http://213.239.217.181/carboot/ 我可能会被否决,因为人们会说你试过什么或向我们展示你试过的代码 但我已经为这个问题苦苦挣扎了
我似乎无法解决这个问题,我将标签栏高度从 viewWillLayoutSubviews() 调整为 60,但覆盖 View 似乎不承认调整后的高度并效仿. 我发现的其他类似问题实际上并不相似(请参见此
我在相对布局中有两个线性布局。每个线性布局中有三张图片。从而形成一个图片网格,其中三张图片水平放置在第一个线性布局中,三张在上面的第二个中。如下所示 我的网格 xml 代码是:
我一直试图在我的页面上获取多个背景图片,但我无法获取超过 2 个,所以我开始考虑我可以使用 div 代替。但是当我使用 div 时,我在屏幕的顶部和两侧留下了大约 5 个白色像素,直到我将位置更改为绝
我有一些关于 CSS 的问题。您可以查看以下链接: http://lookdemo.biz/webs/chirag/mickes_figurer/ 在那里,您会在文本“NYFÖDDA FIGURER”
我有一个问题,我有一个绝对定位的 div,它充当背景图像顶部的颜色叠加层。 我遇到的问题是这个绝对定位的 div 之后的所有内容都放在它后面而不是在它上面。我不太明白发生了什么事。我知道它必须简单。
我知道这是一个热门话题,但我浏览了很多论坛,但没有一个修复对我有用。我有一个下拉菜单,隐藏在我正在显示的 pdf 后面。我尝试将 pdf 设置为嵌入并将其设置为 iframe。我尝试更改 css 中的
我不确定我是否在这里遗漏了什么,但似乎我无法将图像映射放在其他所有内容之上(就 z-index 而言)。我尝试改变 HTML 元素定义的顺序,我尝试使用 CSS 来定义适当的 z-index 值,但这
我有一个使用来自 slideful.com 的 iframe 的幻灯片。 slideful 的幻灯片使用 jquery。将幻灯片放在主页上后,我在导航中添加了一个下拉菜单,它位于“slideful.c
我是一名优秀的程序员,十分优秀!