zoukankan      html  css  js  c++  java
  • android自定义控件(二) 入门,继承View

    转载请注明地址:http://blog.csdn.net/ethan_xue/article/details/7313788

    ps: 可根据apidemo里LableView,list4,list6学习

    文档在dev guide/Framework Topics/User Interface/Building Custom Components

    自定义控件的步骤:

    1 View的工作原理  2 编写View类  3 为View类增加属性  4 绘制屏幕  5 响应用户消息  6 自定义回调函数 

    不多说,主要是Canvas, Paint, Path

    1. public class CustomView1 extends View {  
    2.   
    3.     private Paint mPaint;  
    4.     // private static final String mText = "drawText";  
    5.     private String mText = "drawText";  
    6.   
    7.     public CustomView1(Context context, AttributeSet attrs) {  
    8.         super(context, attrs);  
    9.     }  
    10.   
    11.     @Override  
    12.     protected void onDraw(Canvas canvas) {  
    13.         super.onDraw(canvas);  
    14.         mPaint = new Paint();  
    15.         mPaint.setColor(Color.BLUE);  
    16.         // FILL填充, STROKE描边,FILL_AND_STROKE填充和描边  
    17.         mPaint.setStyle(Style.FILL);  
    18.         canvas.drawRect(new Rect(10, 10, 100, 100), mPaint);// 画一个矩形  
    19.   
    20.         mPaint.setColor(Color.GREEN);  
    21.         mPaint.setTextSize(35.0f);  
    22.         canvas.drawText(mText, 10, 60, mPaint);  
    23.     }  
    24.   
    25. }  



    布局

    1. <pre name="code" class="java"><?xml version="1.0" encoding="utf-8"?>  
    2. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"  
    3.     android:orientation="vertical"  
    4.     android:layout_width="fill_parent"  
    5.     android:layout_height="fill_parent"  
    6.     >  
    7. <ethan.customview1.CustomView1    
    8.     android:layout_width="wrap_content"   
    9.     android:layout_height="wrap_content"   
    10.     />  
    11. </LinearLayout></pre><pre name="code" class="java"></pre>  

    效果图

    注意,此时,在控件下放一个textView的话,是显示不出来的(TextView放在控件上面可以显示),以后再解决

    下载地址 http://download.csdn.net/detail/ethan_xue/4108820

  • 相关阅读:
    [数据结构]直接插入排序
    隐藏小程序scroll-view组件的滚动条
    当 uni-app 遇见 vscode
    npm(你怕吗) 全局安装与本地安装、开发依赖和生产依赖
    Vue-resource的使用
    spy-debugger调试、抓包工具
    一个小时学会Git
    flex布局踩过的坑
    Html5移动端布局及(rem布局)页面自适应布局详解
    使用vscode自动编译less
  • 原文地址:https://www.cnblogs.com/chengzhengfu/p/4574084.html
Copyright © 2011-2022 走看看