J'ai besoin d'afficher trois images de même taille (200 X 100) côte à côte (sans espace) en haut de l'écran. Ils doivent occuper toute la largeur de l'écran et conserver les proportions. Est-il possible d'accomplir cela en utilisant uniquement un fichier xml de mise en page, ou dois-je utiliser Java code?
La solution doit être indépendante de la résolution ... Quelqu'un peut-il publier une solution ou un lien pour ce problème (ou similaire)? Merci!
Je l'ai fait fonctionner! Mais comme je l'ai dit ci-dessus, vous devez créer votre propre classe. Mais c'est assez petit. Je l'ai créé à l'aide de la réponse de Bob Lee dans cet article: Android: Comment étirer une image à la largeur de l'écran tout en conservant les proportions?
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);
}
}
Maintenant, pour l'utiliser dans le 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" />
S'amuser!
=====================================
Trouvé une autre façon de faire la même chose uniquement en XML en utilisant Android: adjustViewBounds = "true". Voici un exemple:
<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>
Seule une mise à niveau mineure pour tenir compte de ce qui pourrait mal tourner: null Drawable ou 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);
}
}
Jake Wharton améliore la classe AspectRatioImageView, vous pouvez définir dominantMeasurement et aspectRatio via xml. Vous pouvez le trouver dans le lien ci-dessous.
Je ne connais pas les dispositions XML et l'API Android, mais le calcul est simple; trouvez la largeur de l'écran et divisez par trois. C'est la largeur de chaque image. Multipliez maintenant la largeur par le rapport hauteur/largeur de l'image d'origine. C'est la hauteur de chaque image.
int imageWidth = screenWidth / 3;
float ratio = originalImage.Height / (float)originalImage.Width;
int imageHeight = (int)(imageWidth * ratio);