acabar
This commit is contained in:
74
app/src/main/java/com/example/lifegrid/SplashActivity.java
Normal file
74
app/src/main/java/com/example/lifegrid/SplashActivity.java
Normal file
@@ -0,0 +1,74 @@
|
||||
package com.example.lifegrid;
|
||||
|
||||
import android.animation.Animator;
|
||||
import android.animation.AnimatorListenerAdapter;
|
||||
import android.content.Intent;
|
||||
import android.os.Bundle;
|
||||
import android.os.Handler;
|
||||
import android.os.Looper;
|
||||
import android.view.animation.DecelerateInterpolator;
|
||||
import android.view.animation.OvershootInterpolator;
|
||||
import android.widget.ImageView;
|
||||
import android.widget.TextView;
|
||||
|
||||
import androidx.activity.EdgeToEdge;
|
||||
import androidx.appcompat.app.AppCompatActivity;
|
||||
import androidx.core.graphics.Insets;
|
||||
import androidx.core.view.ViewCompat;
|
||||
import androidx.core.view.WindowInsetsCompat;
|
||||
|
||||
import com.google.firebase.FirebaseApp;
|
||||
import com.google.firebase.auth.FirebaseAuth;
|
||||
import com.google.firebase.auth.FirebaseUser;
|
||||
|
||||
public class SplashActivity extends AppCompatActivity {
|
||||
|
||||
@Override
|
||||
protected void onCreate(Bundle savedInstanceState) {
|
||||
super.onCreate(savedInstanceState);
|
||||
EdgeToEdge.enable(this);
|
||||
setContentView(R.layout.activity_splash);
|
||||
|
||||
ViewCompat.setOnApplyWindowInsetsListener(findViewById(R.id.main), (v, insets) -> {
|
||||
Insets systemBars = insets.getInsets(WindowInsetsCompat.Type.systemBars());
|
||||
v.setPadding(systemBars.left, systemBars.top, systemBars.right, systemBars.bottom);
|
||||
return insets;
|
||||
});
|
||||
|
||||
FirebaseApp.initializeApp(this);
|
||||
|
||||
ImageView ivSplashLogo = findViewById(R.id.ivSplashLogo);
|
||||
// Configuração inicial da animação
|
||||
ivSplashLogo.setAlpha(0f);
|
||||
ivSplashLogo.setScaleX(0f);
|
||||
ivSplashLogo.setScaleY(0f);
|
||||
|
||||
// Animação do Logo (aumenta e depois diminui um bocado)
|
||||
ivSplashLogo.animate()
|
||||
.alpha(1f)
|
||||
.scaleX(1f)
|
||||
.scaleY(1f)
|
||||
.setDuration(1200)
|
||||
.setInterpolator(new OvershootInterpolator(2.0f))
|
||||
.setListener(new AnimatorListenerAdapter() {
|
||||
@Override
|
||||
public void onAnimationEnd(Animator animation) {
|
||||
// Aguarda um pouco e avança
|
||||
new Handler(Looper.getMainLooper()).postDelayed(() -> navigateToNextActivity(), 600);
|
||||
}
|
||||
})
|
||||
.start();
|
||||
}
|
||||
|
||||
private void navigateToNextActivity() {
|
||||
FirebaseUser currentUser = FirebaseAuth.getInstance().getCurrentUser();
|
||||
Intent intent;
|
||||
if (currentUser != null) {
|
||||
intent = new Intent(SplashActivity.this, TelaInicialActivity.class);
|
||||
} else {
|
||||
intent = new Intent(SplashActivity.this, LoginActivity.class);
|
||||
}
|
||||
startActivity(intent);
|
||||
finish();
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user