Android 自定义 declare-styleable 的format

简介: declare-styleable 格式定义方法一览表类型描述            ​字段名称           定义方式举例            调用方式举例 ...
类型描述             ​字段名称            定义方式举例             调用方式举例            
资源ID
           
reference
           
<attr 
          name = "background"
         format = "reference"
/>

               

<ImageView
    android:layout_width = "42dip"
    android:layout_height = "42dip"
    android:background = "@drawable/图片ID"
    />
颜色 color
<attr 
          name = "background"
         format = "color"
/><span style="font-family: Arial, Helvetica, sans-serif; widows: auto; background-color: rgb(255, 255, 255);">  </span>
<ImageView
    android:background = "#ffffff"
    />
布尔值 boolean
<attr 
          name = "isture"
         format = "boolean"
/>
<ImageView
    app:istrue = "false"
    />
尺寸值
           
dimension
<attr
    name="layout_width"
    format="dimension"
/>
<ImageView
    android:layout_width="42dip"
/>

               

浮点值
           
float  
<attr
    name="fromAlpha"
    format="float"
/>
<View
    app:fromAlpha="1.0"
/>
整数型 integer
<attr
    name="numerical"
    format="integer"
/>
<View
    app:numerical="1"
/>
字符串 string
           
<attr
    name="view_title"
    format="string"
/>
<View
    app:view_title= "open view title"
/>
百分比 fraction
<attr
    name="provX"
    format="fraction"
/><span style="font-family: Arial, Helvetica, sans-serif; widows: auto; background-color: rgb(255, 255, 255);"> </span>
<View
    app:provX="20%"
/>
枚举类型 enum
           
<attr name="orientation">
 <enum name="hori" value="0"/>
 <enum name="ver" value="1"/>
</attr>
<View
    app:orientation="hori"
/>
位或运算 flag
<attr name="orie">
 <flag name="hori" value="0x10"/>
 <flag name="ver" value="0x20"/>
</attr>
<View
    app:orie="hori | ver"
/>
     


附加:自定义xml属性步骤

1、在res/values/目录中新建resources的xml文件,xml举例:
<resources>
    <declare-styleable name="accItem">
        <attr name="accleftimg" format="reference"/>
        <attr name="acctitle" format="string"/>
        <attr name="splitstyle_top">
            <enum name="none_line" value="0"/>
            <enum name="whole_line" value="1"/>
            <enum name="half_line" value="2"/>
        </attr>
        <attr name="splitstyle_bottom">
            <enum name="none_line" value="0"/>
            <enum name="whole_line" value="1"/>
            <enum name="half_line" value="2"/>           
        </attr>
    </declare-styleable>
</resources>

  • declare-styleable:自定义属性块标识

  • accItem:自定义属性块的名称,在代码获取xml属性的时候会使用到

  • <attr>:一项自定义属性的标识块,其中name为属性名称,format为属性格式,参考起始表

2、在xml文件中如何使用
  •     在xml定义xmlns,举例示意:     

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res/package"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical" >
</LinearLayout>

代码第二行即为我们自定义的xmlns,有三点需要注意:1、xmlns为定义xmlns标识,不可改变;2、app(xmlns:app)为引用标识,用户可自行改变,使用xml布局时,使用该标识可指定属性,如“app.acctitle = "demo"”;3、package是可变参数,必须于工程项目的包名相同,即"AndroidManifest.xml"中的package     

   布局文件中使用自定义控件的时候,和嵌入普通布局一样,引用属性时,使用上一步定义的xmlns加第一步时定义的attr->name直接使用。举例说明:

<!--自定义控件-->
<package.view.demo
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    <!--app为我们定义的xmlns-->
    <!--app后的属性已在declare-styleable中定义-->
    app:accleftimg="@drawable/gerenziliaoimg"
    app:acctitle="@string/gerenziliao"
 
    app:splitstyle_top="whole_line"
    app:splitstyle_bottom="half_line"
    >               
</package.view.demo>

参考代码:3、如何在自定义控件中获取自定义属性的值
TypedArray a = context.obtainStyledAttributes(attrs, R.styleable.accItem);
mheaderDrawable = a.getDrawable(R.styleable.accItem_accleftimg);
mcontentTitle = a.getString(R.styleable.accItem_acctitle);
mtopSpliterStyle = a.getInt(R.styleable.accItem_splitstyle_top, 0);
mbottomSpliterStyle = a.getInt(R.styleable.accItem_splitstyle_bottom, 0);
a.recycle();

第一行:R.styleable.accItem,其中accItem为在资源文件中定义的declare-styleable代码块的name属性使用TypedArray 获取自定义属性

第二行:R.styleable.accItem_accleftimg,其中accItem_accleftimg为[declare-styleable][name]->[attr][name]属性

