当我的TextView
中的字符串长大并溢出时,我有一个问题,有时会隐藏另一个TextView
的文字或开始消失。
我希望它能像这样工作(我知道这看起来很像摆动FlowLayout
但不完全,因为它的对齐不固定,一个组件被留下而另一个组件被对齐):
-------------------------------------
|[TextView0] [TextView1]|
-------------------------------------
当文字增长时:
TextView0 grows: TextView1 grows:
------------------------------------- -------------------------------------
|[TextView0 TextView0 TextView0] | |[TextView0] |
| [TextView1]| | [TextView1 TextView1 TextView1]|
------------------------------------- -------------------------------------
我尝试了ReleativeLayout
和LinearLayout
,但从未让它发挥作用:
RelativeLayout
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="wrap_content" >
<TextView
android:id="@+id/TextView0"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentLeft="true"
android:text="TextView0" />
<TextView
android:id="@+id/TextView1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentRight="true"
android:text="TextView1" />
</RelativeLayout>
当文本开始重叠时,我尝试修复TextView0
为toLeftOf="TextView1"
。但在这种情况下,TextView0
消失了。
LinearLayout
:
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:orientation="horizontal" >
<TextView
android:id="@+id/TextView0"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="TextView0" />
<TextView
android:id="@+id/TextView1"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:gravity="right"
android:text="TextView1" />
</LinearLayout>
此处TextView
开始干扰,当TextView0
获得全宽TextView1
消失时(宽度趋于零)。
答案 0 :(得分:1)
Android-FlowLayout的最佳图书馆之一 它简单,易于使用且非常棒。
答案 1 :(得分:0)
简短的回答是“是” - 因为它只是软件,任何事情都可以做到:)。但是,我不认为你可以用任何标准布局来实现它。
所以我最好的选择是创建自己的View类,然后以任何你想要的方式布局。您可能想要阅读此内容(如果没有)作为起点:
http://developer.android.com/training/custom-views/create-view.html
答案 2 :(得分:0)
我尝试为此目的创建布局。
它就像我在原始问题中讨论一样,但如果你做得更好,可以随时更新答案!
public class KeyValueLayout extends ViewGroup {
public KeyValueLayout(Context context) {
super(context);
}
public KeyValueLayout(Context context, AttributeSet attributeSet) {
super(context, attributeSet);
}
public KeyValueLayout(Context context, AttributeSet attributeSet,
int defStyle) {
super(context, attributeSet, defStyle);
}
@Override
protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
int paddRight = getPaddingRight();
int paddLeft = getPaddingLeft();
int paddBottom = getPaddingBottom();
int paddWidth = paddRight + paddLeft;
int sizeWidth = MeasureSpec.getSize(widthMeasureSpec) - paddWidth;
int sizeHeight = MeasureSpec.getSize(heightMeasureSpec) - paddWidth;
int modeWidth = MeasureSpec.getMode(widthMeasureSpec);
int modeHeight = MeasureSpec.getMode(heightMeasureSpec);
int modeW = modeWidth == MeasureSpec.EXACTLY
? MeasureSpec.AT_MOST : modeWidth;
int modeH = modeHeight == MeasureSpec.EXACTLY
? MeasureSpec.AT_MOST : modeHeight;
// where the next view should be placed
int lineYPosition = 0;
for (int i = 0; i < getChildCount(); ) {
View key = getChildAt(i++);
key.measure(
MeasureSpec.makeMeasureSpec(sizeWidth, modeW),
MeasureSpec.makeMeasureSpec(sizeHeight, modeH)
);
LayoutParams keyLp = (LayoutParams) key.getLayoutParams();
keyLp.setPosition(paddLeft, lineYPosition);
if (i >= getChildCount())
break;
View val = getChildAt(i++);
val.measure(
MeasureSpec.makeMeasureSpec(sizeWidth, modeW),
MeasureSpec.makeMeasureSpec(sizeHeight, modeH)
);
LayoutParams valLp = (LayoutParams) val.getLayoutParams();
int valXPosition = paddLeft + sizeWidth - val.getMeasuredWidth();
// check if both fit on the same line
if (key.getMeasuredWidth() + val.getMeasuredWidth() <= sizeWidth) {
valLp.setPosition(valXPosition, lineYPosition);
lineYPosition += Math.max(key.getMeasuredHeight(),
val.getMeasuredHeight());
} else {
// not enough room, make some space
lineYPosition += key.getMeasuredHeight();
valLp.setPosition(valXPosition, lineYPosition);
lineYPosition += val.getMeasuredHeight();
}
}
int controlMaxLength = sizeWidth + paddRight;
int controlMaxThickness = lineYPosition + paddBottom;
int resolvedWidth = resolveSize(controlMaxLength, widthMeasureSpec);
int resolvedHeight =resolveSize(controlMaxThickness,heightMeasureSpec);
this.setMeasuredDimension(resolvedWidth, resolvedHeight);
}
@Override
protected void onLayout(boolean changed, int l, int t, int r, int b) {
final int count = getChildCount();
for (int i = 0; i < count; i++) {
View child = getChildAt(i);
LayoutParams lp = (LayoutParams) child.getLayoutParams();
child.layout(lp.x, lp.y,
lp.x + child.getMeasuredWidth(),
lp.y + child.getMeasuredHeight());
}
}
@Override
protected boolean checkLayoutParams(ViewGroup.LayoutParams p) {
return p instanceof LayoutParams;
}
@Override
protected LayoutParams generateDefaultLayoutParams() {
return new LayoutParams(LayoutParams.WRAP_CONTENT,
LayoutParams.WRAP_CONTENT);
}
@Override
public LayoutParams generateLayoutParams(AttributeSet attributeSet) {
return new LayoutParams(getContext(), attributeSet);
}
@Override
protected LayoutParams generateLayoutParams(ViewGroup.LayoutParams p) {
return new LayoutParams(p);
}
public static class LayoutParams extends ViewGroup.LayoutParams {
private int x;
private int y;
public LayoutParams(Context context, AttributeSet attributeSet) {
super(context, attributeSet);
}
public LayoutParams(int width, int height) {
super(width, height);
}
public LayoutParams(ViewGroup.LayoutParams layoutParams) {
super(layoutParams);
}
public void setPosition(int x, int y) {
this.x = x;
this.y = y;
}
}
}
使用示例:
<nu.wen.android.layout.KeyValueLayout
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:layout_marginTop="10dp" >
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="@string/example_string_long"
android:textStyle="bold" />
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="@string/example_string_short" />
</nu.wen.android.layout.KeyValueLayout>