3

伙计们。我正在学习 xamarin 并尝试为 android 制作一个基本的食物应用程序。这个应用程序是在 RTL 方向。现在我的主要内容中有一个 Listview,其中包含自定义布局列表。下面是这个自定义布局。我是 Xamarin Designer 窗口中的 RTL。 在此处输入图像描述

这是布局 asaml 代码

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="horizontal"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layoutDirection="rtl"
android:textDirection="rtl">
<LinearLayout
    android:orientation="vertical"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:id="@+id/linearLayout2">
    <ImageView
        android:src="@drawable/rating4"
        android:id="@+id/imgRating"
        android:layout_width="70dp"
        android:layout_height="20dp"
        android:layout_marginLeft="20dp"
        android:layout_marginRight="20dp"
        android:layout_marginTop="10dp" />
    <ImageView
        android:src="@drawable/defaultthumbnail"
        android:id="@+id/imgThumbnail"
        android:layout_width="match_parent"
        android:layout_height="70dp"
        android:layout_marginLeft="20dp"
        android:layout_marginRight="20dp" />
    <TextView
        android:text="10,000 تومان"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:textSize="20sp"
        android:textStyle="bold"
        android:id="@+id/foodPrice"
        android:layout_marginLeft="5dp"
        android:textDirection="rtl" />
</LinearLayout>
<LinearLayout
    android:orientation="vertical"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:layout_marginTop="10dp"
    android:layout_marginRight="20dp">
    <TextView
        android:text="نام غذا"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:id="@+id/txtFoodName"
        android:textSize="20sp"
        android:textStyle="bold" />
    <TextView
        android:text="توضیحات غذا"
        android:textAppearance="?android:attr/textAppearanceLarge"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:textSize="12sp"
        android:id="@+id/txtFoodDesc" />
    <TextView
        android:text="تاریخ"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:id="@+id/txtDate"
        android:textSize="8sp"
        android:textAllCaps="false" />
    <TextView
        android:text="آشپز"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:id="@+id/txtCook"
        android:textSize="8sp"
        android:textAllCaps="false" />
</LinearLayout>

这是我的主要布局,这个列表视图在其中。

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:id="@+id/mainContentLayout"
    app:layout_behavior="@string/appbar_scrolling_view_behavior"
    tools:showIn="@layout/app_bar_main"
    android:layoutDirection="rtl"
    android:textDirection="rtl">
    <ListView
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:id="@+id/mainContentListView"
        android:layoutDirection="rtl"
        android:textDirection="rtl" />
</LinearLayout>

但是当我运行它时,这就是我得到的

在此处输入图像描述

正如您可以看到的那样,里面的 2 个线性布局遵循 RTL 规则,但被倒置了。

4

2 回答 2

1

我遇到了同样的问题,我通过在应用程序的清单中添加以下内容来修复它:

<manifest>
    <application>
    android:supportsRtl="true"
    </application>
</manifest>
  • 默认模拟器和预览不适用于“RTL”语言。尝试在真正的 android 设备上测试或尝试 xamarin 实时播放器。

  • 还有一些安卓设备在安卓界面语言为英文时强制“ltr”,尝试将安卓语言更改为“RTL”语言。

于 2018-06-10T12:17:13.313 回答
0

关于android:supportsRtl="true",你可以参考这个,它的默认值为false。

从您的layout axaml code,它在 VS 的设计中显示为:

在此处输入图像描述

但它在 AS 的设计中显示为:

在此处输入图像描述

它与您运行的结果相同。

所以,VS的设计有问题。

如果我没有误读您的问题,您想要得到的是:

在此处输入图像描述

因此,您需要将您的更改layout axaml code为以下:

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="horizontal"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:layoutDirection="rtl"
    android:textDirection="rtl">
    <LinearLayout
        android:orientation="vertical"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:id="@+id/linearLayout2">
        <ImageView
            android:src="@drawable/pause"
            android:id="@+id/imgRating"
            android:layout_width="70dp"
            android:layout_height="20dp"
            android:layout_marginLeft="20dp"
            android:layout_marginRight="20dp"
            android:layout_marginTop="10dp" />
        <ImageView
            android:src="@drawable/dapao"
            android:id="@+id/imgThumbnail"
            android:layout_width="match_parent"
            android:layout_height="70dp"
            android:layout_marginLeft="20dp"
            android:layout_marginRight="20dp" />
        <TextView
            android:text="10,000 تومان"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:textSize="20sp"
            android:textStyle="bold"
            android:id="@+id/foodPrice"
            android:layout_marginLeft="5dp"
            android:textDirection="rtl" />
    </LinearLayout>
<View
    android:layout_weight="1"
    android:layout_width="0dp"
    android:layout_height="match_parent"/>
    <LinearLayout
        android:orientation="vertical"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginTop="10dp"
        android:layout_marginRight="20dp">
        <TextView
            android:text="نام غذا"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:id="@+id/txtFoodName"
            android:textSize="20sp"
            android:textStyle="bold" />
        <TextView
            android:text="توضیحات غذا"
            android:textAppearance="?android:attr/textAppearanceLarge"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:textSize="12sp"
            android:id="@+id/txtFoodDesc" />
        <TextView
            android:text="تاریخ"
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:id="@+id/txtDate"
            android:textSize="8sp"
            android:textAllCaps="false" />
        <TextView
            android:text="آشپز"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:id="@+id/txtCook"
            android:textSize="8sp"
            android:textAllCaps="false" />
    </LinearLayout>
</LinearLayout>
于 2018-06-11T09:21:58.437 回答