onCreate()方法中的线程在设置视图之前执行

问题描述 投票:0回答:1

我正在为应用创建初始屏幕。加载时执行4种方法。第一个检查是否授予Internet权限,第二个向API发送请求以检查它是否在线,第三个从Firebase获取令牌,第四个检查用户是否已经登录。我正在使用4个线程。发生错误时,每种方法都将标志设置为false。然后,当所有线程结束工作时(我使用.join()),最后一个方法检查标志的状态并启动新活动,或者仅显示Error并再次尝试所有操作。

我的问题是,在所有线程完成工作之后,我才能得到视图。例如,我有黑屏,然后显示消息(“发生错误”),只有在此之后,我才能看到UI。但是在Error上,UI刷新了,所以又一次出现黑屏,然后结果和UI持续1秒钟,直到再次重启。

我的问题是,我可以以某种方式停止这些线程,直到我的UI准备好吗?

 @Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    getWindow().setFlags(WindowManager.LayoutParams.FLAG_LAYOUT_NO_LIMITS,
            WindowManager.LayoutParams.FLAG_LAYOUT_NO_LIMITS);

    setContentView(R.layout.activity_splash);
    checkProgress = findViewById(R.id.checkProgressText);
    auth = FirebaseAuth.getInstance();
    tokenUtils = new TokenUtils();

    requestQueue = Volley.newRequestQueue(getApplicationContext());
    animatedCircleLoadingView = findViewById(R.id.circle_loading_view);

    //starting the animation
    startLoading();

    Thread[] checkers = new Thread[4];
    checkers[0] = new Thread(this::checkInternetPermissions);
    checkers[1] = new Thread(this::checkConnection);
    checkers[2] = new Thread(this::getUserAuth);
    checkers[3] = new Thread(this::getUserToken);

    for (Thread t : checkers) {
        try {
            t.start();
            t.join();
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
    }
    changeActivity();
}

检查互联网许可方法:

  private void checkInternetPermissions() {
    checkProgress.setText(getString(R.string.check_internet_permissions_text));
    if (ContextCompat.checkSelfPermission(this, Manifest.permission.INTERNET)
            != PackageManager.PERMISSION_GRANTED)
        requestPermissions(new String[]{Manifest.permission.INTERNET}, 1);
}

@Override
public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) {
    if (requestCode != 1) {
        connectionFlag = false;
    }
}

检查连接方法:

private void checkConnection() {
    checkProgress.setText(getString(R.string.checking_api_connection));
    RequestFuture<String> requestFuture = RequestFuture.newFuture();
    StringRequest request = new StringRequest
            (Request.Method.GET, API_CHECK,
                    requestFuture,
                    requestFuture);
    requestQueue.add(request);

    String response = null;
    try {
        response = requestFuture.get(5, TimeUnit.SECONDS);
    } catch (InterruptedException | ExecutionException | TimeoutException e) {
        this.connectionFlag = false;
    }

    if (!Objects.equals(response, "ok"))
        this.connectionFlag = false;
}

获取用户令牌方法:

private void getUserToken() {
    checkProgress.setText(getString(R.string.getting_user_auth_token));
    String token = null;
    try {
        token = tokenUtils.getFirebaseToken();
    } catch (ExecutionException | InterruptedException e) {
        this.connectionFlag = false;
    }
    if (Objects.isNull(token) || Objects.requireNonNull(token).isEmpty())
        this.connectionFlag = false;
}

最后获得用户身份验证方法:

private void getUserAuth() {
    checkProgress.setText(getString(R.string.checking_user_auth));
    authStateListener = firebaseAuth -> {
        firebaseUser = firebaseAuth.getCurrentUser();
        if (Objects.isNull(firebaseUser) || Objects.requireNonNull(firebaseUser.getEmail()).isEmpty()) {
            this.authFlag = false;
        }
    };
}

处理标志状态的最后方法:

private void changeActivity() {
    checkProgress.setText(getString(R.string.finalizing_text_progress));
    if (connectionFlag && authFlag) {
        startActivity(new Intent(SplashActivity.this, MapActivity.class));
    } else if (!connectionFlag) {
        Toast.makeText(getApplicationContext(), "Error occurred.", Toast.LENGTH_LONG).show();
        finish();
        startActivity(getIntent());
    } else {
        startActivity(new Intent(SplashActivity.this, LoginActivity.class));
    }
}
java android mobile oncreate
1个回答
0
投票

是的,您可以在处理程序线程上稍加延迟地尝试它,然后它将正常工作,或者您可以在onResume()创建视图时在onResume()方法上启动线程]

© www.soinside.com 2019 - 2024. All rights reserved.