android自定义view之地图(一)

最近参加了一个比赛,要用到自己做一个自定义的小地图,所以在网上查找了一些关于自定义view的有关资料,也了解了自定义控件的初步知识。

效果图

第一阶段的效果图
第一阶段我画了一个自制的网格图,点哪个网格就会哪个网格就会显示。

工作环境图

这里写图片描述

代码介绍

1。我们都知道当使用android的原始控件时,每个控件都可以定义属性,比如android:id ,android:layout_width等等大家并不陌生的属性,有些属性是每个控件都有的比如上面两个,还有一些是控件自己有的。我们自定义的控件可以定义自己想要的属性,方便我们以后自己使用。

那就是在values目录下创建一个attrs.xml文件。

<?xml version="1.0" encoding="utf-8"?>
<resources>
    <declare-styleable name="MapView">
        <attr name="border_color" format="color" />
        <attr name="border_width" format="dimension" />
    </declare-styleable>
</resources>

这样就给我们的我们就给控件加了 border_color 和border_width 两个属性,在这里的format里定义的是我们的属性的值是什么类型,比如border_color是color,border_width是dimension,每个不同的数据类型对应不同的类型。

2.第二部分也是最重要的自定义控件的类。

首先我们的自定义类要继承View

public class CustomView extends View {
   
}

接下来我们完成view要实现的三个不同参数的构造函数,其中init是我们自己写的初始化信息的函数。在第二个构造函数中,我们获取了我们在attrs.xml中定义的值。

public CustomView(Context context) {
        super(context);
        //初始化信息
        init();
}

public CustomView(Context context, AttributeSet attrs) {
        super(context, attrs);

//获取我们自己的属性
        TypedArray typedArray = context.getTheme().obtainStyledAttributes(
                attrs, R.styleable.MapView, 0, 0);

        try {
            mBorderColor = typedArray.getColor(
                    R.styleable.MapView_border_color, 0xff000000);
            mBorderWidth = typedArray.getDimension(
                    R.styleable.MapView_border_width, 2);
        } finally {
            typedArray.recycle();
        }

        init();
    }
public CustomView(Cont
  • 1
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值