广告
返回顶部
首页 > 资讯 > 精选 >怎么自定义View视图的属性及引用
  • 633
分享到

怎么自定义View视图的属性及引用

2023-07-05 20:07:20 633人浏览 泡泡鱼
摘要

今天小编给大家分享一下怎么自定义View视图的属性及引用的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。一、创建一个类,继承V

今天小编给大家分享一下怎么自定义View视图的属性及引用的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。

一、创建一个类,继承View

会提示我们添加构造方法,它拥有4个,我们起码要用2个,如下

怎么自定义View视图的属性及引用

二、如何创建自定义属性呢?

2-1:创建一个资源文件

怎么自定义View视图的属性及引用

创建成功

怎么自定义View视图的属性及引用

2-2:打开我们创建好的资源文件,来写我们需要的属性,我简单的写了两个,如图:

怎么自定义View视图的属性及引用

注意:自定义属性的过程及属性和对应的类别

>自定义属性:1. reference:参考某一资源ID,以此类推(1)属性定义:<declare-styleable name = "名称"><attr name = "background" fORMat = "reference" /></declare-styleable>(2)属性使用:<ImageViewAndroid:layout_width = "42dip"android:layout_height = "42dip"android:background = "@drawable/图片ID"/>2. color:颜色值<declare-styleable name = "名称"><attr name = "textColor" format = "color" /></declare-styleable>3. boolean:布尔值<declare-styleable name = "名称"><attr name = "focusable" format = "boolean" /></declare-styleable>4. dimension:尺寸值。注意,这里如果是dp那就会做像素转换<declare-styleable name = "名称"><attr name = "layout_width" format = "dimension" /></declare-styleable>5. float:浮点值。6. integer:整型值。7. string:字符串8. fraction:百分数。9. enum:枚举值10. flag:是自己定义的,类似于 android:gravity="top",就是里面对应了自己的属性值。11. reference|color:颜色的资源文件。12.reference|boolean:布尔值的资源文件

三、如何引用我们的自定义的资源

可以通过TypedArray 类来接受我们自定义的属性,也可以在xml中来指定我们自定义的属性

3-1:在代码中引用

