一个简单的时间线控件,采用 RecyclerView 实现,无任何三方依赖库,一个纯净的库

TimeLine

项目地址:rangaofei/TimeLine 

简介:simple timeline

更多:作者   提 Bug   

标签:

 

一个简单的时间线控件,采用 RecyclerView 实现,无任何三方依赖库,一个纯净的库。主要特性:

  1. 可定制 timeline 的 icon 图标,每个图标可以通过 list 作为参数传入
  2. 可定制 item 布局,每个 item 中的 view 都可通过 anchor 注解来设置不同的 style
  3. 支持时间线的前景色和后景色,采用 src_in 方式覆盖
  4. 时间线进度可随意控制,可以实现 10%,15%,96%等进度
  5. 采用编译期注解,在运行期未使用反射
  6. 支持四种时间线位置,item 大小不同时会自动进行位置对齐。比如时间线在上方,所有的 item 会自动顶部对齐。
  7. 支持三种时间线模式

看两张效果图,仿淘宝退款,和一个不太标准的仿慕课:

 

0.2.4 更新:

新增可以控制 icon 大小的属性:

app:timeLineIconHeight="30dp"
app:timeLineIconWidth="30dp"

新增样式

app:strokeType="midEndPoint"

如图:

未设置该大小时会自动设置成为 timePadding 的三分之二;当其中一个设置另一个未设置时, 未设置的值会自动设置成为已设置的值。

可以设置 dividerNum 为浮点型,会自动调整进度,这种形式在 noEndPoint 模式下工作最好。

集成方式

    implementation 'com.rangaofei:sakatimeline:0.2.4'
    annotationProcessor 'com.rangaofei:JavaTimeLine:0.2.4'

然后修改 app 级别的 module 的 build.gradle 文件:

android {

    defaultConfig {

        //省略代码
        javaCompileOptions{
            annotationProcessorOptions.includeCompileClasspath=true
        }
    }
}

假如没出现问题的话就集成成功了

使用 StepView

StepView 基于注解

StepView 内部使用 apt 处理注解实现了 adapter,adapter 包含两种布局,key 和 value。目前推出的只需要使用 value 布局即可。

首先要定义一个 model,这个 model 要编写一些注解

@TimeLine(valueLayoutId = "R.layout.item_value")
public class StepViewModel {

    @TimeLineTextView(key = false, value = "R.id.value")
    public String text;

    public StepViewModel(String text) {
        this.text = text;
    }

    public String getText() {
        return text;
    }

    public void setText(String text) {
        this.text = text;
    }
}

注意,每个变量必须采用 public 修饰,否则获取不到变量的值(其实是目前我没有做任何 getter 和 setter 方法)

然后先 build 一次,在需要使用 model 的时候要写入

private AbstractTimeLineAdapter adapter;

private List<StepViewModel> stepViewModels = new ArrayList<>();

系统会自动生成一个 StepViewModelViewAdapter 文件,这个 adapter 需要传入一个 list 作为数据源, 这个 list 中的 item 类型必须设置为被标注为 TimeLine 的类。

stepViewModels.add(new StepViewModel("快递发出"));
stepViewModels.add(new StepViewModel("快递签收"));
stepViewModels.add(new StepViewModel("快递丢失"));
adapter = new StepViewModelAdapter(stepViewModels);
binding.tlv.setTimeLineConfig(adapter, TimeLineType.StepViewType.RIGHT_STEP_PROGRESS);

这样我们就完成了基本设置。 运行可以看到效果图:

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
实现一百个格子的进度,可以通过RecyclerView实现。下面是实现的步骤: 1. 首先在布局文件中添加一个RecyclerView控件,设置其方向为垂直方向。 2. 创建一个Adapter类继承RecyclerView.Adapter,实现其中的onCreateViewHolder、onBindViewHolder和getItemCount方法。 3. 在Adapter的onCreateViewHolder方法中创建一个ViewHolder对象,该对象包含一个TextView用于显示进度。 4. 在Adapter的onBindViewHolder方法中根据position设置对应ViewHolder的TextView的文字内容,可以用随机数模拟进度。 5. 在Activity或Fragment中获取RecyclerView控件,并设置其Adapter为上一步创建的Adapter对象。 6. 最后运行程序即可看到一百个格子的进度。 以下是示例代码实现: Adapter代码: ```java public class ProgressAdapter extends RecyclerView.Adapter<ProgressAdapter.ViewHolder> { private int mCount; public ProgressAdapter(int count) { mCount = count; } @NonNull @Override public ViewHolder onCreateViewHolder(@NonNull ViewGroup parent, int viewType) { View view = LayoutInflater.from(parent.getContext()).inflate(R.layout.item_progress, parent, false); return new ViewHolder(view); } @Override public void onBindViewHolder(@NonNull ViewHolder holder, int position) { holder.mProgressText.setText("进度:" + new Random().nextInt(101) + "%"); } @Override public int getItemCount() { return mCount; } static class ViewHolder extends RecyclerView.ViewHolder { TextView mProgressText; ViewHolder(@NonNull View itemView) { super(itemView); mProgressText = itemView.findViewById(R.id.progress_text); } } } ``` 布局文件item_progress.xml: ```xml <TextView xmlns:android="http://schemas.android.com/apk/res/android" android:id="@+id/progress_text" android:layout_width="match_parent" android:layout_height="wrap_content" android:gravity="center" android:padding="16dp" android:textSize="20sp" /> ``` Activity中的代码: ```java public class MainActivity extends AppCompatActivity { private RecyclerView mRecyclerView; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); mRecyclerView = findViewById(R.id.recycler_view); mRecyclerView.setLayoutManager(new LinearLayoutManager(this, RecyclerView.VERTICAL, false)); ProgressAdapter adapter = new ProgressAdapter(100); mRecyclerView.setAdapter(adapter); } } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值