Java 背景(渐变形状)淡出后重定向到新页面

Java 背景(渐变形状)淡出后重定向到新页面,java,android,gradient,fade,shape,Java,Android,Gradient,Fade,Shape,我想我的第一页背景淡出,然后进入下一页。 我用渐变制作形状,并用它作为第一页的背景。 但当我在genymotion中运行我的应用程序时,第一页的背景颜色是深灰色,我对Android开发还不熟悉,所以我不知道如何处理它。 XML: 主要活动XML: <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layo

我想我的第一页背景淡出,然后进入下一页。 我用渐变制作形状,并用它作为第一页的背景。 但当我在genymotion中运行我的应用程序时,第一页的背景颜色是深灰色,我对Android开发还不熟悉,所以我不知道如何处理它。 XML:


主要活动XML:

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="@drawable/linergradiant"
android:id="@+id/firstpage"
android:orientation="vertical" >

<RelativeLayout
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:background="@drawable/texture" >

    <LinearLayout
        android:layout_width="200dip"
        android:layout_height="200dip"
        android:layout_centerHorizontal="true"
        android:layout_centerVertical="true"
        android:layout_marginTop="116dp"
        android:background="@drawable/logo_big2" >
    </LinearLayout>

 </RelativeLayout>

</LinearLayout>

MAINACTIVITY JAVA

public class MainActivity extends ActionBarActivity {
 LinearLayout screen;
 Handler handler = new Handler();
 int i;
 Intent intent;

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    screen=(LinearLayout) findViewById(R.id.firstpage);
    (new Thread(){
        @Override
    public void run(){
        for(i=0; i<255; i=i+3){
            handler.post(new Runnable(){
                public void run(){
                    screen.setBackgroundColor(Color.argb(255, i, i, i));
                }
            });
            try{ sleep(100); }
               catch(Exception e){ break; }
            }
            startActivity(new Intent(getApplicationContext(),BMIcalculator.class));
        }
    }).start();     
}
}
公共类MainActivity扩展了ActionBarActivity{
线性布局屏幕;
Handler=newhandler();
int i;
意图;
@凌驾
创建时受保护的void(Bundle savedInstanceState){
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
屏幕=(线性布局)findViewById(R.id.firstpage);
(新线程(){
@凌驾
公开募捐{

对于(i=0;i参考以下代码


咪咪,你的意思是,你想要渐变背景,当它将显示动画淡入或淡出时,对吗?@pratik我想要渐变背景,淡出后,进入动画的第二页。然后在你的for循环后调用startactivity,就像这样。在执行for循环后,下一件事将发生是开始一activity@mimi那你为什么不使用淡出动画呢?这将是最简单的方法。@pratik我试着用动画来写作,但我不知道怎样才能做到。我尝试了这个[但它对我没有帮助]。
public class MainActivity extends ActionBarActivity {
 LinearLayout screen;
 Handler handler = new Handler();
 int i;
 Intent intent;

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    screen=(LinearLayout) findViewById(R.id.firstpage);
    (new Thread(){
        @Override
    public void run(){
        for(i=0; i<255; i=i+3){
            handler.post(new Runnable(){
                public void run(){
                    screen.setBackgroundColor(Color.argb(255, i, i, i));
                }
            });
            try{ sleep(100); }
               catch(Exception e){ break; }
            }
            startActivity(new Intent(getApplicationContext(),BMIcalculator.class));
        }
    }).start();     
}
}
private View mContentView;
private View mLoadingView;
private int mShortAnimationDuration;

...

private void crossfade() {

    // Set the content view to 0% opacity but visible, so that it is visible
    // (but fully transparent) during the animation.
    mContentView.setAlpha(0f);
    mContentView.setVisibility(View.VISIBLE);

    // Animate the content view to 100% opacity, and clear any animation
    // listener set on the view.
    mContentView.animate()
            .alpha(1f)
            .setDuration(mShortAnimationDuration)
            .setListener(null);

    // Animate the loading view to 0% opacity. After the animation ends,
    // set its visibility to GONE as an optimization step (it won't
    // participate in layout passes, etc.)
    mLoadingView.animate()
            .alpha(0f)
            .setDuration(mShortAnimationDuration)
            .setListener(new AnimatorListenerAdapter() {
                @Override
                public void onAnimationEnd(Animator animation) {
                    mLoadingView.setVisibility(View.GONE);
                }
            });
}