Android自定义自定义StepView仿外卖配送进度仿外卖配送进度
主要为大家详细介绍了Android自定义StepView仿外卖配送进度,具有一定的参考价值,感兴趣的小伙伴们可以
参考一下
本文实例为大家分享了Android自定义StepView配送进度展示的具体代码,供大家参考,具体内容如下
效果图效果图
使用使用
可在layout文件下设置以下属性。
<?xml version="1.0" encoding="utf-8"?>
<resources>
<declare-styleable name="StepView">
<attr name="step_size" format="dimension"/><!--step的size,也就是image的大小-->
<attr name="line_size" format="dimension"/><!--线宽-->
<attr name="text_size" format="dimension"/><!--文字大小-->
<attr name="text_line_margin" format="dimension"/><!--文字和线之间的间距-->
<attr name="normal_line_color" format="color"/><!--一般线的颜色-->
<attr name="normal_text_color" format="color"/><!--一般文字的颜色-->
<attr name="target_text_color" format="color"/><!--一般文字的颜色-->
<attr name="passed_line_color" format="color"/><!--已经过线的颜色-->
<attr name="step_count" format="integer"/><!--总step数-->
<attr name="current_step" format="integer"/><!--当前step位置-->
<attr name="normal_step_iv" format="reference"/><!--一般图片-->
<attr name="passed_step_iv" format="reference"/><!--已经过的图片-->
<attr name="target_step_iv" format="reference"/><!--当前step图片-->
<attr name="step_is_touch" format="boolean"/><!--step是否可点-->
<attr name="text_up_line" format="boolean"/><!--文字是否在线上-->
</declare-styleable>
</resources>
CheckBox cbTouch = findViewById(R.id.cb_touch);
CheckBox cbIsDown = findViewById(R.id.cb_is_down);
final StepView stepView = findViewById(R.id.step_view);
String[] stepTexts = new String[]{"订单已提交", "商家已接单", "配送中", "已送达"};
stepView.setStepTexts(stepTexts);//传入每一进度的文字描述
stepView.setCurrentStep(2);//设置当前进度所在位置
stepView.setOnItemStepTouchListener(new StepView.OnItemStepTouchListener() {
@Override
public void onItemStepTouch(int postion) {
Log.d(TAG, "当前点击位置: "+postion);
}
});
cbTouch.setOnCheckedChangeListener(new CompoundButton.OnCheckedChangeListener() {
@Override
public void onCheckedChanged(CompoundButton buttonView, boolean isChecked) {
stepView.setStepIsTouch(isChecked);
}
});
cbIsDown.setOnCheckedChangeListener(new CompoundButton.OnCheckedChangeListener() {
@Override
public void onCheckedChanged(CompoundButton buttonView, boolean isChecked) {
stepView.setTextUpLine(!isChecked);
}
});
步骤步骤