`

attr.xml 自定义View属性format

阅读更多

attr.xml 自定义属性format

 

 

1. reference:参考某一资源ID。

    (1)属性定义:

            <declare-styleable name = "名称">

                   <attr name = "background" format = "reference" />

            </declare-styleable>

    (2)属性使用:

             <ImageView

                     android:layout_width = "42dip"
                      android:layout_height = "42dip"
                      android:background = "@drawable/图片ID"

                     />

2. color:颜色值。

    (1)属性定义:

            <declare-styleable name = "名称">

                   <attr name = "textColor" format = "color" />

            </declare-styleable>

    (2)属性使用:

            <TextView

                     android:layout_width = "42dip"
                      android:layout_height = "42dip"
                      android:textColor = "#00FF00"

                     />

3. boolean:布尔值。

    (1)属性定义:

            <declare-styleable name = "名称">

                   <attr name = "focusable" format = "boolean" />

            </declare-styleable>

    (2)属性使用:

            <Button

                    android:layout_width = "42dip"
                     android:layout_height = "42dip"

                    android:focusable = "true"

                    />

4. dimension:尺寸值。

    (1)属性定义:

            <declare-styleable name = "名称">

                   <attr name = "layout_width" format = "dimension" />

            </declare-styleable>

    (2)属性使用:

            <Button

                    android:layout_width = "42dip"
                     android:layout_height = "42dip"

                    />

5. float:浮点值。

    (1)属性定义:

            <declare-styleable name = "AlphaAnimation">

                   <attr name = "fromAlpha" format = "float" />
                    <attr name = "toAlpha" format = "float" />

            </declare-styleable>

    (2)属性使用:

            <alpha
                    android:fromAlpha = "1.0"
                    android:toAlpha = "0.7"

                   />

6. integer:整型值。

    (1)属性定义:

            <declare-styleable name = "AnimatedRotateDrawable">

                   <attr name = "visible" />
                    <attr name = "frameDuration" format="integer" />
                    <attr name = "framesCount" format="integer" />
                    <attr name = "pivotX" />
                    <attr name = "pivotY" />
                    <attr name = "drawable" />

            </declare-styleable>

    (2)属性使用:

            <animated-rotate 

                   xmlns:android = "http://schemas.android.com/apk/res/android" 
                    android:drawable = "@drawable/图片ID"  
                   android:pivotX = "50%"  
                   android:pivotY = "50%"  
                   android:framesCount = "12"  
                   android:frameDuration = "100" 

                   />

7. string:字符串。

    (1)属性定义:

            <declare-styleable name = "MapView">
                    <attr name = "apiKey" format = "string" />
             </declare-styleable>

    (2)属性使用:

            <com.google.android.maps.MapView
                     android:layout_width = "fill_parent"
                     android:layout_height = "fill_parent"
                     android:apiKey = "0jOkQ80oD1JL9C6HAja99uGXCRiS2CGjKO_bc_g"

                    />

8. fraction:百分数。

    (1)属性定义:

            <declare-styleable name="RotateDrawable">
                    <attr name = "visible" />
                    <attr name = "fromDegrees" format = "float" />
                    <attr name = "toDegrees" format = "float" />
                    <attr name = "pivotX" format = "fraction" />
                    <attr name = "pivotY" format = "fraction" />
                    <attr name = "drawable" />
             </declare-styleable>

    (2)属性使用:

            <rotate 

                   xmlns:android = "http://schemas.android.com/apk/res/android" 
               android:interpolator = "@anim/动画ID" 

                   android:fromDegrees = "0" 
               android:toDegrees = "360" 

                   android:pivotX = "200%" 

                   android:pivotY = "300%" 
               android:duration = "5000" 

                   android:repeatMode = "restart" 

                   android:repeatCount = "infinite"

                   /> 

9. enum:枚举值。

    (1)属性定义:

            <declare-styleable name="名称">
                    <attr name="orientation">
                           <enum name="horizontal" value="0" />
                           <enum name="vertical" value="1" />
                    </attr>            

            </declare-styleable>

    (2)属性使用:

            <LinearLayout 

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

10. flag:位或运算。

     (1)属性定义:

             <declare-styleable name="名称">
                     <attr name="windowSoftInputMode">
                             <flag name = "stateUnspecified" value = "0" />
                             <flag name = "stateUnchanged" value = "1" />
                             <flag name = "stateHidden" value = "2" />
                             <flag name = "stateAlwaysHidden" value = "3" />
                             <flag name = "stateVisible" value = "4" />
                             <flag name = "stateAlwaysVisible" value = "5" />
                             <flag name = "adjustUnspecified" value = "0x00" />
                             <flag name = "adjustResize" value = "0x10" />
                             <flag name = "adjustPan" value = "0x20" />
                             <flag name = "adjustNothing" value = "0x30" />
                      </attr>         

             </declare-styleable>

     (2)属性使用:

            <activity 

                   android:name = ".StyleAndThemeActivity"
                    android:label = "@string/app_name"
                    android:windowSoftInputMode = "stateUnspecified | stateUnchanged | stateHidden">
                    <intent-filter>
                           <action android:name = "android.intent.action.MAIN" />
                           <category android:name = "android.intent.category.LAUNCHER" />
                    </intent-filter>
              </activity>

     注意:

     属性定义时可以指定多种类型值。

    (1)属性定义:

            <declare-styleable name = "名称">

                   <attr name = "background" format = "reference|color" />

            </declare-styleable>

    (2)属性使用:

             <ImageView

                     android:layout_width = "42dip"
                      android:layout_height = "42dip"
                      android:background = "@drawable/图片ID|#00FF00"

                     />

Android自定义View三步曲:

onMeasure:测量大小

onLayout:布局

onDraw:绘制

分享到:
评论

相关推荐

    Android自定义View中attrs.xml的实例详解

    Android自定义View中attrs.xml的实例详解 我们在自定义View的时候通常需要先完成attrs.xml文件 在values中定义一个attrs.xml 然后添加相关属性 这一篇先详细介绍一下attrs.xml的属性。 &lt;?xml version=1.0 ...

    Android重写View并自定义属性实例分析

    本文实例分析了Android重写View并自定义属性的方法。分享给大家供大家参考,具体如下: 这里通过自定义属性 实现如下图所示效果: 第一步:在res\values的目录下新建一个文件attrs.xml 声明一些自定义属性 &lt;?...

    Android 自定义view模板并实现点击事件的回调

    Android 自定义view模板并实现点击事件的回调 主要的目的就是仿老版QQ的一个界面做一个模板。然后实现点击事件的回调。先看效果图: 步骤如下: 1.在res/values/目录下新建一个atts.xml文件 内容如下: ...

    Android自定义View仿QQ健康界面

    最近一直在学习自定义View相关的知识,今天给...1.自定义view的属性: &lt;?xml version=1.0 encoding=utf-8?&gt; //自定义属性名,定义公共属性 &lt;attr name=titleSize format=dimension&gt;&lt;/attr&gt; &lt;attr name=ti

    Android自定义View实现加载进度条效果

    上一篇文章总结了下自定义View的几个步骤,...1.首先还是在attrs.xml文件中自定义我们需要的属性: &lt;?xml version=1.0 encoding=utf-8?&gt; &lt;attr name=textSize format=dimension&gt; &lt;attr name=textColor

    Android自定义View圆形百分比控件(一)

    1、在res/values文件夹下新建attrs.xml文件,编写自定义属性: &lt;?xml version=1.0 encoding=utf-8?&gt; &lt;attr name=circleBg format=color/&gt; &lt;attr name=arcColor format=color/&gt; &lt;attr name=

    Android自定义View圆形进度条控件(三)

    继续练习自定义View,这次...1、在res/values文件夹下新建attrs.xml文件,编写自定义属性: &lt;?xml version=1.0 encoding=utf-8?&gt; &lt;!-- 弧线宽度 --&gt; &lt;attr name=arcWidth format=dimension&gt; &lt;!--

    Android中自定义View实现圆环等待及相关的音量调节效果

    2、在View的构造方法中获得我们自定义的属性 3、重写onMesure  4、重写onDraw 1、自定义属性: &lt;?xml version=1.0 encoding=utf-8?&gt; &lt;resources&gt; &lt;attr name=firstColor format=color&gt; &lt;attr name=...

    Android自定义View倒计时圆

    本文实例为大家分享了Android自定义View倒计时圆的具体代码,供大家参考,具体内容如下   创建attr &lt;?xml version=1.0 encoding=utf-8?&gt; &lt;!--颜色--&gt; &lt;attr name=ringColor format=color&gt; &lt...

    应用启动页自定义跳转计时器View Demo

    应用启动页自定义跳转计时器View Demo: CircleTextProgressbar.java: package com.demo.startpageskiptimerdemo.widget; import android.content.Context; import android.content.res.ColorStateList; import ...

    Android自定义View实现自动转圈效果

    本文实例为大家分享了Android实现自动转圈效果展示的具体代码,供大家参考,具体内容如下 在values文件夹下创建attrs.xml &lt;?xml version=1.0 encoding=utf-8?...attr name=circle_x format=dimens

    Android自定义view之仿支付宝芝麻信用仪表盘示例

    自定义view练习 仿支付宝芝麻信用的仪表盘 对比图: 首先是自定义一些属性,可自己再添加,挺基础的,上代码 &lt;?xml version=1.0 encoding=utf-8?&gt; &lt;!--最大数值--&gt; &lt;attr name=maxNum format...

    Android自定义View实现炫酷进度条

    第一步:创建attrs文件夹,自定义属性: &lt;?xml version=1.0 encoding=utf-8?&gt; &lt;attr name=out_color format=color/&gt; &lt;attr name=inner_color format=color/&gt; &lt;attr name=border_width format=d

    Android自定义View仿QQ运动步数效果

    首先自定义属性: &lt;?xml version=1.0 encoding=utf-8?&gt; &lt;attr name=out_color format=color/&gt; &lt;attr name=inner_color format=color/&gt; &lt;attr name=border_width format=dimension/&gt;

    Android 自定义View 密码框实例代码

    暴露您view中所有影响可见外观的属性或者行为。 •通过XML添加和设置样式 •通过元素的属性来控制其外观和行为,支持和重要事件交流的事件监听器 详细步骤见:Android 自定义View步骤 效果图展示: 支持的样式...

    Andorid自定义attr的各种坑

    在开发Andorid应用程序中,经常会自定义View来实现各种各样炫酷的效果,在实现这吊炸天效果的同时,我们往往会定义很多attr属性,这样就可以在XML中配置我们想要的属性值,以下就是定义属性值可能遇到的各种坑。...

    android自定义view制作圆形进度条效果

    1、自定义View的属性 2、在View的构造方法中获得我们自定义的属性 [ 3、重写onMesure ] 4、重写onDraw 1、自定义属性: &lt;?xml version=1.0 encoding=utf-8?&gt; &lt;attr name=mSpeed format=integer&gt; &lt;attr...

    Android 开发订单流程view实例详解

    Android 开发订单流程view实例详解 先看看最终效果图: 怎么样,效果还是很不错的吧?群里有人说切四张图的、recycleview的、各种的都有啊,但是最简单的就是通过自定义view来实现了...attr name=thumb_radius format

    Android自定义控件深入学习 Android生成随机验证码

    在上一篇的文章中介绍了自定义控件的属性,详情见《详解Android自定义控件属性TypedArray以及attrs》。那么在这基础上实现随机验证码生成,里面的代码是自定义控件以及涉及到自定义view绘画。 1、先看实现的效果图 ...

Global site tag (gtag.js) - Google Analytics