Android之shape设置虚线无效果

本文介绍了在Android中使用Shape设置虚线时遇到无法显示的问题及解决方法。尝试了调整View高度、禁用硬件加速等方法无效,最终通过设置View的Layer类型为软件模式实现了虚线效果。同时提醒开发者检查项目中硬件加速的使用情况。
摘要由CSDN通过智能技术生成

hape能画直线,虚线,矩形,圆形等,当然也可以画虚线,刚开始弄了半天就是没有效果。不懈的翻阅博客,各种尝试,总算解决了这个问题。

1.XML中定义shape,命名为

<shape
    android:shape="line"
    xmlns:android="http://schemas.android.com/apk/res/android">

    <stroke
        android:width="@dimen/px_3"
        android:dashGap="@dimen/px_9"
        android:dashWidth="@dimen/px_18"
        android:color="@color/color_e2"
        />
    <size android:height="@dimen/px_6" />
</shape>

2.在View中使用

<View
    android:layout_width="match_parent"
    android:layout_height="@dimen/px_18"
    android:background="@drawable/sha_dash_e2"/>

理论上来说,此时应该有虚线效果的,但实际情况并没有效果。有的说将View的高度设置为大于shape的高度,可以看xml,view的高度明显大于shape的高度。还有的说从android3.0开始,安卓关闭了硬件加速功能

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要将 AntV G6 中的图形元素设置虚线流动效果,您可以使用 G6 中的动画效果和事件机制。以下是一个示例代码片段,可以创建一个带有虚线流动效果的二次贝塞尔曲线: ```javascript const edge = graph.edge({ source: 'sourceNode', target: 'targetNode', type: 'edge', shape: 'quadratic', controlPoints: [ [x1, y1], // 第一个控制点 [x2, y2] // 第二个控制点 ], style: { lineDash: [4, 2] // 设置虚线的样式 } }); // 定义动画效果 graph.on('afterlayout', () => { const length = edge.getTotalLength(); // 获取曲线长度 const time = length / 100; // 计算动画时间 // 定义动画路径 edge.animate({ onFrame: ratio => { const start = edge.getPoint(0); // 获取曲线起点 const end = edge.getPoint(1); // 获取曲线终点 const point = edge.getPoint(ratio); // 获取动画路径上的点 // 计算动画路径上的虚线样式 const lineDash = [4, 2].map(len => len * (length - ratio * length) / length); return { // 更新曲线控制点位置 controlPoints: [ [x1 + point.x - start.x, y1 + point.y - start.y], [x2 + point.x - end.x, y2 + point.y - end.y] ], // 更新曲线虚线样式 style: { lineDash } }; }, repeat: true, // 重复播放动画 duration: time // 设置动画时间 }); }); ``` 在上面的示例中,我们使用 `getTotalLength()` 方法获取曲线的长度,并计算出动画的总时间。然后,我们使用 `animate()` 方法创建一个动画效果,该效果在曲线上运动,并更新控制点和虚线样式。最后,我们将动画设置为重复播放,以实现流动效果
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值