【问题标题】:Vector drawable not drawn correctly in Android Studio在 Android Studio 中未正确绘制矢量可绘制对象
【发布时间】:2016-11-04 09:12:42
【问题描述】:

我正在重新设计一个应用程序,但我无法在 Android Studio 中正确绘制一些图标。我使用 Sketch 完成所有的设计工作。

我已经在网上四处寻找解决方案,但很难解释搜索词的问题,所以我想我会尝试发布屏幕截图并提供一个 Sketch 文件来查看 StackOverflow社区可以提供帮助。

我认为问题与我在 Sketch 中构建矢量路径有关,尤其是它们如何相互重叠。这是我正在处理的图标示例:

Earth shape with longitude and latitude lines

如您所见,我在 Sketch 中创建图标没有问题。但是,在我将图标导出为 SVG 文件并将其导入 Android Studio 后,它的绘制方式如下:

Icon drawn in Android Studio

只有当形状变得更复杂并开始相互重叠时,我才会遇到这个问题。到目前为止,我已经能够为大多数图标保持简单,但它已经到了我需要找到解决方案的地步。

我打算在 Dropbox 中发布指向 Sketch 文件的链接,但我需要更多的信誉点才能做到这一点。如果需要,希望我可以在回复中提供该链接给某人。

任何帮助将不胜感激。如果这是一个重复的问题,我很抱歉。在我所有的搜索中,我可能没有用这样一种方式来表达这个问题以获得好的结果。

@Paul LeBeau,感谢您的回复。这是从 Sketch 导出的 SVG 代码:

<?xml version="1.0" encoding="UTF-8" standalone="no"?>
<svg width="24px" height="24px" viewBox="0 0 24 24" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">
    <!-- Generator: Sketch 3.8.3 (29802) - http://www.bohemiancoding.com/sketch -->
    <title>globe</title>
    <desc>Created with Sketch.</desc>
    <defs></defs>
    <g id="Page-1" stroke="none" stroke-width="1" fill="none" fill-rule="evenodd">
        <g id="globe" fill="#368EFA">
            <g id="test" transform="translate(2.000000, 2.000000)">
                <path d="M1.76297407,13 L5.00480805,13 C4.73881764,12.1144772 4.55303608,11.1138143 4.50968627,10 L1.02773406,10 C1.01839018,9.83680058 1.01365419,9.67236691 1.01365419,9.5068271 C1.01365419,9.33666963 1.01865808,9.16768089 1.02852674,9 L4.50968627,9 C4.55303608,7.88618573 4.73881764,6.8855228 5.00480805,6 L1.76915759,6 C1.92639337,5.65361668 2.10620446,5.31965722 2.30671248,5 L5.35559719,5 C6.20744032,2.88601313 7.45296691,1.59423095 7.91693127,1.16221702 C8.43195688,1.06468547 8.96343249,1.01365419 9.5068271,1.01365419 C10.0442032,1.01365419 10.569923,1.06356132 11.0796041,1.15899346 C11.5408038,1.58777803 12.7904304,2.88072886 13.6444028,5 L16.7069417,5 C16.9074497,5.31965722 17.0872608,5.65361668 17.2444966,6 L13.9951919,6 C14.2611824,6.8855228 14.4469639,7.88618573 14.4903137,9 L17.9851275,9 C17.9949961,9.16768089 18,9.33666963 18,9.5068271 C18,9.67236691 17.995264,9.83680058 17.9859201,10 L14.4903137,10 C14.4469639,11.1138143 14.2611824,12.1144772 13.9951919,13 L17.2506801,13 C17.0942093,13.3463294 16.915188,13.6802868 16.7154884,14 L13.6444028,14 C12.7787643,16.1482222 11.506588,17.4473934 11.0611474,17.8580954 C10.5572344,17.95129 10.0377192,18 9.5068271,18 C8.96992723,18 8.44466314,17.9501813 7.93540532,17.8549144 C7.4868821,17.4407166 6.21901315,16.1427067 5.35559719,14 L2.29816579,14 C2.09846621,13.6802868 1.9194449,13.3463294 1.76297407,13 Z M6.02760136,13 L9,13 L9,10 L5.51031179,10 C5.55606369,11.1058076 5.7507371,12.108186 6.02760136,13 Z M6.38814497,14 L9,14 L9,17.9088258 C8.62776002,17.558389 7.2971495,16.2062617 6.38814497,14 Z M9,1.09117415 L9,5 L6.38814497,5 C7.2971495,2.79373835 8.62776002,1.44161098 9,1.09117415 Z M6.02760136,6 L9,6 L9,9 L5.51031179,9 C5.55606369,7.8941924 5.7507371,6.89181397 6.02760136,6 Z M10,13 L12.9723986,13 C13.2492629,12.108186 13.4439363,11.1058076 13.4896882,10 L10,10 L10,13 Z M10,14 L12.611855,14 C11.7028505,16.2062617 10.37224,17.558389 10,17.9088258 L10,14 Z M10,1.09117415 C10.37224,1.44161098 11.7028505,2.79373835 12.611855,5 L10,5 L10,1.09117415 Z M10,6 L12.9723986,6 C13.2492629,6.89181397 13.4439363,7.8941924 13.4896882,9 L10,9 L10,6 Z" id="earth"></path>
                <path d="M9.5,18 L9.5,18 C14.1944204,18 18,14.1944204 18,9.5 C18,4.80557963 14.1944204,1 9.5,1 C4.80557963,1 1,4.80557963 1,9.5 C1,14.1944204 4.80557963,18 9.5,18 L9.5,18 Z M9.5,19 L9.5,19 C4.25329488,19 0,14.7467051 0,9.5 C0,4.25329488 4.25329488,0 9.5,0 C14.7467051,0 19,4.25329488 19,9.5 C19,14.7467051 14.7467051,19 9.5,19 L9.5,19 Z" id="border"></path>
            </g>
        </g>
    </g>