public class ViewDemo extends View {    public ViewDemo(Context context) {        super(context);    }    public ViewDemo(Context context, AttributeSet attrs) {        super(context, attrs);                TypedArray typedArray = context.obtainStyledAttributes(attrs,R.styleable.Myview);        int colors =typedArray.getColor(R.styleable.Myview_rect_color,0xffff0000);//给他赋值一个红色        setBackgroundColor(colors);        typedArray.recycle();    }}

引用后设置为颜色为红色,我们布局中的组件就会变成红色

怎么自定义View视图的属性及引用

3-2:引用我们的资源?

我们还可以在我们的布局中直接引用我们的属性,如下

<?xml version="1.0" encoding="utf-8"?><LinearLayout xmlns:android="Http://schemas.android.com/apk/res/android"    xmlns:attrs_ViewDemo="http://schemas.android.com/apk/res/tester.ermu.com.viewtext"    xmlns:tools="http://schemas.android.com/tools"    android:id="@+id/activity_main"    android:orientation="vertical"    android:layout_width="match_parent"    android:layout_height="match_parent"    tools:ignore="ResAuto">    <tester.ermu.com.viewtext.ViewDemo        android:layout_width="match_parent"        android:layout_height="50dp"        attrs_ViewDemo:rect_color = "#ff00ff00"/></LinearLayout>

运行效果,已经覆盖红色

怎么自定义View视图的属性及引用

附上所有的代码 MainActivity

package tester.ermu.com.viewtext;import android.app.Activity;import android.os.Bundle;public class MainActivity extends Activity {    @Override    protected void onCreate(Bundle savedInstanceState) {        super.onCreate(savedInstanceState);        setContentView(R.layout.activity_main);    }}

ViewDemo

package tester.ermu.com.viewtext;import android.content.Context;import android.content.res.TypedArray;import android.util.AttributeSet;import android.view.View;public class ViewDemo extends View {    public ViewDemo(Context context) {        super(context);    }    public ViewDemo(Context context, AttributeSet attrs) {        super(context, attrs);                TypedArray typedArray = context.obtainStyledAttributes(attrs,R.styleable.Myview);        int colors =typedArray.getColor(R.styleable.Myview_rect_color,0xffff0000);//给他赋值一个红色        setBackgroundColor(colors);        typedArray.recycle();    }}

main布局

<?xml version="1.0" encoding="utf-8"?><RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"    xmlns:tools="http://schemas.android.com/tools"    android:id="@+id/activity_main"    android:layout_width="match_parent"    android:layout_height="match_parent"    android:paddingBottom="@dimen/activity_vertical_margin"    android:paddingLeft="@dimen/activity_horizontal_margin"    android:paddingRight="@dimen/activity_horizontal_margin"    android:paddingTop="@dimen/activity_vertical_margin"    tools:context="tester.ermu.com.viewtext.MainActivity">    <include       layout="@layout/activity_viewdemo" /></RelativeLayout>

自定义view布局

<?xml version="1.0" encoding="utf-8"?><LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"    xmlns:attrs_ViewDemo="http://schemas.android.com/apk/res/tester.ermu.com.viewtext"    xmlns:tools="http://schemas.android.com/tools"    android:id="@+id/activity_main"    android:orientation="vertical"    android:layout_width="match_parent"    android:layout_height="match_parent"    tools:ignore="ResAuto">    <tester.ermu.com.viewtext.ViewDemo        android:layout_width="match_parent"        android:layout_height="50dp"        attrs_ViewDemo:rect_color = "#ff00ff00"/></LinearLayout>

自定义属性资源

<?xml version="1.0" encoding="utf-8"?><resources>    <!--我们自定义的属性,名字为Myview,attr是其中属性的意思,format时指定这条属性是属于什么类型-->    <declare-styleable name="Myview">        <attr name="rect_color" format="color"></attr>        <attr name="rect_text" format="reference"></attr>    </declare-styleable></resources>

以上就是“怎么自定义View视图的属性及引用”这篇文章的所有内容,感谢各位的阅读!相信大家阅读完这篇文章都有很大的收获,小编每天都会为大家更新不同的知识,如果还想学习更多的知识,请关注编程网精选频道。

--结束END--

本文标题: 怎么自定义View视图的属性及引用

本文链接: https://www.lsjlt.com/news/355324.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 怎么自定义View视图的属性及引用
    今天小编给大家分享一下怎么自定义View视图的属性及引用的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。一、创建一个类,继承V...
    99+
    2023-07-05
  • 图文详解自定义View视图的属性及引用
    目录一、创建一个类,继承View二、如何创建自定义属性呢?2-1:创建一个资源文件2-2:打开我们创建好的资源文件,来写我们需要的属性,我简单的写了两个,如图:三、如何引用我们的自定...
    99+
    2023-05-14
    自定义View 自定义视图 View属性引用
  • 自定义视图view的折线图怎么使用
    这篇文章主要讲解了“自定义视图view的折线图怎么使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“自定义视图view的折线图怎么使用”吧!绘制折线图预览图绘制这个折线图需要都需要哪些步骤?...
    99+
    2023-07-05
  • 自定义视图view的折线图使用讲解
    目录一、如何绘制X和Y轴。1、我们来分析下,我们想知道三个坐标,那么这三个坐标是多少呢,我们该怎么计算呢? 答:这里,我是在onSizeChanged()方法中获取到了父类控件的宽度...
    99+
    2023-05-14
    自定义视图 自定义view 自定义view折线图
  • 自定义视图View绘图基础之Path的使用
    目录使用Path绘制线一、我们这里绘制了7条线来分别介绍上面的几种子类都有什么用二、不难看出其中每条线的属性和样式不一样,我在上面有 了很详细的讲解。三、xxxTo()方法绘制(本章...
    99+
    2023-05-14
    自定义视图 自定义View 自定义视图 Path使用
  • 自定义视图view怎么实现环形进度条
    这篇文章主要介绍“自定义视图view怎么实现环形进度条”,在日常操作中,相信很多人在自定义视图view怎么实现环形进度条问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”自定义视图view怎么实现环形进度条”的疑...
    99+
    2023-07-05
  • HTML5自定义属性前缀data-及dataset怎么用
    这篇文章主要介绍了HTML5自定义属性前缀data-及dataset怎么用,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。HTML5规定可以为...
    99+
    2022-10-19
  • HTML5的自定义属性data怎么用
    这篇文章主要介绍了HTML5的自定义属性data怎么用的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇HTML5的自定义属性data怎么用文章都会有所收获,下面我们一起来看看吧。...
    99+
    2022-10-19
  • html5自定义属性怎么使用
    这篇文章主要介绍了html5自定义属性怎么使用的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇html5自定义属性怎么使用文章都会有所收获,下面我们一起来看看吧。 ...
    99+
    2022-10-19
  • 怎么自定义视图view使用Canvas实现手写板和涂鸦功能
    本文小编为大家详细介绍“怎么自定义视图view使用Canvas实现手写板和涂鸦功能”,内容详细,步骤清晰,细节处理妥当,希望这篇“怎么自定义视图view使用Canvas实现手写板和涂鸦功能”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入...
    99+
    2023-07-05
  • HTML5中data-* 自定义属性怎么用
    这篇文章主要为大家展示了“HTML5中data-* 自定义属性怎么用”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“HTML5中data-* 自定义属性怎么用”这篇文章吧。在jQuery的attr...
    99+
    2023-06-09
  • Spring Cloud自定义引导属性源的方法是什么
    本篇内容介绍了“Spring Cloud自定义引导属性源的方法是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!引导过程添加的外部配置的默...
    99+
    2023-06-05
  • vue中标签自定义属性的使用及说明
    目录vue标签自定义属性使用举个例子vue自定义属性的设置及获取vue中设置自定义属性及获取总结vue标签自定义属性使用 在 vue 中,尽量避免对dom的操作,通过对状态的管理实现...
    99+
    2023-05-19
    vue标签 vue标签自定义属性 vue定义属性
  • CSS的caption-side属性怎么定义使用
    这篇文章主要介绍了CSS的caption-side属性怎么定义使用的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇CSS的caption-side属性怎么定义使用文章都会有所收获,下面我们一起来看看吧。CSS c...
    99+
    2023-07-04
  • CSS的padding属性怎么定义和使用
    这篇文章主要讲解了“CSS的padding属性怎么定义和使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“CSS的padding属性怎么定义和使用”吧!CSS padding 属性定义和用法...
    99+
    2023-07-04
  • HTML5怎么自定义data-* data(obj)属性和jquery的data()方法
    本篇内容介绍了“HTML5怎么自定义data-* data(obj)属性和jquery的data()方法”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理...
    99+
    2022-10-19
  • CSS的padding-bottom属性怎么定义和使用
    这篇文章主要讲解了“CSS的padding-bottom属性怎么定义和使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“CSS的padding-bottom属性怎么定义和使用”吧!CSS p...
    99+
    2023-07-04
  • Vue中的自定义指令有哪些及怎么使用
    本篇内容主要讲解“Vue中的自定义指令有哪些及怎么使用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Vue中的自定义指令有哪些及怎么使用”吧!1、什么是自定义指令vue 官方提供了 v-text...
    99+
    2023-06-30
  • Java拦截器以及自定义注解的使用是怎么样的
    Java拦截器以及自定义注解的使用是怎么样的,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。1,设置预处理,设置不需要拦截的请求@Componentpublic cla...
    99+
    2023-06-22
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作