Warning: file_get_contents(/data/phpspider/zhask/data//catemap/3/android/201.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Java Android上的Crossfade图像视图未重置-单击相同的图像_Java_Android - Fatal编程技术网

Java Android上的Crossfade图像视图未重置-单击相同的图像

Java Android上的Crossfade图像视图未重置-单击相同的图像,java,android,Java,Android,我正在尝试编写一个应用程序,在两个图像之间进行交叉淡入淡出,然后在单击时返回。 最初的方法,淡入淡出,工作正常,淡入新图像,但单击第二个图像时,没有效果。 我认为问题在于第一个图像仍然覆盖在第二个图像上,所以我只是一遍又一遍地点击第一个图像。 但是,我添加了打印图像变量的hashcode(),以检查执行情况,每次它似乎只从方法fadeBack返回相同的变量。 我在日志(//n单击图像n)中注释了每次单击时出现的条目,但似乎调用了相同的方法,fadeBack,此时应调用fade 如果需要更多信息,

我正在尝试编写一个应用程序,在两个图像之间进行交叉淡入淡出,然后在单击时返回。 最初的方法,
淡入淡出
,工作正常,淡入新图像,但单击第二个图像时,没有效果。 我认为问题在于第一个图像仍然覆盖在第二个图像上,所以我只是一遍又一遍地点击第一个图像。 但是,我添加了打印图像变量的
hashcode()
,以检查执行情况,每次它似乎只从方法
fadeBack
返回相同的变量。 我在日志(
//n单击图像n
)中注释了每次单击时出现的条目,但似乎调用了相同的方法,
fadeBack
,此时应调用
fade

如果需要更多信息,请告诉我

日志:

代码:

活动主xml文件

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout 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:paddingBottom="@dimen/activity_vertical_margin"
    android:paddingLeft="@dimen/activity_horizontal_margin"
    android:paddingRight="@dimen/activity_horizontal_margin"
    android:paddingTop="@dimen/activity_vertical_margin"
    app:layout_behavior="@string/appbar_scrolling_view_behavior"
    tools:context="com.example.richardcurteis.layoutdemo.MainActivity"
    tools:showIn="@layout/activity_main"
    android:clickable="false">

     <ImageView
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:id="@+id/obama"
        android:layout_alignParentTop="true"
        android:layout_alignParentStart="true"
         android:src="@drawable/obama"
         android:onClick="fade" />

    <ImageView
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:id="@+id/will"
        android:layout_alignTop="@+id/obama"
        android:layout_alignParentStart="true"
        android:src="@drawable/will"
        android:alpha="0"
        android:onClick="fadeBack" />
</RelativeLayout>

好的,我知道了。 由于可绘制的,
will
在设计中位于
obama
之上,因此总是调用
fadeBack
方法。 更改了代码,使crossfade和return包含在一个方法中,并带有一个计数器来控制它的方向

MainActivity.java

package com.example.richardcurteis.layoutdemo;

import android.os.Bundle;
import android.support.design.widget.FloatingActionButton;
import android.support.design.widget.Snackbar;
import android.support.v7.app.AppCompatActivity;
import android.support.v7.widget.Toolbar;
import android.view.View;
import android.view.Menu;
import android.view.MenuItem;
import android.widget.ImageView;

public class MainActivity extends AppCompatActivity {

    ImageView obama;
    ImageView will;
    int count;

    public void fade(View view) {

        if (count == 0) {
            obama.animate().alpha(0f).setDuration(2000);
            will.animate().alpha(1f).setDuration(2000);
            count++;
        } else {
            will.animate().alpha(0f).setDuration(2000);
            obama.animate().alpha(1f).setDuration(2000);
            count = 0;
        }

    }

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

        obama = (ImageView) findViewById(R.id.obama);
        will = (ImageView) findViewById(R.id.will);
        count = 0;

        Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar);
        setSupportActionBar(toolbar);

        FloatingActionButton fab = (FloatingActionButton) findViewById(R.id.fab);
        fab.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                Snackbar.make(view, "Replace with your own action", Snackbar.LENGTH_LONG)
                        .setAction("Action", null).show();
            }
        });

    }

    @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.
        int id = item.getItemId();

        //noinspection SimplifiableIfStatement
        if (id == R.id.action_settings) {
            return true;
        }

        return super.onOptionsItemSelected(item);
    }
}
content_main.xml

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout 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:paddingBottom="@dimen/activity_vertical_margin"
    android:paddingLeft="@dimen/activity_horizontal_margin"
    android:paddingRight="@dimen/activity_horizontal_margin"
    android:paddingTop="@dimen/activity_vertical_margin"
    app:layout_behavior="@string/appbar_scrolling_view_behavior"
    tools:context="com.example.richardcurteis.layoutdemo.MainActivity"
    tools:showIn="@layout/activity_main"
    android:clickable="false">

     <ImageView
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:id="@+id/obama"
        android:layout_alignParentTop="true"
        android:layout_alignParentStart="true"
         android:src="@drawable/obama"
         android:layout_alignParentLeft="true" />

    <ImageView
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:id="@+id/will"
        android:layout_alignTop="@+id/obama"
        android:layout_alignParentStart="true"
        android:layout_alignParentTop="true"
        android:layout_alignParentLeft="true"
        android:src="@drawable/will"
        android:onClick="fade"
        android:alpha="0" />