</svg>

这是将SVG文件直接导入Android Studio后的代码:

<vector xmlns:android="http://schemas.android.com/apk/res/android"
    android:width="24dp"
    android:height="24dp"
    android:viewportWidth="24.0"
    android:viewportHeight="24.0">
<path
    android:pathData="M3.763,15L7.005,15C6.739,14.114 6.553,13.114 6.51,12L3.028,12C3.018,11.837 3.014,11.672 3.014,11.507C3.014,11.337 3.019,11.168 3.029,11L6.51,11C6.553,9.886 6.739,8.886 7.005,8L3.769,8C3.926,7.654 4.106,7.32 4.307,7L7.356,7C8.207,4.886 9.453,3.594 9.917,3.162C10.432,3.065 10.963,3.014 11.507,3.014C12.044,3.014 12.57,3.064 13.08,3.159C13.541,3.588 14.79,4.881 15.644,7L18.707,7C18.907,7.32 19.087,7.654 19.244,8L15.995,8C16.261,8.886 16.447,9.886 16.49,11L19.985,11C19.995,11.168 20,11.337 20,11.507C20,11.672 19.995,11.837 19.986,12L16.49,12C16.447,13.114 16.261,14.114 15.995,15L19.251,15C19.094,15.346 18.915,15.68 18.715,16L15.644,16C14.779,18.148 13.507,19.447 13.061,19.858C12.557,19.951 12.038,20 11.507,20C10.97,20 10.445,19.95 9.935,19.855C9.487,19.441 8.219,18.143 7.356,16L4.298,16C4.098,15.68 3.919,15.346 3.763,15ZM8.028,15L11,15L11,12L7.51,12C7.556,13.106 7.751,14.108 8.028,15ZM8.388,16L11,16L11,19.909C10.628,19.558 9.297,18.206 8.388,16ZM11,3.091L11,7L8.388,7C9.297,4.794 10.628,3.442 11,3.091ZM8.028,8L11,8L11,11L7.51,11C7.556,9.894 7.751,8.892 8.028,8ZM12,15L14.972,15C15.249,14.108 15.444,13.106 15.49,12L12,12L12,15ZM12,16L14.612,16C13.703,18.206 12.372,19.558 12,19.909L12,16ZM12,3.091C12.372,3.442 13.703,4.794 14.612,7L12,7L12,3.091ZM12,8L14.972,8C15.249,8.892 15.444,9.894 15.49,11L12,11L12,8Z"
    android:strokeWidth="1"
    android:fillColor="#368EFA"
    android:strokeColor="#00000000"/>
<path
    android:pathData="M11.5,20L11.5,20C16.194,20 20,16.194 20,11.5C20,6.806 16.194,3 11.5,3C6.806,3 3,6.806 3,11.5C3,16.194 6.806,20 11.5,20L11.5,20ZM11.5,21L11.5,21C6.253,21 2,16.747 2,11.5C2,6.253 6.253,2 11.5,2C16.747,2 21,6.253 21,11.5C21,16.747 16.747,21 11.5,21L11.5,21Z"
    android:strokeWidth="1"
    android:fillColor="#368EFA"
    android:strokeColor="#00000000"/>

