我在这里看到的问题/解决方案没有显示键盘,但没有与我的具体问题有关。单击EditText时,键盘显示正常。但是,当我首先为EditText设置动画时,当您单击EditText时键盘将不会显示。
任何想法为什么会发生这种情况?
在我的活动中,我首先为我的徽标设置动画,然后在完成动画制作后,我为EditTexts创建了一个淡入动画。完成动画后,我尝试单击其中任何一个,但键盘不会显示。
这是我的Activity中的onCreate方法:
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
this.requestWindowFeature(Window.FEATURE_NO_TITLE); //Remove title bar
setContentView(R.layout.login);
final EditText emailField = (EditText) findViewById(R.id.emailField);
final EditText passwordField = (EditText) findViewById(R.id.passwordField);
final TextView logInText = (TextView) findViewById(R.id.logInText);
final Button signupButton = (Button) findViewById(R.id.signupButton);
final Button loginButton = (Button) findViewById(R.id.loginButton);
//animation of logo
ImageView img_animation = (ImageView) findViewById(R.id.encoreLogo);
TranslateAnimation animation = new TranslateAnimation(0.0f, 00f,
0.0f, -400.0f);
animation.setDuration(4000);
animation.setFillAfter(true);
animation.setStartOffset(2000);
img_animation.startAnimation(animation);
animation.setAnimationListener(new AnimationListener() {
@Override
public void onAnimationEnd(Animation animation) {
Animation animFadeIn = AnimationUtils.loadAnimation(getApplicationContext(), android.R.anim.fade_in);
animFadeIn.setDuration(2000);
animFadeIn.setFillAfter(true);
emailField.setAnimation(animFadeIn);
passwordField.setAnimation(animFadeIn);
logInText.setAnimation(animFadeIn);
loginButton.setAnimation(animFadeIn);
signupButton.setAnimation(animFadeIn);
}
@Override
public void onAnimationRepeat(Animation animation) {}
@Override
public void onAnimationStart(Animation animation) {}
});
signupButton.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
Intent myIntent = new Intent(MainActivity.this, SignUpActivity.class);
MainActivity.this.startActivity(myIntent);
}
});
}
这是我对应的login.xml:
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context=".MainActivity" >
<ImageView
android:id="@+id/backroundImage"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentBottom="true"
android:layout_alignParentRight="true"
android:layout_alignParentTop="true"
android:cropToPadding="false"
android:scaleType="centerCrop"
android:src="@drawable/crowdblur1" />
<ImageView
android:id="@+id/encoreLogo"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_centerHorizontal="true"
android:layout_centerVertical="true"
android:adjustViewBounds="true"
android:maxHeight="@dimen/thumbnail_height"
android:maxWidth="@dimen/thumbnail_width"
android:scaleType="centerInside"
android:src="@drawable/hand72" />
<TextView
android:id="@+id/logInText"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignBottom="@+id/encoreLogo"
android:layout_alignLeft="@+id/passwordField"
android:layout_centerHorizontal="true"
android:layout_centerInParent="true"
android:layout_marginBottom="79dp"
android:paddingLeft="@dimen/left_padding_login_text"
android:text="Login to Encore"
android:textColor="@android:color/white"
android:textSize="@dimen/log_in_text"
android:textStyle="bold"
android:visibility="invisible" />
<EditText
android:id="@+id/emailField"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignBottom="@+id/encoreLogo"
android:layout_centerHorizontal="true"
android:layout_marginBottom="18dp"
android:background="@drawable/rounded_corners"
android:ems="10"
android:inputType="textEmailAddress"
android:hint="Email"
android:textColor="@android:color/black"
android:textStyle="italic"
android:visibility="invisible" />
<EditText
android:id="@+id/passwordField"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_below="@+id/encoreLogo"
android:layout_centerHorizontal="true"
android:background="@drawable/rounded_corners"
android:ems="10"
android:inputType="textPassword"
android:hint="Password"
android:textStyle="italic"
android:textColor="@android:color/black"
android:visibility="invisible" />
<Button
android:id="@+id/signupButton"
style="?android:attr/buttonStyleSmall"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_below="@+id/loginButton"
android:layout_centerHorizontal="true"
android:layout_marginTop="22dp"
android:background="@android:color/transparent"
android:text="@string/signUp"
android:textColor="#5FC2FF"
android:textSize="@dimen/signupText"
android:textStyle="bold"
android:visibility="invisible" />
<Button
android:id="@+id/loginButton"
style="?android:attr/buttonStyleSmall"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_below="@+id/passwordField"
android:layout_centerHorizontal="true"
android:layout_marginTop="14dp"
android:background="@android:color/transparent"
android:text="@string/login"
android:textColor="@android:color/white"
android:textSize="@dimen/signupText"
android:visibility="invisible" />
提前致谢!
因此,当您在EditText字段上将可见性设置为INVISIBLE时,它似乎不希望获得焦点。
我通过在动画完成后更改这些字段的可见性来修复此问题,如下所示:
animFadeIn.setAnimationListener(new AnimationListener() {
@Override
public void onAnimationEnd(Animation animation) {
emailField.setVisibility(View.VISIBLE);
passwordField.setVisibility(View.VISIBLE);
logInText.setVisibility(View.VISIBLE);
loginButton.setVisibility(View.VISIBLE);
signupButton.setVisibility(View.VISIBLE);
}
@Override
public void onAnimationStart(Animation animation) {}
@Override
public void onAnimationRepeat(Animation animation) {}
});
希望这可以帮助你:)
您似乎想要等待图像(徽标)完成其动画,然后启动TextView和EditView的动画。你可以做的不是使用setAnimationListener
而是将animFadeIn
的起始偏移值设置为4000毫秒。
试试这个:
TranslateAnimation animation = new TranslateAnimation(0.0f, 00f,
0.0f, -400.0f);
animation.setDuration(4000);
animation.setFillAfter(true);
animation.setStartOffset(2000);
img_animation.startAnimation(animation);
Animation animFadeIn = AnimationUtils.loadAnimation(getApplicationContext(), android.R.anim.fade_in);
animFadeIn.setDuration(2000);
animFadeIn.setStartOffset(4000);
animFadeIn.setFillAfter(true);
emailField.setAnimation(animFadeIn);
passwordField.setAnimation(animFadeIn);
logInText.setAnimation(animFadeIn);
loginButton.setAnimation(animFadeIn);
signupButton.setAnimation(animFadeIn);
键盘对我来说很好。
有同样的问题。只是不要使用fillAfter,这是废话。结合@ Wextux的解决方案。