Muh*_*nov 7 android aspect-ratio android-constraintlayout
我在显示没有centerCrop的风景图像时遇到问题.我尝试过PercentFramelayout,并以编程方式设置宽高比,如下所示:
laParams.percentLayoutInfo.aspectRatio = img.width.toFloat() / img.height.toFloat()
Run Code Online (Sandbox Code Playgroud)
结果还可以 - 应用程序显示没有centerCrop的所有风景图像:
但有时我会得到错误的宽高比:
我试过android:adjustViewBounds ="true"但它对我没有帮助.我用过ConstraintLayout,用XML设置宽高比如下:
<?xml version="1.0" encoding="utf-8"?>
<android.support.constraint.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:id="@+id/container"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="@color/white"
>
<android.support.v7.widget.AppCompatImageView xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:id="@+id/photo"
android:layout_width="0dp"
android:layout_height="0dp"
app:layout_constraintDimensionRatio="h,16:9"
app:layout_constraintHorizontal_chainStyle="spread"
app:layout_constraintLeft_toLeftOf="parent"
app:layout_constraintRight_toRightOf="parent"
app:layout_constraintTop_toTopOf="parent"
/>
</android.support.constraint.ConstraintLayout>
Run Code Online (Sandbox Code Playgroud)
我得到了很好的结果,但我加载了不同大小的图像.图像应该没有CenterCrop和FitXY.我没有找到关于设置宽高比的任何好答案,因为Constraintlayout
我想显示像instagram或vk这样的图像.
Jul*_*ius 20
像往常一样,迟到的答案,但这可能对某人有用.
您可以通过执行以下操作以编程方式设置ratio属性:
ConstraintSet set = new ConstraintSet();
set.clone(mLayout);
set.setDimensionRatio(mView.getId(), "16:9");
set.applyTo(mLayout);
Run Code Online (Sandbox Code Playgroud)
我上面做的是获取布局的现有ConstraintSet并在将ConstraintSet重新应用到ConstraintLayout(mLayout)之前以编程方式添加比率约束.
您应该使用findViewById()方法获取ConstraintLayout(mLayout)(并在.xml中手动将id属性添加到ConstraintLayout).
tej*_*hah 10
你还可以检查下面的代码
val layoutParams = imageView.layoutParams as ConstraintLayout.LayoutParams
layoutParams.dimensionRatio = "H,2:1"
imageView.layoutParams = layoutParams
Run Code Online (Sandbox Code Playgroud)
只是更改layoutParams也可以
(view.layoutParams as ConstraintLayout.LayoutParams).dimensionRatio = "16:9"
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
5588 次 |
| 最近记录: |