IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 移动开发 -> Android-横向虚线、竖向虚线实现 -> 正文阅读

[移动开发]Android-横向虚线、竖向虚线实现

效果图:

?横向虚线挺容易实现的,竖向虚线就不是那么容易实现了

1、水平横向分割线 detail_coupon_horizontal_line.xml

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
    android:shape="line">
    <!-- 破折线的宽度为dashWith,破折线之间的空隙的宽度为dashGap,当dashGap=0dp时,为实线-->
    <stroke
        android:width="0.5dp"
        android:color="#979797"
        android:dashWidth="3dp"
        android:dashGap="2dp" />
    <size android:height="1px" />

</shape>

2、垂直竖向分割线?detail_coupon_vertical_line.xml

<?xml version="1.0" encoding="utf-8"?>
<layer-list xmlns:android="http://schemas.android.com/apk/res/android">
    <!--注意上下左右方向问题-->
    <!--这里思路相当于一个只显示一条边的矩形虚线边框-->
    <item
        android:bottom="-0.5dp"
        android:right="-0.5dp"
        android:top="-0.8dp">
        <shape>
            <!--设置背景透明-->
            <solid android:color="#00000000" />
            <!--破折线的宽度为dashWith,破折线之间的空隙的宽度为dashGap,当dashGap=0dp时,为实线-->
            <stroke
                android:width="0.5dp"
                android:color="#979797"
                android:dashWidth="2dp"
                android:dashGap="1dp"/>
            <size android:height="1px" />
        </shape>
    </item>
</layer-list>

3、style文件??

在Android中画虚线需要设置android:layerType的值为software,否则显示为一条直线

<?xml version="1.0" encoding="utf-8"?>
<resources>

    <style name="horizontal_dotted_line_style">
        <item name="android:layout_width">match_parent</item>
        <item name="android:layout_height">2px</item>
        <item name="android:background">@drawable/detail_coupon_horizontal_line</item>
        <item name="android:layerType">software</item>
    </style>


    <style name="vertical_dotted_line_style">
        <item name="android:layout_width">1px</item>
        <item name="android:layout_height">45dp</item>
        <item name="android:background">@drawable/detail_coupon_vertical_line</item>
        <item name="android:layerType">software</item>
    </style>



</resources>

4、使用

<View
 android:id="@+id/line"
 style="@style/vertical_dotted_line_style"/>
       

?顺带附加一个textview? 显示两个不同字体的方法

/**
     * 
     * 价格单位字体大小和价格字体大小不同 和 颜色不同 适用
     * @param context
     * @param monetary_unit 价格单位
     * @param price 价格
     * @param suffixSize  单位字体大小
     * @param priceSize  价格字体大小
     * @return
     */
    public static SpannableString setPrice(Context context, String monetary_unit,String price, int suffixSize, int priceSize){
        SpannableString spannableString = null;
        if (!TextUtils.isEmpty(price)){
            StringBuilder sbPrice = new StringBuilder(monetary_unit);
            int offset = sbPrice.toString().length();
            sbPrice.append(price);
            spannableString = new SpannableString(sbPrice.toString());
            spannableString.setSpan(new AbsoluteSizeSpan(dip2px(context,suffixSize)), 0, offset,
                    Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);
            spannableString.setSpan(new ForegroundColorSpan(Color.RED), 0, offset, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);

            spannableString.setSpan(new AbsoluteSizeSpan(dip2px(context,priceSize)), offset,
                    sbPrice.toString().length(), Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);

            spannableString.setSpan(new ForegroundColorSpan(Color.BLUE), offset, sbPrice.toString().length(), Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);

        }
        return spannableString;
    }

  移动开发 最新文章
Vue3装载axios和element-ui
android adb cmd
【xcode】Xcode常用快捷键与技巧
Android开发中的线程池使用
Java 和 Android 的 Base64
Android 测试文字编码格式
微信小程序支付
安卓权限记录
知乎之自动养号
【Android Jetpack】DataStore
上一篇文章      下一篇文章      查看所有文章
加:2021-07-30 12:51:16  更:2021-07-30 12:51:41 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/28 11:41:17-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码