- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
所以我遇到的实际问题是我想要固定的背景图像效果,同时保持背景图像足够宽以填充容器。不幸的是,CSS 方式使用 background-attachment:fixed;
只能相对于视口(viewport)定位图像。这会在宽高比与背景图像截然不同的屏幕尺寸上产生问题,导致背景图像(即人的图片)出现不必要的剪裁。
我目前达到的解决方案是使用background-size: contains
来防止在模拟background-attachment:fixed
时在所有屏幕尺寸上剪切图像使用 JavaScript 通过在滚动时对 background-position-y
进行动画处理。问题是,如果我单击一个按钮,导致页面向下滚动 scrollTop
动画,则图像的 background-position-y
设置会不稳定。
知道如何防止动画中出现这种抖动吗?
// Banner scroll function
var scrollTop = $(window).scrollTop();
var banner = $('.hero-banner').css('background-position-y',scrollTop+'px');
var debounced_fixBG = function(){
var newScrollTop = $(window).scrollTop();
banner.css('background-position-y',newScrollTop+'px');
scrollTop = newScrollTop;
};
$(window).scroll(debounced_fixBG);
$('.scroll-down').on('click',function(){
$('html,body').animate({
easing: 'swing',
scrollTop: $('#anchor').offset().top
},2000);
});
.hero-banner {
background-image: url('http://londonprogressivejournal.com/site_images/741.jpg');
height: 383px;
background-repeat: no-repeat;
background-attachment: contain;
background-position-y: top;
}
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.1.1/jquery.min.js"></script>
<button class="scroll-down">
Scroll Down
</button>
<div class="hero-banner">
</div>
<br>
<br>
<br>
<br>
<br>
<a id="anchor">Anchor</a>
最佳答案
发布评论中的答案:
您可以同时使用 background-attachment:fixed;
和 background-size:contain;
并通过使用 background-position 偏移图像来避免顶部剪切-y:[顶部元素的高度];
.
关于javascript - 背景位置 y 的断断续续的 JavaScript 动画,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39989464/
我将简要介绍一下我的应用程序的所有元素: 我有一个将音频记录到 AVAudioPCMBuffer 的应用程序。然后将该缓冲区转换为 NSData,然后转换为 [UInt8]。然后通过 OutputSt
我正在用 Java 制作一个非常简单的乒乓球游戏,并且我正在使用 KeyListener 进行此操作。我想要它,所以当用户按下键盘上的向右或向左键时,乒乓 block 会朝那个方向移动。这是一个足够简
我正在用 Java 制作一个非常简单的乒乓球游戏,并且我正在使用 KeyListener 进行此操作。我想要它,所以当用户按下键盘上的向右或向左键时,乒乓 block 会朝那个方向移动。这是一个足够简
所以我一直遇到动画问题,尤其是当两个动画同时发生或在 Activity 加载时发生时。我知道这可能是资源问题,并且主线程中发生了很多事情,导致动画卡顿。 我发现了一些有趣的建议: 1.线程(Threa
我推一个ViewController其中包含的 View 不多,UIScrollView其中包含 10 个 View ,我有一个单例 ViewController并一次次推,不释放和再次分配ViewC
矩形应该向下移动,先向左然后向右。但出于某种原因,他们只是有点“跳跃”。谁能告诉我为什么? .imgbox { position: relative; float:left;
我的动画有问题。我正在写一个由标题、正文(对话框所在的位置)和输入字段组成的聊天。它的位置是这样的: .chatWindowContainer { display: flex; fle
我有一个项目正在渲染视频播放并对其应用 CIFilters。我知道我可以使用视频合成来获取带滤镜的视频,但问题是滤镜需要可滑动(预览下一个滤镜,因此我们对第一个 ImageView 使用 mask ,
我正在处理过渡,当过渡应用于不同函数中的选择时,我注意到有些卡顿和闪烁。但是,如果转换与方法链一起应用,它会完全按照规定工作。 下面是简单移动一些文本的小例子(Fiddle)。在过渡开始之前,最左边的
我的适配器正确地将图像应用到 RecyclerView 并正确滚动……直到我添加大量项目。然后它变得相当不稳定,我知道这是我的方法的问题。请看下面的代码: class FragmentMenuView
我试图在用户提交表单后滚动到页面底部。但是,当我执行以下代码时,浏览器会滚动到页面底部,但不允许我在没有锁定/关闭/抖动的情况下向上滚动(通过鼠标滚轮、滚动条或箭头键)。 var scrollToBo
问题 我正在尝试让 Canvas 上的图像从左向右平滑移动。它在 Chrome/Safari 上还不错(仍然有点卡顿),但在多台机器上的 Firefox 中有明显的卡顿(在 Windows 和 Mac
我无法在 SceneKit 中获得平滑的阴影。您将在下面找到将灯光和图片添加到我的场景的代码。我圈出了像素化的区域。 即使是 SceneKit 提供的基本几何图形也无法正确着色。 有谁知道我该如何解决
我正在制作一个简单的应用程序,允许用户每天写一两句话来描述他们的一天。 我有一个 UICollectionView 将每一天显示为一个单元格。在该单元格中,有一个 UITextView,用户可以在其中
我在使用 UITableView 时遇到了这个问题,tableView 的 cells 高度不同,自动布局约束设置不当。当您向下滚动到 tableView 的底部并加载更多数据(无论使用 reload
我正在尝试创建一个包含一堆 block 的页面(通常包含可以通过单击框展开的“溢出:隐藏”文本)。但是,当我单击该框以调整其高度(以显示所有文本)时,我还想通过使用 ScrollTop 使该框成为焦点
我的程序绘制了在窗口上移动的圆圈。我想我一定是遗漏了一些基本的 gtk/cairo 概念,因为对于我正在做的事情来说,它似乎运行得太慢/断断续续。有任何想法吗?感谢您的帮助! #!/usr/bin/p
目前我有一个 UITableView,里面有一个可以调整大小的 UITextView。该单元格正在使用 beginUpdates/endUpdates 自动调整大小,但是当它这样做时,表格 View
我是一名优秀的程序员,十分优秀!