【问题标题】:Group Indicator get distorted?组指标失真?
【发布时间】:2015-09-08 14:41:46
【问题描述】:

我使用带有组指示器的 ExpandableListView。组指示图应放置在组视图的右侧,垂直居中,不失真。

下面是它的样子:

未失真的图像如下所示:

这是我的布局:

<ExpandableListView
    android:id="@+id/list"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:groupIndicator="@drawable/list_group_indictor"
    android:divider="@color/whiteColor"
    android:dividerHeight="1dp" />

这里是样式list_group_indictor

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android" >

    <item
        android:drawable="@drawable/carat_right" />

    <item
        android:drawable="@drawable/carat_down"
        android:state_expanded="true" />

</selector>

如何让右侧的组指示器,垂直居中而不失真?

编辑:我尝试使用 this 工具使用内容填充生成 9-patch 图像。结果是这样的:

【问题讨论】:

  • @FrankN.Stein 能否请您发布一个示例并解释为什么 9-patch?
  • 您不必在填充区域上设置标记。但是在拉伸区域,就像我发布的 9 个补丁一样。还是您还没有看到我编辑的答案?
  • 可以多写几行。我不明白你是怎么做到的。
  • 如教程页面中所述(顺便说一句,您是否阅读了我的答案?)我在答案中链接,填充区域是您设置内容的位置(返回 = 内容),而拉伸区域是您设置可拉伸的位置(黑色 = 可拉伸)。在标记边框上,黑色必须是 black (#ff000000),其余部分是透明的 (#00000000)。如果您试用我的补丁,它们会在第一次尝试时运行。只需正确命名即可。

标签: java android listview expandablelistview


【解决方案1】:

您应该使用 9 个补丁,而不是普通的 png。
只需将顶部和左侧标记放在空白区域以仅拉伸这些部分(这将导致在缩放时添加一些填充)。

一个关于 9 个补丁的好教程会让你明白为什么需要使用它们,比我的话更好:http://radleymarx.com/blog/simple-guide-to-9-patch/


[编辑]

这些是补丁:

这就是它们在 draw9patch 工具中的外观 - 您可以清楚地看到 9 个补丁标记的运行情况:

您可以看到箭头没有被拉伸,只有其周边的透明部分。
这是想要的效果。

请记住,扩展名必须是 .9.png,而不是 .png

【讨论】:

  • 好的,请为我准备一份。
  • ...两个。我会准备“下”和“仪式”。
  • 请查看我的编辑我尝试使用 9-patch 但它变得更糟。
  • 您的 9 个补丁错误。你为什么不试试我的呢?
猜你喜欢
  • 2018-12-07
  • 1970-01-01
  • 2021-08-30
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2020-11-23
  • 2011-01-28
  • 1970-01-01
相关资源
最近更新 更多