Skip to content

xiangcman/360Downloading-master

Repository files navigation

最近在学习android的高级view的绘制,再结合值动画的数据上的改变,自己撸了个360手机助手的下载按钮。先看下原版的360手机助手的下载按钮是长啥样子吧:

360下载按钮效果图.gif

再来看看自己demo吧,你们尽情的吐槽吧,哈哈:

修改loading状态下的运动点最高点和最低点.gif

属性也没怎么整理,就抽取出了一些比较常用的几个了:

属性名 类型 描述
status_text_size dimension 状态以及显示百分比的字体大小
status_text_color color 状态的颜色
load_point_color     color load状态下移动的点的颜色
bg_color color 整个背景的颜色
progress_color color 进度的颜色
collect_speed integer 背景收缩的时间
collect_rotate_speed integer 背景收缩后中间的load转一圈需要的时间
expand_speed integer 收缩后背景展开的时间
right_loading_speed integer loading状态下右边的loading每一次转动时增加的角度
left_loading_speed integer 左边运动的几个点走一次需要的时间
cancel_back_icon reference 取消按钮用到的背景图
stop_back_icon reference 暂停按钮用到的背景图
continue_back_icon reference 继续按钮用到的背景图

代码使用:

项目中直接使用的view:

<com.library.downloading.Down360ViewGroup
        android:id="@+id/down_loading_viewgroup"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_gravity="bottom"
        app:bg_color="#33CCFF"
        app:cancel_back_icon="@mipmap/close"
        app:continue_back_icon="@mipmap/play"
        app:left_loading_speed="2500"
        app:right_loading_speed="8"
        app:status_text_color="#cccccc"
        app:stop_back_icon="@mipmap/stop" />

效果图如下:

final_simple_gif.gif

供调用的方法有如下:

取消下载:
setCancel();

设置进度:
setProgress(int progress);

设置状态(status:Down360Loading.Status.Normal直接可以取消的操作):
setStatus(Status status);

设置暂停或继续:
setStop(stop:true表示暂停;stop:false表示继续);

接口监听:
public interface OnProgressStateChangeListener {
    void onSuccess();

    //暂停
    void onStop();

    //取消
    void onCancel();

    //继续
    void onContinue();
}

gradle依赖:

allprojects {
    repositories {
        ...
        maven { url 'https://jitpack.io' }
    }
}

dependencies {
        ...
        compile 'com.github.1002326270xc:360Downloading-master:v1.3.1'
        ...
}

好了介绍就到这里了,如果觉得行的话,点个star吧,谢谢!!!

如果发现有什么问题,请联系我,我会第一时间给出反馈!!!

欢迎客官到本店光临:184793647(qq群)

关于我:

email: a1002326270@163.com

csdn:enter

简书:enter