Мне нужно отображать три изображения одного размера (200 X 100) бок о бок (без пробелов) в верхней части экрана. Они должны занимать всю ширину экрана и сохранять соотношение сторон.
Можно ли это сделать, используя только XML файл макета, или мне нужно использовать java-код?
Решение может быть независимым от разрешения... Может ли кто-нибудь опубликовать решение или ссылку для этой (или подобной) проблемы? Спасибо!
Как растянуть три изображения на экране, сохраняя соотношение сторон?
Ответ 1
Сработало! Но, как я сказал выше, вам нужно создать свой собственный класс. Но он довольно маленький. Я создал его с помощью этого ответа Боба в этом сообщении: Android: как растянуть изображение до ширины экрана при сохранении пропорций?
package com.yourpackage.widgets;
import android.content.Context;
import android.util.AttributeSet;
import android.widget.ImageView;
public class AspectRatioImageView extends ImageView {
public AspectRatioImageView(Context context) {
super(context);
}
public AspectRatioImageView(Context context, AttributeSet attrs) {
super(context, attrs);
}
public AspectRatioImageView(Context context, AttributeSet attrs, int defStyle) {
super(context, attrs, defStyle);
}
@Override
protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
int width = MeasureSpec.getSize(widthMeasureSpec);
int height = width * getDrawable().getIntrinsicHeight() / getDrawable().getIntrinsicWidth();
setMeasuredDimension(width, height);
}
}
Теперь использовать его в XML:
<com.yourpackage.widgets.AspectRatioImageView
android:id="@+id/image"
android:src="@drawable/yourdrawable"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_alignParentTop="true"
android:layout_centerHorizontal="true"
android:adjustViewBounds="true" />
Удачи!
=====================================
Нашел другой способ сделать то же самое только в XML с помощью android: adjustViewBounds = "true". Вот пример:
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content" >
<ImageView
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_weight="1"
android:adjustViewBounds="true"
android:src="@drawable/image1" />
<ImageView
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_weight="1"
android:adjustViewBounds="true"
android:src="@drawable/image2" />
<ImageView
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_weight="1"
android:adjustViewBounds="true"
android:src="@drawable/image2" />
</LinearLayout>
Ответ 2
Только незначительное обновление, чтобы принять во внимание то, что может пойти не так: null Drawable или 0 width.
package com.yourpackage.yourapp;
import android.content.Context;
import android.graphics.drawable.Drawable;
import android.util.AttributeSet;
import android.widget.ImageView;
public class AspectRatioImageView extends ImageView {
public AspectRatioImageView(Context context)
{
super(context);
}
public AspectRatioImageView(Context context, AttributeSet attrs)
{
super(context, attrs);
}
public AspectRatioImageView(Context context, AttributeSet attrs,
int defStyle)
{
super(context, attrs, defStyle);
}
@Override
protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec)
{
Drawable drawable = getDrawable();
if (drawable != null)
{
int width = MeasureSpec.getSize(widthMeasureSpec);
int diw = drawable.getIntrinsicWidth();
if (diw > 0)
{
int height = width * drawable.getIntrinsicHeight() / diw;
setMeasuredDimension(width, height);
}
else
super.onMeasure(widthMeasureSpec, heightMeasureSpec);
}
else
super.onMeasure(widthMeasureSpec, heightMeasureSpec);
}
}
Ответ 3
Jake Wharton улучшает класс AspectRatioImageView, вы можете установить dominantMeasurement и aspectRatio через xml. Вы можете найти его по ссылке ниже.
Ответ 4
Я не знаю о XML-макетах и API андроида, но математика проста; найдите ширину экрана и разделите на три. Это ширина каждого изображения. Теперь умножьте ширину на исходное соотношение изображений от высоты до ширины. Это высота каждого изображения.
int imageWidth = screenWidth / 3;
float ratio = originalImage.Height / (float)originalImage.Width;
int imageHeight = (int)(imageWidth * ratio);