【问题讨论】:

  • 您能否将 SVG 作为代码粘贴到您的问题中?

标签: android android-studio svg android-vectordrawable sketch-3


【解决方案1】:

我也遇到了同样的问题,我的三个图标在 Android Studio 中无法正确呈现。

虽然根本原因是 VectorDrawable 不支持奇偶填充类型,但要使其正常工作,您不应在 .svg 文件上对其进行编辑。您必须在 Sketch 本身上对其进行编辑。 This article 彻底解释这个话题。我将尝试回顾一些要点。

  1. 在草图中。找到你丢失的形状。在我的例子中,它是一个圆形。

  1. 在填充配置(齿轮形图标)中,将其更改为非零。

  1. 你需要重新调整你的形状顺序,打开图层 -> 路径 -> 倒序。

  1. 导出您的分组形状。

  1. 将其转换为 VectorDrawable(通过 Android Studio 或 3rd 方工具)。

有时我需要重复第 3 步。不过,它始终适用于我的情况。我希望这能解决你的问题。

【讨论】:

  • 我不知道填充设置中存在“非零/偶数”选项@aldok!我还没有机会使用它,但是当我们在导出图形时遇到其他问题时,我会记住这一点。
【解决方案2】:

我猜你的图标是一个切出 16 个孔的圆圈。对吗?

如果是这样,则可能是填充规则存在问题。 VectorDrawables(和 SVG)默认使用非零填充规则,如果您的形状使用奇偶填充规则呈现,则会给出不同的结果。

我猜 Sketch 默认使用奇偶填充规则。或者你把它改成了奇偶(?)

如果由于某种原因您无法修复 Sketch 中的填充规则,或者在转换为 VectorDrawable 时无法通过,则需要在 VectorDrawable 中自己手动更改。

打开 VectorDrawable 文件并找到 &lt;path&gt; 元素。然后更改(或设置)以下属性:

android:fillType="evenodd"

更新

好的,我认为切换 fillType 会起作用,但事实并非如此。但我确实有解决办法。

很多人不知道的是,填充路径的段绘制方向对填充有影响。线段绘制方向是指路径(或子路径)中的点是按顺时针方向还是逆时针方向绘制的。这被称为点的“缠绕”。

修改您的文件并更改六个错误的子路径(切口),使它们以与现在相反的方向绘制。你的 VectorDrawable 应该会正确渲染。

例如,如果您尝试这个修改后的 VectorDrawable 文件,您会发现我已将其中一个切口(左上角有缺陷的)中的点重新排列到相反的缠绕方向。一些矢量编辑器可以为您反转路径方向。我不确定 Sketch 是否可以。

【讨论】:

  • 嗨,保罗,非常感谢您的回复。形状不是一个有 16 个切口的圆形。相反,我使用了六个 1px 矩形来创建圆圈内的分区。我将 SVG 代码添加到我的原始帖子中,如果有帮助,这里是指向 Dropbox 中 Sketch 文件的链接:dropbox.com/s/k3wvzqfb9xecy5w/globe.sketch?dl=0> 我尝试查找有关 Sketch 的 SVG 填充类型的信息,但我在网上找不到任何东西.我确实尝试将 {android:fillType="evenodd"} 属性添加到 Android Studio 中的 '' 元素,但它没有改变任何东西。
  • 用更多信息更新了我的答案。
  • 嘿,保罗……这几乎解决了这个问题。我说得差不多是因为我必须在反转子路径的绘制顺序之前展平总体路径。我构建图形的方式可能有点古怪,但我只是习惯于使用矢量工具构建形状......使用 Photoshop 更好,但远离光栅图形。无论如何,非常感谢您的帮助!随着我在创建形状方面做得越来越好,我认为您提供的答案将有很大帮助。
  • fillType 似乎在过去几年的某个时候从 evenodd 变为 evenOdd。无法编辑,因为“建议的编辑队列已满”。不过感谢您的帮助!
【解决方案3】:

只需覆盖顶部的材料设计缩放。 在右上角。

【讨论】:

    猜你喜欢
    • 2020-10-16
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2018-09-07
    • 2020-10-26
    • 2016-05-25
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多