2012-03-17 10 views
8

Una vista de texto que se expande a varias líneas parece expandirse automáticamente para ajustarse a su ancho máximo posible. ¿Cómo puedo evitar que eso suceda?Evite que una vista de texto multilínea se expanda innecesariamente a su ancho máximo

Aquí es un ejemplo de diseño (test.xml)

<?xml version="1.0" encoding="utf-8"?> 
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" 
android:layout_width="match_parent" 
android:layout_height="match_parent" 
android:background="@color/white"> 
<TextView 
android:background="@color/green" 
android:layout_alignParentRight="true" 
android:id="@+id/foo" 
android:layout_width="wrap_content" 
android:layout_height="wrap_content" 
android:gravity="right" 
android:text="This is the message a much shorter message" 
android:textAppearance="?android:attr/textAppearanceMedium" 
android:textColor="@color/black" /> 
</RelativeLayout> 

TextView shown with maximum width

Si añado un margen a la izquierda, se contrae correctamente el ancho de la Vista de Texto (sin reformatear el contenido), pero el tamaño del margen debería calcularse dado el contenido de TextView.

<?xml version="1.0" encoding="utf-8"?> 
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" 
android:layout_width="match_parent" 
android:layout_height="match_parent" 
android:background="@color/white"> 
<TextView 
android:layout_marginLeft="32dp" 
android:background="@color/green" 
android:layout_alignParentRight="true" 
android:id="@+id/foo" 
android:layout_width="wrap_content" 
android:layout_height="wrap_content" 
android:gravity="right" 
android:text="This is the message a much shorter message" 
android:textAppearance="?android:attr/textAppearanceMedium" 
android:textColor="@color/black" /> 
</RelativeLayout> 

TextView show with margin

Respuesta

0

uso android:padding="32dp" Es ayudarle a tener el relleno, si usted quiere tener el relleno del uso izquierda android:paddingLeft="32dp"

+1

El problema no está en el relleno. Quiero que el TextView realmente envuelva el contenido, y en cambio cuando se trata de líneas múltiples se expande al ancho de la vista principal. –

7

Es posible utilizar Vista de Texto personalizado con onMeasure método reemplazado(), donde se calcula la anchura:

public class WrapWidthTextView extends TextView { 

... 

@Override 
protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) { 
    super.onMeasure(widthMeasureSpec, heightMeasureSpec); 

    Layout layout = getLayout(); 
    if (layout != null) { 
     int width = (int)FloatMath.ceil(getMaxLineWidth(layout)) 
       + getCompoundPaddingLeft() + getCompoundPaddingRight(); 
     int height = getMeasuredHeight();    
     setMeasuredDimension(width, height); 
    } 
} 

private float getMaxLineWidth(Layout layout) { 
    float max_width = 0.0f; 
    int lines = layout.getLineCount(); 
    for (int i = 0; i < lines; i++) { 
     if (layout.getLineWidth(i) > max_width) { 
      max_width = layout.getLineWidth(i); 
     } 
    } 
    return max_width; 
} 

}

+0

+1000 :) ¡Gracias! –

0

He intentado la solución de Vitaliy Polchuk y funciona bien. Y también quiero añadir pequeña corrección:

... 
@Override 
protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) { 
    Layout layout = getLayout(); 
    if (layout != null) { 
     int width = (int) FloatMath.ceil(getMaxLineWidth(layout)) 
       + getCompoundPaddingLeft() + getCompoundPaddingRight(); 
     widthMeasureSpec = MeasureSpec.makeMeasureSpec(width, MeasureSpec.EXACTLY); 
    } 
    super.onMeasure(widthMeasureSpec, heightMeasureSpec); 
    // get already measured dimensions 
    int width = getMeasuredWidth(); 
    int height = getMeasuredHeight(); 
    setMeasuredDimension(width, height); 
} 
... 
0

Si desea utilizar una sugerencia de @Vitaliy Polchuk (una respuesta superior), por lo que volver a escribir o ver su respuesta a Why is wrap content in multiple line TextView filling parent?:

public class WrapWidthTextView extends AppCompatTextView { 
    public WrapWidthTextView(Context context) { 
     super(context); 
    } 

    public WrapWidthTextView(Context context, @Nullable AttributeSet attrs) { 
     super(context, attrs); 
    } 

    public WrapWidthTextView(Context context, @Nullable AttributeSet attrs, int defStyleAttr) { 
     super(context, attrs, defStyleAttr); 
    } 

    @Override 
    protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) { 
     super.onMeasure(widthMeasureSpec, heightMeasureSpec); 

     Layout layout = getLayout(); 
     if (layout != null) { 
      int width = (int) Math.ceil(getMaxLineWidth(layout)) 
        + getCompoundPaddingLeft() + getCompoundPaddingRight(); 
      int height = getMeasuredHeight(); 
      setMeasuredDimension(width, height); 
     } 
    } 

    private float getMaxLineWidth(Layout layout) { 
     float max_width = 0.0f; 
     int lines = layout.getLineCount(); 
     for (int i = 0; i < lines; i++) { 
      if (layout.getLineWidth(i) > max_width) { 
       max_width = layout.getLineWidth(i); 
      } 
     } 
     return max_width; 
    } 
} 

Reconstruya un proyecto cuando inserta esta clase en XML. De lo contrario, no encontrará esta clase.

Cuestiones relacionadas