android - 如何动态更改 addOnScrollChangedListener 中 ImageView 的大小?
问题描述
我在通过 addOnScrollChangedListener 更改图像大小时遇到问题。我有 setScaleType(ImageView.ScaleType.FIT_XY) 。我的代码:
final int[] last_scrollX = {width};
hv.getViewTreeObserver().addOnScrollChangedListener(new ViewTreeObserver.OnScrollChangedListener() {
@Override
public void onScrollChanged() {
//int scrollY = hv.getScrollY(); // For ScrollView
int scrollX = hv.getScrollX(); // For HorizontalScrollView
if(scrollX>last_scrollX[0]) {
IV_4.getLayoutParams().width = (int) (IV_4.getLayoutParams().width / 1.01);
IV_4.getLayoutParams().height = IV_4.getLayoutParams().width*2;
IV_2.getLayoutParams().width = (int) (IV_2.getLayoutParams().width * 1.01);
IV_2.getLayoutParams().height = IV_2.getLayoutParams().width*2;
} else if (scrollX<last_scrollX[0]) {
IV_4.getLayoutParams().width = (int) (IV_4.getLayoutParams().width * 1.01);
IV_4.getLayoutParams().height = IV_4.getLayoutParams().width*2;
IV_2.getLayoutParams().width = (int) (IV_2.getLayoutParams().width / 1.01);
IV_2.getLayoutParams().height = IV_2.getLayoutParams().width*2;
}
last_scrollX[0]=scrollX;
}
});
}
当 HorizontallScrollView hv 来回滚动时,我想减小和增加它们的大小,但是当我滚动它们时,它们不会改变它们的大小。当我最小化应用程序然后再次最大化它或在活动中集中编辑文本时,图像会改变它们的大小(非常大或非常小)。编辑:忘记提及这些图像位于滚动视图后面的 ConstraintLayout 中。所以它们不在滚动视图中,因此不在线性布局中。这就是我现在得到的:https ://image.ibb.co/naJiqT/ezgif_5_e9c1de6230.gifIV_4 是左图,IV_2 是右图,我希望它们在滚动时更改大小,但现在它们仅在我最小化/最大化应用程序或聚焦编辑文本时才会更改。EDIT2:我可以看到如何使用页面转换器完成迄今为止所做的事情,我从未使用过它,但据我所知,很难使图像缩放 + 和 - 并改变它们变形的同时位置。我需要了解为什么它们的大小在滚动时不会改变,但是当我最小化/最大化应用程序或聚焦编辑文本时,onscrollchange 代码会显示它对图像的更改。
解决方案
您可以使用 ViewPager 来获得与附加到 ViewPager 的自定义页面转换器相同的效果
public class CustPagerTransformer implements ViewPager.PageTransformer {
private int maxTranslateOffsetX;
private ViewPager viewPager;
public CustPagerTransformer(Context context) {
this.maxTranslateOffsetX = dp2px(context, 180);
}
public void transformPage(View view, float position) {
if (viewPager == null) {
viewPager = (ViewPager) view.getParent();
}
int leftInScreen = view.getLeft() - viewPager.getScrollX();
int centerXInViewPager = leftInScreen + view.getMeasuredWidth() / 2;
int offsetX = centerXInViewPager - viewPager.getMeasuredWidth() / 2;
float offsetRate = (float) offsetX * 0.38f / viewPager.getMeasuredWidth();
float scaleFactor = 1 - Math.abs(offsetRate);
if (scaleFactor > 0) {
view.setScaleX(scaleFactor);
view.setScaleY(scaleFactor);
view.setTranslationX(-maxTranslateOffsetX * offsetRate);
}
}
/**
* dp和像素转换
*/
private int dp2px(Context context, float dipValue) {
float m = context.getResources().getDisplayMetrics().density;
return (int) (dipValue * m + 0.5f);
}}
将其附加到 viewpager,如下所示
viewPager.setPageTransformer(false, new CustPagerTransformer(HomeActivity.this));
推荐阅读
- c# - 在资源字典中存储标记
- google-api - 如何从 google api 访问所有用户设置?
- gremlin - 如何使用 gremlin QL 递归地获取所有子顶点及其边缘(两者的属性)?
- android - 为什么我的图像变得模糊?带有约束布局的动画
- google-cloud-platform - GCP Nat 超时
- python - 大型数据集的 for-loop 替代方案以提高计算速度
- batch-file - 无法获取与当前 Java 虚拟机关联的唯一 Console 对象
- flutter - Flutter - 如何将“中间光标”添加到 SingleChildScrollView?
- kubernetes-helm - 仅在不存在时安装 helm 子图资源
- visual-studio-code - 如何在vscode中保存整个Webview