加载时显示初始屏幕

2022-09-02 05:06:24

我有一个Android应用程序,它显示“初始屏幕”3秒钟。之后,MainActivity将被加载。

不幸的是,MainActivity需要额外的大约4秒才能加载。在第一次启动时甚至更长。但是,加载应用程序时,一切都会顺利进行。

现在,我如何实现它在初始屏幕显示期间加载MainActivity?它应该显示一个图像,直到整个东西完全加载。我已经阅读了有关异步任务的信息,但我不确定将其放在哪里以及如何正确使用它。有人可以帮我吗?

初始屏幕.java

public class SplashScreen extends Activity {
    private static int SPLASH_TIME_OUT = 3000;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_startup);

        new Handler().postDelayed(new Runnable() {
            @Override
            public void run() {
                Intent i = new Intent(SplashScreen.this, MainActivity.class);
                startActivity(i);
                finish();
            }
        }, SPLASH_TIME_OUT);
    }
}

主要活动.java

public class MainActivity extends Activity implements OnClickListener, MediaController.MediaPlayerControl {

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

        //Some heavy processing
        //starting services
        //starting Google Text to Speech
        //and so on...

    }

}

答案 1

不应在启动时创建新线程,而应创建一个不必等待资源加载的视图,如本文所述:初始屏幕的正确方式

如本文所述,您应该创建一个可绘制文件而不是 XML 文件:layer-listlayout

<layer-list xmlns:android="http://schemas.android.com/apk/res/android">

    <!-- Fill the background with a solid color -->
    <item android:drawable="@color/gray"/>

    <!-- Place your bitmap in the center -->
    <item>
        <bitmap
            android:gravity="center"
            android:src="@mipmap/ic_launcher"/>
    </item>

</layer-list>

然后使用可绘制文件作为背景创建主题。我使用属性而不是文章中建议的属性,因为考虑到状态和导航栏,更好地使可绘制的中心。我还设置为,以便初始屏幕不会对过渡到:backgroundwindowBackgroundbackgroundwindowAnimationStylenullMainActivity

<resources>

    <!-- Base application theme -->
    <style name="AppTheme" parent="Theme.AppCompat.Light.DarkActionBar">
        <!-- Customize your theme here. -->
    </style>

    <!-- Splash Screen theme -->
    <style name="SplashTheme" parent="Theme.AppCompat.NoActionBar">
        <item name="android:background">@drawable/background_splash</item>
        <item name="android:windowAnimationStyle">@null</item>
    </style>

</resources>

然后在清单中声明您的主题:SplashActivity

<activity android:name=".SplashActivity"
    android:theme="@style/SplashTheme">
    <intent-filter>
        <action android:name="android.intent.action.MAIN" />

        <category android:name="android.intent.category.LAUNCHER" />
    </intent-filter>
</activity>

最后,您所要做的就是启动 ,初始屏幕将仅在应用配置所需的时间内显示:SplashActivityMainActivity

public class SplashActivity extends AppCompatActivity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);

        Intent intent = new Intent(this, MainActivity.class);
        startActivity(intent);
        finish();
    }
}

答案 2

如果对初始屏幕的显示时间没有特定限制,则可以通过以下方式使用:AsyncTask

public class SplashScreen extends Activity {
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_startup);
        startHeavyProcessing();

    }

    private void startHeavyProcessing(){
       new LongOperation().execute("");
    }

    private class LongOperation extends AsyncTask<String, Void, String> {

        @Override
        protected String doInBackground(String... params) {
            //some heavy processing resulting in a Data String
            for (int i = 0; i < 5; i++) {
                try {
                    Thread.sleep(1000);
                } catch (InterruptedException e) {
                    Thread.interrupted();
                }
            }
            return "whatever result you have";
        }

        @Override
        protected void onPostExecute(String result) {
            Intent i = new Intent(SplashScreen.this, MainActivity.class);
            i.putExtra("data", result);
            startActivity(i);
            finish();
        }

        @Override
        protected void onPreExecute() {}

        @Override
        protected void onProgressUpdate(Void... values) {}
    }
}

如果生成的数据与字符串具有其他性质,则可以将对象作为活动的额外内容。在 中,您可以使用以下命令检索数据:ParcelableonCreate

getIntent().getExtras.getString('data');


推荐