java - 如何在android中制作离散的搜索/进度条?

标签 java android progress-bar seekbar stepper

如何在 Android 中像步进器一样制作离散进度/搜索栏。就像我们在 Whatsapp 状态故事中看到的那样。

enter image description here

最佳答案

虽然它是由很多库实现的,但我需要在不使用库的情况下实现它。

我使用水平线性布局中的 View ,并根据需要显示的部分数量或状态故事数量动态划分它。

activity_main.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:gravity="center"
    android:orientation="vertical"
    tools:context=".MainActivity">

<LinearLayout
    android:id="@+id/layout_views"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:layout_marginBottom="8dp"
    android:orientation="horizontal"
    android:padding="4dp" />

<Button
    android:id="@+id/button"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_marginTop="32dp"
    android:text="Click" />

</LinearLayout>

MainActivity.java

public class MainActivity extends AppCompatActivity {
String TAG = "MainActivity";
Button mButton;
int x=0,height,width,numberOfSections;
LinearLayout layoutViews;
ArrayList<View> viewsList =new ArrayList<>();

@SuppressLint("ClickableViewAccessibility")
@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);

    //findviews
    layoutViews = findViewById(R.id.layout_views);
    mButton = (Button) findViewById(R.id.button);

    //for getting dimensions of screen
    DisplayMetrics displayMetrics = new DisplayMetrics();
    getWindowManager().getDefaultDisplay().getMetrics(displayMetrics);
    height = displayMetrics.heightPixels;
    width = displayMetrics.widthPixels;

    //suppose we have to cut section into 4 parts
    numberOfSections = 10;
    width -= (16 + 16*numberOfSections);    //reducing length of layout by 16dp from left and right and in between 16dp {in between*number of sections)
    width /= numberOfSections;
    for(int i=0;i<numberOfSections;i++){
        View v = new View(this);
        LinearLayout.LayoutParams params = new LinearLayout.LayoutParams(width, 10);
        params.setMargins(16,0,0,0);    //giving 16dp internal margin between two views
        v.setLayoutParams(params);
        viewsList.add(v);   //adding views in array list for changing color on click of button

        v.setBackgroundColor(getResources().getColor(colorAccent));
        layoutViews.addView(v);
    }
    //button onclick function
    mButton.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View view) {
                buttonClick();
        }
    });
}

public void buttonClick(){
   viewsList.get(x).setBackgroundColor(getResources().getColor(colorPrimaryDark));
   x++;
  }
 }

Voyella!尽管您可以在 View 中添加过渡动画,但您已经制作了这个动态故事进度条。

关于java - 如何在android中制作离散的搜索/进度条?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/61186347/

相关文章:

android - 如何调试未直接集成到 APK 应用程序中的 android native 可执行文件和库

java - Gradle 任务 assembleDebug 失败,退出代码为 1(运行时异常)

java - 加载另一个 JFrame 类的进度条

java - 如何使用 Spring 中 R2dbc 提供的 Mono<Connection> 或 DatabaseClient 处理可为 null 的字段?

java - Spring中json中的斜杠是什么

java - 算术运算符不能应用于 IntStream

java - EditText 输入金额

ios - AWS SDK iOS - 如何确定上传请求的完成百分比

java - 如何使用Java获取上传到Amazon S3的文件的进度状态

java - 在 java spring hibernate 的 userDAO 类中写什么东西