当我将 ConstraintLayout 子项的重力(例如:TextView)更改为开始时,文本完全从左到右(在LTR配置中)以及当我将语言更改为阿拉伯语时( RTL配置)文本也来自从左到右,它不是预期的行为(预期的行为使文本来自从右到左) 。
当我将TextView放入像LinearLayout这样的另一个容器中时,我得到了我想要的文本 Right-to-eft 。
但我仍然不知道为什么当我在任何ConstraintLayout孩子中使用启动引力时,我得到的结果是英语和阿拉伯语配置中的从左到右 ?
我如何使用 ConstraintLayout 来做到这一点?
这个image显示了我在启动时设置重力时得到的结果,这个one显示了我应该得到的东西。
这是xml内容
<android.support.constraint.ConstraintLayout
android:id="@+id/constraintLayout"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="@color/black"
android:paddingBottom="20dp">
<ImageView
android:id="@+id/imageView5"
android:layout_width="@dimen/login_logo_width"
android:layout_height="@dimen/login_logo_height"
android:layout_marginEnd="8dp"
android:layout_marginStart="8dp"
android:layout_marginTop="@dimen/login_logo_margin_top"
android:background="@color/transparent"
android:src="@drawable/ic_logo"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent" />
<TextView
android:id="@+id/textView2"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginEnd="8dp"
android:layout_marginStart="8dp"
android:layout_marginTop="@dimen/login_login_text_margin_top"
android:background="@color/transparent"
android:text="@string/login"
android:textColor="@color/white"
android:textSize="@dimen/login_login_text_size"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toBottomOf="@+id/imageView5" />
<android.support.v7.widget.AppCompatEditText
android:id="@+id/phone_edit_txt"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_marginEnd="@dimen/login_phone_password_margin_start_end"
android:layout_marginStart="@dimen/login_phone_password_margin_start_end"
android:layout_marginTop="@dimen/login_phone_margin_top"
android:background="@drawable/simi_round_white_border_transparent_background"
android:ems="10"
android:gravity="end"
android:hint="@string/phone_number"
android:inputType="phone"
android:padding="@dimen/login_phone_password_padding"
android:textColor="@color/white"
android:textColorHint="@color/white"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toBottomOf="@+id/textView2" />
<android.support.v7.widget.AppCompatEditText
android:id="@+id/password_edit_txt"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_marginEnd="@dimen/login_phone_password_margin_start_end"
android:layout_marginStart="@dimen/login_phone_password_margin_start_end"
android:layout_marginTop="@dimen/login_password_margin_top"
android:background="@drawable/simi_round_white_border_transparent_background"
android:ems="10"
android:gravity="end"
android:hint="@string/password"
android:inputType="textPassword"
android:padding="@dimen/login_phone_password_padding"
android:textColor="@color/white"
android:textColorHint="@color/white"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toBottomOf="@+id/phone_edit_txt" />
<Button
android:id="@+id/login_button"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginEnd="8dp"
android:layout_marginStart="8dp"
android:layout_marginTop="@dimen/login_login_button_margin_top"
android:background="@drawable/simi_round_green_border_transparent_background"
android:paddingLeft="@dimen/login_login_button_padding_right_left"
android:paddingRight="@dimen/login_login_button_padding_right_left"
android:text="@string/login"
android:textColor="@color/white"
android:textSize="@dimen/login_login_button_text_size"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toBottomOf="@+id/password_edit_txt" />
</android.support.constraint.ConstraintLayout>
答案 0 :(得分:0)
如果您可以粘贴layout.xml将会很有帮助。但基于您的描述有两个建议:
,将所有左替换为开始,将右替换为结束,例如:使用layout_constraintStart_toEndOf
代替app:layout_constraintLeft_toRightOf
在AndroidManifest.xml中添加 android:supportsRtl =“true”