在 android 内将 ImageView 移动到屏幕中心
Move ImageView To Center Of Screen in android
我在一个有 2 个图像视图的应用程序中工作,第一个在左边,另一个在右边...当页面加载图像视图移动时,它会移动到屏幕中央..
即
imageview-------->center<----------imageview
我正在使用平移动画来移动带有 4 个参数的图像
即
TranslateAnimation (float fromXDelta, float toXDelta, float fromYDelta, float toYDelta)
但问题是什么都没有显示..
我的 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"
android:id="@+id/topRelativeLayout" >
<LinearLayout
android:id="@+id/centerLayout"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_alignParentRight="true"
android:layout_centerVertical="true"
android:orientation="vertical" >
<ImageView
android:id="@+id/imageView_header"
android:layout_width="150dp"
android:layout_height="80dp"
android:layout_gravity="left"
android:layout_marginTop="80dp"
android:src="@drawable/logo_footer" />
<ImageView
android:id="@+id/imageView_footer"
android:layout_width="150dp"
android:layout_height="80dp"
android:layout_gravity="right"
android:layout_marginTop="30dp"
android:src="@drawable/logo_header" />
</LinearLayout> </RelativeLayout>
在我的 Applicationn On createview java 代码是
DisplayMetrics displaymetrics = new DisplayMetrics();
getWindowManager().getDefaultDisplay().getMetrics(displaymetrics);
int height = displaymetrics.heightPixels;
int width = displaymetrics.widthPixels;
Log.d("Screen Width",String.valueOf(width));
Log.d("Screen Height",String.valueOf(height));
Log.d("Screen Half Width",String.valueOf(width/2));
Log.d("Screen HalHeight",String.valueOf(height/2));
header=(ImageView)findViewById(R.id.imageView_header);
moveImageToLeftToCenter(header,height,width);
footer=(ImageView)findViewById(R.id.imageView_footer);
moveImageToRightToCenter( footer,height,width );
功能码为
public void moveImageToLeftToCenter(ImageView img, int height, int width ){
TranslateAnimation anim = new TranslateAnimation( 0, width/2,height/2,height/2);// - originalPos[0] , 0, yDest - originalPos[1] );
anim.setDuration(3000);
anim.setFillAfter( true );
img.startAnimation(anim);
}
public void moveImageToRightToCenter(ImageView img,int height, int width ){
TranslateAnimation anim = new TranslateAnimation( width/2, 0,height/2,height/2);// - originalPos[0] , 0, yDest - originalPos[1] );
anim.setDuration(3000);
anim.setFillAfter( true );
img.startAnimation(anim);
}
我的 Logcat 值是
05-11 11:27:33.762: D/Screen Width(4090): 1152
05-11 11:27:33.762: D/Screen Height(4090): 672
05-11 11:27:33.762: D/Screen Half Width(4090): 576
05-11 11:27:33.762: D/Screen HalHeight(4090): 336
我不明白是什么问题..如果有人知道而不是帮助我....
在此先感谢朋友
这可能对你有帮助,对我有用
public void moveImageToRightToCenter(ImageView img ,int screenWidth)
{
img.setTranslationX(screenWidth);
img.animate()
.translationX(0)
.setDuration(300)
.setStartDelay(300);
}
我也做了类似的事情,我可以在 onWindowsFocusChanged 函数中设法做到这一点。代码在下面,我知道你已经尝试过了,但也许你能从中找到有用的东西。
@Override
public void onWindowFocusChanged(boolean hasFocus) {
// TODO Auto-generated method stub
super.onWindowFocusChanged(hasFocus);
AnimationSet set = new AnimationSet(true);
Animation fadeIn = FadeIn(3000);
fadeIn.setStartOffset(0);
set.addAnimation(fadeIn);
RelativeLayout root = (RelativeLayout) findViewById(R.id.splashLayout);
DisplayMetrics dm = new DisplayMetrics();
this.getWindowManager().getDefaultDisplay().getMetrics(dm);
int statusBarOffset = dm.heightPixels - root.getMeasuredHeight();
int originalPos[] = new int[2];
splashImage.getLocationOnScreen(originalPos);
int xDest = dm.widthPixels / 2;
xDest -= (splashImage.getMeasuredWidth() / 2);
int yDest = dm.heightPixels / 2 - (splashImage.getMeasuredHeight() / 2)
- statusBarOffset;
TranslateAnimation anim = new TranslateAnimation(0, xDest
- originalPos[0], 0, yDest - originalPos[1]);
anim.setDuration(3000);
set.addAnimation(anim);
Animation fadeOut = FadeOut(1000);
fadeOut.setStartOffset(3000);
set.addAnimation(fadeOut);
set.setFillAfter(true);
set.setFillEnabled(true);
splashImage.startAnimation(set);
}
private Animation FadeIn(int t) {
Animation fade;
fade = new AlphaAnimation(0.0f, 1.0f);
fade.setDuration(t);
fade.setInterpolator(new AccelerateInterpolator());
return fade;
}
private Animation FadeOut(int t) {
Animation fade;
fade = new AlphaAnimation(1.0f, 0.1f);
fade.setDuration(t);
fade.setInterpolator(new AccelerateInterpolator());
return fade;
}
这里我尝试做的是,通过在图像上应用动画设置,将启动图像从特定位置移动到较低的位置。这里的FadeIn,FadeOut只是改变图像alpha的动画,所以你只需要给动画集提供你自己的动画即可。
希望对您有所帮助。
此致,
我在一个有 2 个图像视图的应用程序中工作,第一个在左边,另一个在右边...当页面加载图像视图移动时,它会移动到屏幕中央.. 即
imageview-------->center<----------imageview
我正在使用平移动画来移动带有 4 个参数的图像
即
TranslateAnimation (float fromXDelta, float toXDelta, float fromYDelta, float toYDelta)
但问题是什么都没有显示..
我的 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"
android:id="@+id/topRelativeLayout" >
<LinearLayout
android:id="@+id/centerLayout"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_alignParentRight="true"
android:layout_centerVertical="true"
android:orientation="vertical" >
<ImageView
android:id="@+id/imageView_header"
android:layout_width="150dp"
android:layout_height="80dp"
android:layout_gravity="left"
android:layout_marginTop="80dp"
android:src="@drawable/logo_footer" />
<ImageView
android:id="@+id/imageView_footer"
android:layout_width="150dp"
android:layout_height="80dp"
android:layout_gravity="right"
android:layout_marginTop="30dp"
android:src="@drawable/logo_header" />
</LinearLayout> </RelativeLayout>
在我的 Applicationn On createview java 代码是
DisplayMetrics displaymetrics = new DisplayMetrics();
getWindowManager().getDefaultDisplay().getMetrics(displaymetrics);
int height = displaymetrics.heightPixels;
int width = displaymetrics.widthPixels;
Log.d("Screen Width",String.valueOf(width));
Log.d("Screen Height",String.valueOf(height));
Log.d("Screen Half Width",String.valueOf(width/2));
Log.d("Screen HalHeight",String.valueOf(height/2));
header=(ImageView)findViewById(R.id.imageView_header);
moveImageToLeftToCenter(header,height,width);
footer=(ImageView)findViewById(R.id.imageView_footer);
moveImageToRightToCenter( footer,height,width );
功能码为
public void moveImageToLeftToCenter(ImageView img, int height, int width ){
TranslateAnimation anim = new TranslateAnimation( 0, width/2,height/2,height/2);// - originalPos[0] , 0, yDest - originalPos[1] );
anim.setDuration(3000);
anim.setFillAfter( true );
img.startAnimation(anim);
}
public void moveImageToRightToCenter(ImageView img,int height, int width ){
TranslateAnimation anim = new TranslateAnimation( width/2, 0,height/2,height/2);// - originalPos[0] , 0, yDest - originalPos[1] );
anim.setDuration(3000);
anim.setFillAfter( true );
img.startAnimation(anim);
}
我的 Logcat 值是
05-11 11:27:33.762: D/Screen Width(4090): 1152
05-11 11:27:33.762: D/Screen Height(4090): 672
05-11 11:27:33.762: D/Screen Half Width(4090): 576
05-11 11:27:33.762: D/Screen HalHeight(4090): 336
我不明白是什么问题..如果有人知道而不是帮助我.... 在此先感谢朋友
这可能对你有帮助,对我有用
public void moveImageToRightToCenter(ImageView img ,int screenWidth)
{
img.setTranslationX(screenWidth);
img.animate()
.translationX(0)
.setDuration(300)
.setStartDelay(300);
}
我也做了类似的事情,我可以在 onWindowsFocusChanged 函数中设法做到这一点。代码在下面,我知道你已经尝试过了,但也许你能从中找到有用的东西。
@Override
public void onWindowFocusChanged(boolean hasFocus) {
// TODO Auto-generated method stub
super.onWindowFocusChanged(hasFocus);
AnimationSet set = new AnimationSet(true);
Animation fadeIn = FadeIn(3000);
fadeIn.setStartOffset(0);
set.addAnimation(fadeIn);
RelativeLayout root = (RelativeLayout) findViewById(R.id.splashLayout);
DisplayMetrics dm = new DisplayMetrics();
this.getWindowManager().getDefaultDisplay().getMetrics(dm);
int statusBarOffset = dm.heightPixels - root.getMeasuredHeight();
int originalPos[] = new int[2];
splashImage.getLocationOnScreen(originalPos);
int xDest = dm.widthPixels / 2;
xDest -= (splashImage.getMeasuredWidth() / 2);
int yDest = dm.heightPixels / 2 - (splashImage.getMeasuredHeight() / 2)
- statusBarOffset;
TranslateAnimation anim = new TranslateAnimation(0, xDest
- originalPos[0], 0, yDest - originalPos[1]);
anim.setDuration(3000);
set.addAnimation(anim);
Animation fadeOut = FadeOut(1000);
fadeOut.setStartOffset(3000);
set.addAnimation(fadeOut);
set.setFillAfter(true);
set.setFillEnabled(true);
splashImage.startAnimation(set);
}
private Animation FadeIn(int t) {
Animation fade;
fade = new AlphaAnimation(0.0f, 1.0f);
fade.setDuration(t);
fade.setInterpolator(new AccelerateInterpolator());
return fade;
}
private Animation FadeOut(int t) {
Animation fade;
fade = new AlphaAnimation(1.0f, 0.1f);
fade.setDuration(t);
fade.setInterpolator(new AccelerateInterpolator());
return fade;
}
这里我尝试做的是,通过在图像上应用动画设置,将启动图像从特定位置移动到较低的位置。这里的FadeIn,FadeOut只是改变图像alpha的动画,所以你只需要给动画集提供你自己的动画即可。
希望对您有所帮助。
此致,