【问题标题】:Android How to Remove the Inner Padding of a Vector Asset DrawableAndroid 如何删除矢量资源 Drawable 的内部填充
【发布时间】:2020-10-17 03:51:22
【问题描述】:

我从 Vector Asset 绘制的矢量:

<vector
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:width="24dp"
    android:height="24dp"
    android:tint="@android:color/holo_purple"
    android:viewportWidth="24"
    android:viewportHeight="24">

    <path
        android:fillColor="@android:color/white"
        android:pathData="M7,14l5,-5 5,5z" />

</vector>

我的布局:

<LinearLayout
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:orientation="vertical">

    <ImageView
        android:layout_width="80dp"
        android:layout_height="80dp"
        android:src="@drawable/ic_baseline_arrow_drop_up_24" />

    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:background="@drawable/background"
        android:text="Hi, my name is Sam"
        android:textColor="@android:color/white"
        android:textSize="30sp" />

</LinearLayout>

当前输出:

如何移除这个矢量可绘制对象的内部填充?任何帮助将不胜感激。

【问题讨论】:

标签: android xml drawable android-drawable android-vectordrawable


【解决方案1】:

好的,这是我想出的解决方案,不是完美的答案,但可以满足我的需要。

像这样修改 Vector Drawable:

<vector
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:width="24dp"
    android:height="24dp"
    android:tint="@android:color/holo_purple"
    android:viewportWidth="24"
    android:viewportHeight="24">

    <group                       //key point
        android:pivotX="12"      //(12, 12) is the center accordig to the viewport, see link below
        android:pivotY="12"
        android:scaleX="2.0"     //twice bigger, adjust as needed
        android:scaleY="2.0"
        android:translateY="8">  //move downward, asjust as needed

        <path
            android:fillColor="@android:color/white"
            android:pathData="M7,14l5,-5 5,5z" />

    </group>

</vector>

结果:


此解决方案的好处是,无论您如何更改ImageView 的大小,目标形状都保持其位置(在我的情况下位于底部),因此无需理会RelativeLayout,只需LinearLayout

"pivot(12, 12)" 解释:https://stackoverflow.com/a/51659233/3466808

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2019-04-01
    • 2018-07-14
    • 2023-04-02
    • 2014-09-17
    • 2016-08-10
    • 2015-12-31
    相关资源
    最近更新 更多