自定义控件实现点状进度条

转载请注明本文地址:
http://blog.csdn.net/springcoder/article/details/52296036

本来最近做一个项目想找个不一样点的progressbar,然后看到了一个四点状的progressbar不过需要金币才能下载,算了反正也写的不是那么的适用,干脆直接自己写一个吧。我写东西喜欢封装的过瘾点,多来点set方法给以后用的人自己set去,于是他们只做了点的我就一定做个既可以空心也可以实心的,还可以改变点的数目颜色的,于是花了一个小时左右的时间,写了这个东东

一。废话不多说,先上效果图

这里写图片描述

这里写图片描述

这里写图片描述

这里写图片描述

二。具体代码

一。首先自定义一个点

这个点可以是空心的,也可以是实心的,其实就是一个圆圈,在这里我们给他的属性有,颜色,半径,是否是空心的还是实心的,还有空心的那么线条的粗细是多少呢,这里我是写的是用半径除以6 ,看起来效果还不错,嗯就用他了


import android.graphics.Canvas;
import android.graphics.Paint;
import android.icu.text.DateFormat;

/**
 * Created by sunshine on 2016/8/23.
 */
public class Dot {
   
    /**
     * 圆点的坐标
     */
    private  double x;
    private double y;
    private float radious;
    /**
     * 圆圈的中心是不是满的
     */
    private boolean isFill;
    private Paint paint;
    private int color;

    /**
     *  默认的空虚圆圈的边线宽是三
     * @param x
     * @param y
     * @param radious
     * @param color
     */
    public Dot(double x, double y, float radious, int color) {
        this.x = x;
        this.y = y;
        this.radious = radious;
        this.color = color;
        isFill=true;
        paint=new Paint();

    }

    public double getX() {
        return x;
    }

    public void setX(float x) {
        this.x = x;
    }

    public double getY() {
        return y;
    }

    public void setY(float y) {
        this.y = y;
    }

    public float getRadious() {
        return radious;
    }

    public void setRadious(float radious) {
        this.radious = radious;
    }

    public int getColor() {
        return color;
    }

    public void setColor(int color) {
        color = color;
    }

    public void setLovation(float x,float y){
        this.x=x;
        this.y=y;
    }
    public void drawSelf(Canvas canvas){
        if(isFill){
            paint.setStyle(Paint.Style.FILL);
        }else{
            paint.setStyle(Paint.Style.STROKE);
            paint.setStrokeWidth(radious/6);
        }
        paint.setColor(color);
        //设置抗锯齿
        paint.setAntiAlias(true);
        canvas.drawCircle((float)x,(float)y,radious,paint);
    }

    public boolean 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
自定义控件是指开发者根据自己的需求和设计来创建一种新的控件,以便在应用程序中使用。环形进度条是一种常见的自定义控件,它以环形的形式展示进度状态。在Qt中,可以通过以下步骤来创建一个环形进度条自定义控件: 1. 创建一个新的Qt自定义控件类,例如"CustomCircularProgressBar"。这个类应该继承自QWidget或QProgressBar类。QWidget提供了基本的窗口功能,而QProgressBar是一个进度条控件。 2. 在自定义控件类的头文件中,定义私有成员变量来存储进度条的当前值和最大值,并声明一些用于设置和获取这些值的公有方法。 3. 重写自定义控件类的绘图事件函数paintEvent(QPaintEvent *event),在这个函数中绘制环形进度条的外观。可以使用Qt的绘图工具类QPainter来绘制圆形和弧线,并根据当前值和最大值计算出进度的角度。 4. 实现自定义控件类的公有方法,用于设置和获取进度条的当前值和最大值。在这些方法中,更新私有成员变量的值,并调用update()函数来触发控件的重绘。 5. 在应用程序中使用自定义控件类。在Qt的设计工具中,将自定义控件拖放到主窗口或其他需要显示环形进度条的地方,并调用相应的公有方法来设置进度条的值。 通过以上步骤,就可以创建一个自定义的环形进度条控件。开发者可以根据自己的需求,进一步扩展和定制这个控件,例如添加动画效果、改变颜色和样式等。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值