- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我有一个元素,用户可以在其中指定一个任意图像,稍后用作元素的背景图像。用户必须能够将图像定位在要应用图像的宿主元素中,以确保图像中需要显示的部分实际上是可见部分。
SitePoint notes the following关于 CSS background-position
属性的行为:
Note that when the
background-position
is defined with a percentage value, that position refers to both the element itself and the corresponding point on thebackground-image
. For example, abackground-image
with background-position values of50% 50%
will place the point of the image that’s located at 50% of the image’s width and 50% of the image’s height at a corresponding position within the element that contains the image. In the above case, this causes the image to be perfectly centered. This is an important point to grasp—usingbackground-position
isn’t the same as placing an element with absolute position using percentages where the top-left corner of the element is placed at the position specified.
假设您有两个 HTML 元素。第一个是一个大元素,表示稍后用作背景位置的图像。第二个是位于第一个元素之上的较小元素,代表将来要应用背景图像的元素。
+-----------------------+ <-- Y1
| Image Placeholder |
| |
| +-----------------------+ <-- y1
| | Container Placeholder |
| +-----------------------+ <-- y2
| |
| |
| |
| |
| |
| |
+-----------------------+ <-- Y2
给定每个元素的顶部和底部的 y 坐标,如何计算正确的百分比以保持图像的正确部分在应用了背景图像的最终元素中可见?
最佳答案
让我们采用原始可视化,为我们正在寻找的百分比位置的两个点添加变量:
+-----------------------+ <-- Y1
| Image |
| |
| +-----------------------+ <-- y1
Y3 -->| y3 -->| Container |
| +-----------------------+ <-- y2
| |
| |
| |
| |
| |
| |
+-----------------------+ <-- Y2
根据定义,这两点(图像上的一个点和容器上的一个点)必须位于同一位置。这两个百分比必须相等。因此:
下一步似乎是定义这两个目标点。假设其左上角位于坐标 [0,0]
处,这证明对于两个元素中较大的一个更容易:
其中 p
表示我们正在寻求的百分比。
这个等式看起来几乎适用于较小的元素,除了这个元素不是从点 [0,0]
开始。相反,它从点 [x1,y1]
开始。 (我们可以安全地忽略它的 x 原点,因为我们只关心 y 百分比。)
校正此偏移量可得出以下等式:
代入我们原来的等式,我们得到:
现在剩下的就是求解p
;完成后,我们得到了这个最终等式:
Here是a jsfiddle example这个等式的作用。上下拖动黄色元素可以看到动态计算的百分比(输出在图像下方)。红色刻度线是相同百分比的视觉指示器。
关于css - 从两个重叠的 HTML 元素逆向工程 CSS `background-position`,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35493319/
我刚开始使用 html5 和 css,我对使用 css position 有点困惑。 我可以从堆栈溢出中找到这些链接, Difference between relative and absolute
我想知道是否有一种方法可以获得相对定位的元素的“绝对位置”。我想不出任何方法,但也许有人想出了一个方法...... 最佳答案 我不确定“绝对位置”是什么意思,但您可以使用 el.getBounding
基本上我的 HTML(使用 Bootstrap 类)中有一个页面,其中包含使用 thumbnail 和 caption 类展示的产品。在产品图片上方有一个 ON SELL(圆形红色标签)。我给这个红色
当我使用 BaseAdapter 的 ListView 离开屏幕时,每一行不再保持连续的位置。除了这个我不知道还能怎么解释。 如果我的 BA/LV 在屏幕上显示 4 个项目,并且我添加了一个显示每一行
此 HTML 无法在 IE8 中正确呈现。它适用于 Firefox、Opera、IE7、IE9 和 IE10。 (当然,它在 IE6 中也不起作用,因为它涉及固定位置的元素。) 实际上它在 Chrom
我正在使用Position Absolute的表单验证引擎。 我有一个特定的验证案例,希望可以为我解决。我需要能够根据另一个字段的值来使一个字段成为必需。 例如: If country.dropdow
我看过很多帖子,人们希望将相机位置调整到屏幕位置。我的问题是如何做相反的事情。 我目前想要实现的是将“门”位置设置为屏幕的百分比,此计算已准备就绪,并且我确实有最终屏幕的 X、Y (px) 位置。相机
谁能解释一下使用 position:relative、position:absolute 和 float 对正常文档流及其子项的影响的区别? 例如当我有三个元素 A、B、C 时,其中 A 是包含 B
我有以下代码: .tabs{ position: fixed; top:110px; left:0px; width:40px; z-inde
我不知道如何表达这个问题。 所以这是一个例子。 图层上的动画滑入 View ,然后稍微弹回。 十分简单。 位置关键帧看起来像这样: 关键帧 0:(-100,200) 关键帧 10:(100,200)
我是 XSLT 的新手,我正在使用 w3schools 的“自己尝试”页面进行一些测试。我正在使用以下演示: http://www.w3schools.com/xsl/tryxslt.asp?xmlf
我试图让一个对象 1 (SKSpriteNode) 在某个高度(y 坐标)处创建另一个对象 (object2)。我已经得到了我需要的所有代码,除了我不知道如何正确编写: object1.positio
.special p { display:none; } .special:hover p { display:block; } Things
当将一个绝对定位元素放置在一个位置固定包装器中时,在一个位置相对包装器中,绝对元素位置不应该相对于相对 parent 而不是固定 parent ? Content
我有一个 iframe,它在应用 css 后显示谷歌地图 position: relative; top: 48px; left: -233px; 但是当我向下滚动时,它刚好出现在显示 khaleej
我在一个网站上工作,有一个带有 position:relative 的父元素,它有一个带有 position:absolute 的子元素。令我感到奇怪的是,对于我提到的位置,子元素似乎仍然可以识别它们
我有一个 main 元素,我已将其设置为 position: relative。这包含两个 div,然后我在其上应用 position: absolute。然后,这会导致夹在 main 元素中间的页眉
HTML 代码由一个 div 组成,它具有两种类型的类:“隐藏”和“保留”。 Lorem ipsum dolor sit amet, consectetur adipis
我必须开发一个生成表格(有点……)的软件,并且必须提供对元素位置的完全控制。 到目前为止,我们有这样的构造: 还有一些javascript代码来放置#a , #b和 #c #co
我尝试将 z-index 设置为 body 下的某些位置为 fixed 的元素 示例如下: HTML menu content ....
我是一名优秀的程序员,十分优秀!