view与viewgroup

. Android的基本组件
1.1 Activity
1.1.1 Activity代表手机的一个屏幕
1.1.2 一个Android程序由多个Activity组成,即:一个Android程序由多屏内容组成
1.1.3 Activity相当于一个展板,本身没有可视的内容,你把画(View)贴到展板上就可以展示出来了
1.2 Service
1.2.1 不可见的组件
1.2.2 在后台运行
1.2.3 为其他组件提供后台服务
1.2.4 监控其他组件的运行状态
1.2.5 后台播放音乐
1.3 BroadcastReceiver:广播消息监听器
1.3.1 作用:用来监听广播,eg:收短信的广播 往手机推送消息
1.4 ContentProvider:内容提供者
1.4.1 帮助不同的应用程序间交换数据,eg:获取通讯录信息
1.5 Intent和IntentFilter 意图
Activity、Service、BroadcastReceiver之间通信的载体,传递数据

  1. View和ViewGroup介绍
    View类似于swing中的JPanel,代表一个空白的矩形区域,Android应用中的绝大部分UI组件都继承于View或其子类
    View还一个重要的子类ViewGroup,它通常作为其它组件的[容器]使

    简单来讲View是所有控件的父控件,ViewGroup可以包含其它的View对象,并且是所有布局控件的父类
    Activity相当于一个展板,本身没有可视的内容,你把画(View)贴到展板上就可以展示出来了
    setContentView(view)

.Paint的应用

public class MyView extends View {
     private Paint paint;//定义画笔
     public MyView(Context context) {
        super(context);
        paint = new Paint();//实现画笔
        paint.setColor(Color.RED);//画笔颜色,红色
        paint.setStyle(Paint.Style.STROKE);//画笔为空心
         //该方法即为设置基线上那个点究竟是left,center,还是right  这里我设置为center
         paint.setTextAlign(Paint.Align.CENTER);
//         paint.setStyle(Paint.Style.FILL);//画笔为实心
    }
        @Override
    protected void onDraw(Canvas canvas) {
        super.onDraw(canvas);
//        canvas.drawCircle(200,200,100,paint);//画圆

//        Path path = new Path();
//        path.moveTo(100,100);//将起始点设置到x,y点,相当于设置一个点
//        path.lineTo(200,200);//从当前点绘制一条线段到x,y点
//        path.lineTo(100,200);
//        path.lineTo(100,100);
//        canvas.drawPath(path,paint);//三角形实心方法
//        canvas.drawLine(300,300,400,400,paint);//三角形空心方法
//        paint.setStrokeWidth(10);//画笔粗细
        String hh="中华人民共和国万岁";//定义一个字符串
        canvas.drawText(hh,500,400,paint);
        //凹形
//        path.moveTo(200,200);
//        path.lineTo(300,200);
//        path.lineTo(300,300);
//        path.lineTo(400,300);
//        path.lineTo(400,200);
//        path.lineTo(500,200);
//        path.lineTo(500,500);
//        path.lineTo(200,500);
//        path.close();
//        canvas.drawPath(path,paint);

        //凸形
//        Path path1 = new Path();
//        path1.moveTo(300,600);
//        path1.lineTo(500,600);
//        path1.lineTo(500,800);
//        path1.lineTo(700,800);
//        path1.lineTo(700,1100);
//        path1.lineTo(100,1100);
//        path1.lineTo(100,800);
//        path1.lineTo(300,800);
//        path1.close();
//        canvas.drawPath(path1,paint);

        Rect rect = new Rect(100,100,500,500);//画一个矩形
        Paint rectPaint = new Paint();
        rectPaint.setColor(Color.BLUE);
        rectPaint.setStyle(Paint.Style.FILL);
        canvas.drawRect(rect, rectPaint);

        Paint textPaint = new Paint();
        textPaint.setColor(Color.WHITE);
        textPaint.setTextSize(50);
        textPaint.setStyle(Paint.Style.FILL);
        //该方法即为设置基线上那个点究竟是left,center,还是right  这里我设置为center
        textPaint.setTextAlign(Paint.Align.CENTER);

        Paint.FontMetrics fontMetrics = textPaint.getFontMetrics();
        float top = fontMetrics.top;//为基线到字体上边框的距离,即上图中的top
        float bottom = fontMetrics.bottom;//为基线到字体下边框的距离,即上图中的bottom

        int baseLineY = (int) (rect.centerY() - top/2 - bottom/2);//基线中间点的y轴计算公式

        canvas.drawText("你好世界",rect.centerX(),baseLineY,textPaint);

//        Bitmap bitmap = BitmapFactory.decodeResource(getResources(),R.drawable.dog);//图片
//        canvas.drawBitmap(bitmap,400,100,paint);//图片显示的位置
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值