Индикатор выполнения не отображается при установке видимости на VISIBLE - PullRequest
0 голосов
/ 28 апреля 2018

Я создаю программу, которая должна отображать индикатор выполнения, когда она выполняет что-то в фоновом режиме (используя AsyncTask) и когда задача завершается, индикатор выполнения уходит и отображается результат.

Я включил индикатор выполнения в RecyclerView, но установил, что видимость пропала. и в AsyncTask PreExecute я установил его видимость на VISIBLE, а в OnPostExecute я установил его видимость на GONE, но когда я запускаю приложение, индикатор выполнения вообще не отображается.

Я включил XML:

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
app:layout_behavior="@string/appbar_scrolling_view_behavior"
tools:context=".MainActivity"
tools:showIn="@layout/activity_main">

<android.support.v4.widget.ContentLoadingProgressBar
    android:id="@+id/rv_progress_bar"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:indeterminate="true"
    android:indeterminateTint="@color/plus_icon_color"
    android:visibility="gone" />

<android.support.v7.widget.RecyclerView
    android:id="@+id/train_rv"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:scrollbars="vertical" />

и код Java:

public class MainActivity extends AppCompatActivity {
private RecyclerView mTrainsRv;
private TrainAdapter mTrainAdapter;
ArrayList<Train> trains = new ArrayList<>();
ProgressBar mRvProgress;

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar);
    setSupportActionBar(toolbar);

    mRvProgress = (ProgressBar)findViewById(R.id.rv_progress_bar);
    mTrainsRv = (RecyclerView) findViewById(R.id.train_rv);
    mTrainsRv.setLayoutManager(new LinearLayoutManager(this));
    mTrainAdapter = new TrainAdapter(createDefaultTrains());
    mTrainsRv.setAdapter(mTrainAdapter);

    FloatingActionButton fab = (FloatingActionButton) findViewById(R.id.fab);
    fab.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View view) {
            trains.add(new Train(4, "Berowra Platform 4", 12, "Late", "Beverly", "15:18"));
            mTrainAdapter.notifyDataSetChanged();
        }
    });
}

private List<Train> createDefaultTrains() {
    trains.add(new Train(0, "Albion Park Platform 1", 3, "On Time", "Allawah", "14:11"));
    trains.add(new Train(1, "Arncliffe Platform 2", 4, "Late", "Central", "14:34"));
    trains.add(new Train(2, "Artarmion Platform 3", 7, "On Time", "Ashfield", "15:01"));
    trains.add(new Train(3, "Berowra Platform 4", 12, "Late", "Beverly", "15:18"));
    return trains;
}

@Override
public boolean onCreateOptionsMenu(Menu menu) {
    // Inflate the menu; this adds items to the action bar if it is present.
    getMenuInflater().inflate(R.menu.menu_main, menu);
    return true;
}

@Override
public boolean onOptionsItemSelected(MenuItem item) {
    // Handle action bar item clicks here. The action bar will
    // automatically handle clicks on the Home/Up button, so long
    // as you specify a parent activity in AndroidManifest.xml.
    // Handle item selection
    switch (item.getItemId()) {
        case R.id.action_delete:
            trains.clear();
            mTrainAdapter.notifyDataSetChanged();
            return true;
        case R.id.action_refresh:
            new RefreshProgressAsync().execute();
            return true;
        case R.id.action_quit:
            Toast.makeText(this, R.string.quit_menu,
                    Toast.LENGTH_LONG).show();
            return true;
        default:
            return super.onOptionsItemSelected(item);
    }
}
private class RefreshProgressAsync extends AsyncTask<Void,Void,Integer> {
private int mGenerated;

    @Override
    protected Integer doInBackground(Void... voids) {
        try {
            Thread.sleep(3000);
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
        int ran = 0;
        Random r = new Random();
        for(int i=0; i<trains.size(); i++) {
            int min = 1;
            int max = 20;
            ran = r.nextInt(max - min + 1) + min;
            mGenerated = ran;
        }
        return mGenerated;
    }

    @Override
    protected void onPreExecute() {
        mRvProgress.setVisibility(View.VISIBLE);
        mTrainsRv.setAlpha(0);
        super.onPreExecute();
    }

    @Override
    protected void onPostExecute(Integer arrivalTime) {
        super.onPostExecute(arrivalTime);
        for (int i=0; i<trains.size();i++){
            trains.get(i).setArrivalTime(arrivalTime);
        }
        mTrainAdapter.notifyDataSetChanged();
        mTrainsRv.setAlpha(1);
        mRvProgress.setVisibility(View.GONE);
    }
}

Я не знаю, почему это не показывается. Спасибо

1 Ответ

0 голосов
/ 28 апреля 2018

Это ведет себя как ожидалось. Цель ContentLoadingProgressBar - показать прогресс только при необходимости. Если операция занимает тривиальное время, индикатор выполнения не отображается. Это необходимо для того, чтобы не иметь мигающего эффекта индикатора выполнения, отображаться и исчезать в быстрой последовательности.

Если вы хотите сделать его видимым для целей тестирования (я не буду рекомендовать в производственном коде), то увеличьте время сна до 10 секунд:

 @Override
  protected Integer doInBackground(Void... voids) {
        try {
            Thread.sleep(10000);
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
        ....
  } 

В качестве альтернативы вы можете просто использовать обычный ProgressBar

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...