第三行:执行完毕后,需要调用recycle来释放元素

目录
相关文章
|
28天前
|
Android开发 开发者
安卓应用开发中的自定义视图
【9月更文挑战第37天】在安卓开发的海洋中,自定义视图犹如一座座小岛,等待着勇敢的探索者去发现其独特之处。本文将带领你踏上这段旅程,从浅滩走向深海,逐步揭开自定义视图的神秘面纱。
31 3
|
21天前
|
数据可视化 Android开发 开发者
安卓应用开发中的自定义View组件
【10月更文挑战第5天】在安卓应用开发中,自定义View组件是提升用户交互体验的利器。本篇将深入探讨如何从零开始创建自定义View,包括设计理念、实现步骤以及性能优化技巧,帮助开发者打造流畅且富有创意的用户界面。
52 0
|
3月前
|
供应链 物联网 区块链
未来触手可及:探索新兴技术的趋势与应用安卓开发中的自定义视图:从基础到进阶
【8月更文挑战第30天】随着科技的飞速发展,新兴技术如区块链、物联网和虚拟现实正在重塑我们的世界。本文将深入探讨这些技术的发展趋势和应用场景,带你领略未来的可能性。
|
21天前
|
XML 前端开发 Java
安卓应用开发中的自定义View组件
【10月更文挑战第5天】自定义View是安卓应用开发的一块基石,它为开发者提供了无限的可能。通过掌握其原理和实现方法,可以创造出既美观又实用的用户界面。本文将引导你了解自定义View的创建过程,包括绘制技巧、事件处理以及性能优化等关键步骤。
|
2月前
|
Android开发 开发者
安卓开发中的自定义视图:从入门到精通
【9月更文挑战第19天】在安卓开发的广阔天地中,自定义视图是一块充满魔力的土地。它不仅仅是代码的堆砌,更是艺术与科技的完美结合。通过掌握自定义视图,开发者能够打破常规,创造出独一无二的用户界面。本文将带你走进自定义视图的世界,从基础概念到实战应用,一步步展示如何用代码绘出心中的蓝图。无论你是初学者还是有经验的开发者,这篇文章都将为你打开一扇通往创意和效率的大门。让我们一起探索自定义视图的秘密,将你的应用打造成一件艺术品吧!
56 10
|
2月前
|
XML 编解码 Android开发
安卓开发中的自定义视图控件
【9月更文挑战第14天】在安卓开发中,自定义视图控件是一种高级技巧,它可以让开发者根据项目需求创建出独特的用户界面元素。本文将通过一个简单示例,引导你了解如何在安卓项目中实现自定义视图控件,包括创建自定义控件类、处理绘制逻辑以及响应用户交互。无论你是初学者还是有经验的开发者,这篇文章都会为你提供有价值的见解和技巧。
38 3
|
2月前
|
前端开发 Android开发 开发者
安卓应用开发中的自定义视图基础
【9月更文挑战第13天】在安卓开发的广阔天地中,自定义视图是一块神奇的画布,它允许开发者将想象力转化为用户界面的创新元素。本文将带你一探究竟,了解如何从零开始构建自定义视图,包括绘图基础、触摸事件处理,以及性能优化的实用技巧。无论你是想提升应用的视觉吸引力,还是追求更流畅的交互体验,这里都有你需要的金钥匙。
|
2月前
|
缓存 搜索推荐 Android开发
安卓应用开发中的自定义View组件实践
【9月更文挑战第10天】在安卓开发领域,自定义View是提升用户体验和实现界面个性化的重要手段。本文将通过一个实际案例,展示如何在安卓项目中创建和使用自定义View组件,包括设计思路、实现步骤以及可能遇到的问题和解决方案。文章不仅提供了代码示例,还深入探讨了自定义View的性能优化技巧,旨在帮助开发者更好地掌握这一技能。
|
3月前
|
XML 搜索推荐 Android开发
安卓开发中的自定义View组件实践
【8月更文挑战第30天】探索Android世界,自定义View是提升应用界面的关键。本文以简洁的语言带你了解如何创建自定义View,从基础到高级技巧,一步步打造个性化的UI组件。
|
2月前
|
前端开发 搜索推荐 Android开发
探索安卓开发中的自定义视图##
【9月更文挑战第6天】 在安卓应用开发的世界里,自定义视图如同绘画艺术中的色彩,它们为界面设计增添了无限可能。通过掌握自定义视图的绘制技巧,开发者能够创造出既符合品牌形象又提升用户体验的独特界面元素。本文将深入浅出地介绍如何从零开始构建一个自定义视图,包括基础框架搭建、关键绘图方法实现、事件处理机制以及性能优化策略。准备好让你的安卓应用与众不同了吗?让我们开始吧! ##