</RelativeLayout>

好的,我知道了。 由于可绘制的,
will
在设计中位于
obama
之上,因此总是调用
fadeBack
方法。 更改了代码,使crossfade和return包含在一个方法中,并带有一个计数器来控制它的方向

MainActivity.java

package com.example.richardcurteis.layoutdemo;

import android.os.Bundle;
import android.support.design.widget.FloatingActionButton;
import android.support.design.widget.Snackbar;
import android.support.v7.app.AppCompatActivity;
import android.support.v7.widget.Toolbar;
import android.view.View;
import android.view.Menu;
import android.view.MenuItem;
import android.widget.ImageView;

public class MainActivity extends AppCompatActivity {

    ImageView obama;
    ImageView will;
    int count;

    public void fade(View view) {

        if (count == 0) {
            obama.animate().alpha(0f).setDuration(2000);
            will.animate().alpha(1f).setDuration(2000);
            count++;
        } else {
            will.animate().alpha(0f).setDuration(2000);
            obama.animate().alpha(1f).setDuration(2000);
            count = 0;
        }

    }

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

        obama = (ImageView) findViewById(R.id.obama);
        will = (ImageView) findViewById(R.id.will);
        count = 0;

        Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar);
        setSupportActionBar(toolbar);

        FloatingActionButton fab = (FloatingActionButton) findViewById(R.id.fab);
        fab.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                Snackbar.make(view, "Replace with your own action", Snackbar.LENGTH_LONG)
                        .setAction("Action", null).show();
            }
        });

    }

    @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.
        int id = item.getItemId();

        //noinspection SimplifiableIfStatement
        if (id == R.id.action_settings) {
            return true;
        }

        return super.onOptionsItemSelected(item);
    }
}
content_main.xml

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout 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:paddingBottom="@dimen/activity_vertical_margin"
    android:paddingLeft="@dimen/activity_horizontal_margin"
    android:paddingRight="@dimen/activity_horizontal_margin"
    android:paddingTop="@dimen/activity_vertical_margin"
    app:layout_behavior="@string/appbar_scrolling_view_behavior"
    tools:context="com.example.richardcurteis.layoutdemo.MainActivity"
    tools:showIn="@layout/activity_main"
    android:clickable="false">

     <ImageView
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:id="@+id/obama"
        android:layout_alignParentTop="true"
        android:layout_alignParentStart="true"
         android:src="@drawable/obama"
         android:layout_alignParentLeft="true" />

    <ImageView
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:id="@+id/will"
        android:layout_alignTop="@+id/obama"
        android:layout_alignParentStart="true"
        android:layout_alignParentTop="true"
        android:layout_alignParentLeft="true"
        android:src="@drawable/will"
        android:onClick="fade"
        android:alpha="0" />
</RelativeLayout>