gpt4 book ai didi

android - 如何修复TextView在旋转时向左和向右移动的问题?

转载 作者:太空狗 更新时间:2023-10-29 16:35:40 25 4
gpt4 key购买 nike

我想让 TextView 与窗口屏幕的左右边缘对齐。预期结果将如下所示

expected result

但实际结果是这样的

actual result

这是我的 XML...

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/cameraContainer"
android:layout_width="match_parent"
android:layout_height="match_parent">

<FrameLayout
android:id="@+id/cameraPreview"
android:layout_width="match_parent"
android:layout_height="match_parent" />


<TextView
android:id="@+id/text1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentTop="true"
android:layout_centerHorizontal="true"
android:layout_centerVertical="true"
android:background="@color/grey_700"
android:text="TEST TEXT TEST TEXT"
android:textColor="@color/white"
android:textSize="35sp" />

<TextView
android:id="@+id/text2"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentBottom="true"
android:layout_centerHorizontal="true"
android:layout_centerVertical="true"
android:background="@color/grey_700"
android:text="TEST TEXT TEST TEXT"
android:textColor="@color/white"
android:textSize="35sp"
/>


<TextView
android:id="@+id/text3"

android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:background="@color/grey_700"
android:rotation="270"
android:text="TEST TEXT TEST TEXT"
android:textColor="@color/white"
android:textSize="35sp"
android:layout_alignBottom="@+id/text4"
android:layout_alignParentStart="true"
/>

<TextView
android:id="@+id/text4"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:background="@color/grey_700"
android:rotation="90"
android:text="TEST TEXT TEST TEXT"
android:textColor="@color/white"
android:textSize="35sp"
android:layout_centerVertical="true"
android:layout_alignParentEnd="true"
/>
</RelativeLayout>

似乎当我旋转textview时,只有我旋转的textview会移动到最左边和最右边。

您是否有任何想法如何使左右对齐的 2 个 TextView 达到预期结果?

谢谢!

最佳答案

我在 this answer 中找到了一个自定义的垂直 TextView您可以使用和保留背景:

<?xml version="1.0" encoding="utf-8"?>
<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/cameraContainer"
android:layout_width="match_parent"
android:layout_height="match_parent">
<FrameLayout
android:id="@+id/cameraPreview"
android:layout_width="match_parent"
android:layout_height="match_parent"/>
<TextView
android:id="@+id/text1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:gravity="center"
android:background="@color/grey_700"
android:text="TEST TEXT TEST TEXT"
android:textColor="@color/white"
android:textSize="35sp"/>
<TextView
android:id="@+id/text2"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:gravity="center"
android:layout_gravity="bottom"
android:background="@color/grey_700"
android:text="TEST TEXT TEST TEXT"
android:textColor="@color/white"
android:textSize="35sp"/>
<com.app.views.VerticalTextView
android:id="@+id/text3"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center_vertical|left"
android:gravity="bottom|center_horizontal"
android:text="TEST TEXT TEST TEXT"
android:background="@color/grey_700"
android:textColor="@color/white"
android:textSize="35sp"/>
<com.app.views.VerticalTextView
android:id="@+id/text4"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center_vertical|right"
android:gravity="top|center_horizontal"
android:text="TEST TEXT TEST TEXT"
android:background="@color/grey_700"
android:textColor="@color/white"
android:textSize="35sp"/>
</FrameLayout>
/*VerticalTextView.java*/
package com.app.views;

import android.content.Context;
import android.graphics.Canvas;
import android.util.AttributeSet;
import android.view.Gravity;
import android.widget.TextView;

public class VerticalTextView extends TextView {
final boolean topDown;

public VerticalTextView(Context context, AttributeSet attrs) {
super(context, attrs);
final int gravity = getGravity();
if (Gravity.isVertical(gravity) && (gravity & Gravity.VERTICAL_GRAVITY_MASK) == Gravity.BOTTOM) {
setGravity((gravity & Gravity.HORIZONTAL_GRAVITY_MASK) | Gravity.TOP);
topDown = false;
} else
topDown = true;
}

@Override
protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
super.onMeasure(heightMeasureSpec, widthMeasureSpec);
setMeasuredDimension(getMeasuredHeight(), getMeasuredWidth());
}

@Override
protected boolean setFrame(int l, int t, int r, int b) {
return super.setFrame(l, t, l + (b - t), t + (r - l));
}

@Override
public void draw(Canvas canvas) {
if (topDown) {
canvas.translate(getHeight(), 0);
canvas.rotate(90);
} else {
canvas.translate(0, getWidth());
canvas.rotate(-90);
}
canvas.clipRect(0, 0, getWidth(), getHeight(), android.graphics.Region.Op.REPLACE);
super.draw(canvas);
}
}

关于android - 如何修复TextView在旋转时向左和向右移动的问题?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29721509/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com