繁体   English   中英

Android drawable根据设备屏幕尺寸进行更改

[英]Android drawable changing according to device screen size

我想在UI下进行设计。 为了达到相同的目的,我尝试了drawables。 但是问题是 :drawable在不同的屏幕尺寸上显示不同。 对于屏幕尺寸6.0:可绘制对象为椭圆形,而下图为:可绘制圆圈。

UI设计尝试实现:

在此处输入图片说明

content_layout:

<?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="wrap_content"
    android:gravity="center_horizontal"
    android:orientation="horizontal"
    android:padding="16dp"
    app:layout_behavior="@string/appbar_scrolling_view_behavior"
    tools:context="com.mediaagility.drawablesample.MainActivity"
    tools:showIn="@layout/activity_main">

    <LinearLayout
        android:id="@+id/linear1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:background="@drawable/linear">

        <TextView
            android:id="@+id/textview1"
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:background="@drawable/bg_layout"
            android:gravity="center"
            android:text="10"
            android:textColor="@android:color/white"
            android:textSize="22sp" />

    </LinearLayout>

    <LinearLayout
        android:id="@+id/linear2"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginLeft="8dp"
        android:background="@drawable/linear">

        <TextView
            android:id="@+id/textview2"
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:background="@drawable/bg_layout"
            android:gravity="center"
            android:text="10"
            android:textColor="@android:color/white"
            android:textSize="22sp" />

    </LinearLayout>

    <LinearLayout
        android:id="@+id/linear3"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginLeft="8dp"
        android:background="@drawable/linear">

        <TextView
            android:id="@+id/textview3"
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:background="@drawable/bg_layout"
            android:gravity="center"
            android:text="10"
            android:textColor="@android:color/white"
            android:textSize="22sp" />

    </LinearLayout>
</LinearLayout>

linear_layout可绘制:

<?xml version="1.0" encoding="UTF-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
android:innerRadius="0dp"
android:shape="ring"
android:thicknessRatio="2"
android:useLevel="false">


    <stroke
        android:width="3dip"
        android:color="#FFB300" />
    <corners android:radius="10dip"
        />
    <padding
        android:bottom="8dp"
        android:left="8dp"
        android:right="8dp"
        android:top="8dp" />
    </shape>

bg_layout:

<?xml version="1.0" encoding="UTF-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
    android:innerRadius="0dp"
    android:shape="ring"
    android:thicknessRatio="2"
    android:useLevel="false">

    <gradient
        android:angle="-90"
        android:endColor="#1c75d1"
        android:gradientRadius="20dp"
        android:type="linear"
        android:startColor="#609ede" />


    <padding
        android:bottom="8dp"
        android:left="8dp"
        android:right="8dp"
        android:top="8dp" />
</shape>

main.class:

 LinearLayout linear1 = (LinearLayout) findViewById(R.id.linear1);
        LinearLayout linear2 = (LinearLayout) findViewById(R.id.linear2);
        LinearLayout linear3 = (LinearLayout) findViewById(R.id.linear3);


        LinearLayout.LayoutParams layoutParams = new LinearLayout.LayoutParams(
                LinearLayout.LayoutParams.WRAP_CONTENT,
                LinearLayout.LayoutParams.WRAP_CONTENT
        );

        layoutParams.width = ApplicationUtils.getScreenWidth(this) / 4 +50;
        layoutParams.height = ApplicationUtils.getScreenWidth(this) / 4 +50;
        layoutParams.gravity = Gravity.CENTER_HORIZONTAL | Gravity.CENTER_VERTICAL;
        layoutParams.leftMargin = ApplicationUtils.dpToPx(4);
        layoutParams.rightMargin = ApplicationUtils.dpToPx(4);

        linear1.setLayoutParams(layoutParams);
        linear2.setLayoutParams(layoutParams);
        linear3.setLayoutParams(layoutParams);

Please help me by suggesting how to design below UI which independent on screen size.

代替使用多个背景可绘制对象,请尝试使用以下方式:

<?xml version="1.0" encoding="utf-8"?>
<layer-list xmlns:android="http://schemas.android.com/apk/res/android">
    <item
        android:top="4dp"
        android:right="4dp"
        android:bottom="4dp"
        android:left="4dp">
        <shape
            android:shape="oval">
            <solid android:color="@color/colorPrimary" />
        </shape>
    </item>
    <item>
        <shape
            android:shape="oval">
            <stroke android:width="4dp"
                android:color="@color/colorAccent"/>
        </shape>
    </item>
</layer-list>

现在将TextView的背景设置为:

android:layout_width="your_width"
android:layout_height="your_height"    
android:background="@drawable/drawable_name"

这样,您不必寻找LinearLayout

因为您要在LinearLayout中设置固定尺寸,所以才拉伸它。 如果不需要,请将其删除。

您的xml看起来正确,您需要在此处进行计算

layoutParams.width = ApplicationUtils.getScreenWidth(this) / 4 +50;
layoutParams.height = ApplicationUtils.getScreenWidth(this) / 4 +50;

如果要支持固定大小的多屏显示,则应将dimens.xml用于不同的dpi文件夹

  • 价值观sw320dp,华电国际

  • 价值观sw320dp-MDPI

  • 价值观sw320dp-xhdpi
  • 价值观sw320dp-xxhdpi
  • 价值观sw320dp-xxxhdpi

该答案将指导您如何使用dimens.xml

将可绘制对象导入项目的最简单,最快的方法是使用可绘制导入器 这解决了在具有不同屏幕尺寸的不同设备中图像尺寸的问题。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM