[Android自定义控件]自定义属性attrs.xml中format

前言

在我们自定义控件的时候,需要自己定义布局xml对象属性,就需要styles.xml自定义,然后再自定义java文件中获取信息,记录方便自己使用


使用

xml首先需要自定义命名空间

xmlns: zkbilian ="http://schemas.android.com/apk/res-auto"  
  • 1.reference:参考某一资源ID

属性定义:

            <declare-styleable name = "名称">
                   <attr name = "background" format = "reference" />
            </declare-styleable>

属性使用:

             <ImageView
                     android:layout_width = "59dp"
                     android:layout_height = "42dp"
                     zkbilian:background = "@drawable/资源ID"
                     />
  • 2.color:颜色值

属性定义:

            <declare-styleable name = "HavorldAttribute">  
                   <attr name = "textColor" format = "color" />  
            </declare-styleable>  

属性使用:

          <TextView  
            android:layout_width = "42dip"  
            android:layout_height= "42dip"  
            havorld:textColor = "#00FF00" />  
  • 3.boolean:布尔值

属性定义:

          <declare-styleable name = "HavorldAttribute">  
               <attr name = "focusable" format = "boolean" />  
          </declare-styleable> 

属性使用:

          <Button  
             android:layout_width = "42dip"  
             android:layout_height = "42dip"  
         havorld:focusable ="true"/>  
  • 4.dimension:尺寸值

属性定义:

            <declare-styleable name = "HavorldAttribute">  
               <attr name = "layout_width" format = "dimension" />  
            </declare-styleable>

属性使用:

            <Button  
               havorld:layout_width ="42dip"  
               havorld:layout_height ="42dip"/>
  • 5. float:浮点值

属性定义:

           <declare-styleable name = "HavorldAttribute">  
               <attr name = "fromAlpha" format = "float" />  
               <attr name = "toAlpha" format = "float" />  
           </declare-styleable>  

属性使用:

         <alpha  
           havorld:fromAlpha ="1.0"  
           havorld:toAlpha ="0.7"/>  
  • 6. integer:整型值

属性定义:

           <declare-styleable name = "HavorldAttribute">  
               <attr name = "frameDuration" format="integer" />  
               <attr name = "framesCount" format="integer" />  
           </declare-styleable>  

属性使用:

           <animated-rotate  
                havorld:framesCount ="12"    
                havorld:frameDuration ="100"  />  
  • 7. string:字符串

属性定义:

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

属性使用:

           <com.google.android.maps.MapView  
                 android:layout_width = "match_parent"  
                 android:layout_height= "match_parent"  
                 havorld:apiKey ="0jOkQ80oD1JL9C6HAja99uGXCRiS2CGjKO_bc_g"/>  
  • 8.fraction:百分数

属性定义:

          <declare-styleable name=" HavorldAttribute ">  
               <attr name = "pivotX" format = "fraction" />  
               <attr name = "pivotY" format = "fraction" />  
          </declare-styleable>  

属性使用:

          <rotate  
  android:interpolator = "@anim/动画ID"  
    havorld:pivotX ="200%"  
    havorld:pivotY ="300%" />  
  • 9. enum:枚举值

属性定义:

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

属性使用:

          <LinearLayout  
            havorld:orientation ="vertical"  
            android:layout_width = "match_parent"  
            android:layout_height = "match_parent"/>                   
          </LinearLayout>  
  • 10.flag:位或运算

属性定义:

           <declare-styleable name="HavorldAttribute">  
              <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>  

属性使用:

           <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>  

PS: 属性定义时可以指定多种类型值 如

属性定义:

<declare-styleable name = "HavorldAttribute">  
       <attr name = "background" format = "reference|color"/>  
</declare-styleable>  

属性使用:

<ImageView  
    android:layout_width = "42dip"  
    android:layout_height= "42dip"  
    havorld:background ="@drawable/图片ID|#00FF00"/> 
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Cannot initialize RTSP codec context: " << av_err2str(ret) << endl; return 1; } ret = av好的,这是一个关于自定义控件属性的问题。在 Android ,我们可以通过自定义属性自定义codec_open2(rtsp_codec_ctx, rtsp_codec, NULL); if (ret < 0) { cout << "Cannot控件提供一些可配置的属性值。想要调用自定义控件并设置其属性值,可以按照 open RTSP codec: " << av_err2str(ret) << endl; return 1; } // 打开HTTP-以下步骤进行: 1. 在 res/values/attrs.xml 定义自定义属性,例如: ```xml <resources> <declare-styleable name="CustomView"> <attr name="customAttr" format="string" /> </declare-styleable> </resourcesFLV地址 avformat_alloc_output_context2(&http_flv_ctx, NULL, "flv", http_flv_url); > ``` 这里定义了一个名为 CustomView 的自定义属性集合,其包含一个名为 customAttr属性 if (http_flv_ctx == NULL) { cout << "Cannot allocate HTTP-FLV output context" << endl; return,格式为字符串。 2. 在自定义控件的构造函数,通过 AttributeSet 获取自定义属性的值,例如: 1; } // 查找HTTP-FLV编码器 http_flv_codec = avcodec_find_encoder_by_name```java public class CustomView extends View { private String customAttrValue; public CustomView(Context context, AttributeSet attrs) { ("libx264"); if (http_flv_codec == NULL) { cout << "Cannot find encoder for codec libx264 super(context, attrs); TypedArray a = context.obtainStyledAttributes(attrs, R.styleable.CustomView); customAttrValue = a" << endl; return 1; } // 添加HTTP-FLV流 AVStream* stream = avformat_new.getString(R.styleable.CustomView_customAttr); a.recycle(); } } ``` 这里通过 TypedArray 获取自定义属性值,注意_stream(http_flv_ctx, NULL); if (stream == NULL) { cout << "Cannot create new stream for HTTP-FL需要使用 R.styleable.CustomView 来获取自定义属性集合,并使用 a.recycle() 回收 TypedArray。 3. 在布局文件V output" << endl; return 1; } // 设置HTTP-FLV编码器上下文参数 使用自定义控件,并设置自定义属性值,例如: ```xml <com.example.CustomView android:layout_width http_flv_codec_ctx = avcodec_alloc_context3(http_flv_codec); if (http_flv_codec_ctx == NULL) { ="wrap_content" android:layout_height="wrap_content" app:customAttr="someValue" /> ``` 这里通过 app cout << "Cannot allocate codec context for encoder libx264" << endl; return 1; } http_flv_codec:customAttr 设置自定义属性的值。 希望这个回答能够解决你的问题。如果还有疑问,请随提出。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值