2
A
回答
9
的想法很简单:
- 保存活动为您提供为位图
- 分割位分为两个部分
- 动画位图向外(上下)
为了让活动的位图:
View root = currActivity.getWindow().getDecorView().findViewById(android.R.id.content);
root.setDrawingCacheEnabled(true);
Bitmap bmp = root.getDrawingCache();
为了分割位:
int splitYCoord = (splitYCoord != -1 ? splitYCoord : bmp.getHeight()/2);
if (splitYCoord > bmp.getHeight())
throw new IllegalArgumentException("Split Y coordinate [" + splitYCoord + "] exceeds the activity's height [" + bmp.getHeight() + "]");
Bitmap mBmp1 = Bitmap.createBitmap(bmp, 0, 0, bmp.getWidth(), splitYCoord);
Bitmap mBmp2 = Bitmap.createBitmap(bmp, 0, splitYCoord, bmp.getWidth(), bmp.getHeight() - splitYCoord);
private static int[] mLoc1;
private static int[] mLoc2;
mLoc1 = new int[]{0, root.getTop()};
mLoc2 = new int[]{0, root.getTop() + splitYCoord};
private static ImageView mTopImage;
private static ImageView mBottomImage;
mTopImage = createImageView(destActivity, mBmp1, mLoc1);
mBottomImage = createImageView(destActivity, mBmp2, mLoc2);
private static ImageView createImageView(Activity destActivity, Bitmap bmp, int loc[]) {
ImageView imageView = new ImageView(destActivity);
imageView.setImageBitmap(bmp);
WindowManager.LayoutParams windowParams = new WindowManager.LayoutParams();
windowParams.gravity = Gravity.TOP;
windowParams.x = loc[0];
windowParams.y = loc[1];
windowParams.height = ViewGroup.LayoutParams.WRAP_CONTENT;
windowParams.width = ViewGroup.LayoutParams.WRAP_CONTENT;
windowParams.flags =
WindowManager.LayoutParams.FLAG_LAYOUT_IN_SCREEN
windowParams.format = PixelFormat.TRANSLUCENT;
windowParams.windowAnimations = 0;
destActivity.getWindowManager().addView(imageView, windowParams);
return imageView;
}
我们创建位图后,动画应用
AnimatorSet mSetAnim = new AnimatorSet();
mTopImage.setLayerType(View.LAYER_TYPE_HARDWARE, null);
mBottomImage.setLayerType(View.LAYER_TYPE_HARDWARE, null);
mSetAnim.addListener(new Animator.AnimatorListener() {
@Override
public void onAnimationEnd(Animator animation) {
clean(destActivity);
}
@Override
public void onAnimationCancel(Animator animation) {
clean(destActivity);
}
...
});
Animator anim1 = ObjectAnimator.ofFloat(mTopImage, "translationY", mTopImage.getHeight() * -1);
Animator anim2 = ObjectAnimator.ofFloat(mBottomImage, "translationY", mBottomImage.getHeight());
mSetAnim.setDuration(duration);
mSetAnim.playTogether(anim1, anim2);
mSetAnim.start();
private void clean(Activity activity) {
if (mTopImage != null) {
mTopImage.setLayerType(View.LAYER_TYPE_NONE, null);
try {
activity.getWindowManager().removeViewImmediate(mBottomImage);
} catch (Exception ignored) {}
}
if (mBottomImage != null) {
mBottomImage.setLayerType(View.LAYER_TYPE_NONE, null);
try {
activity.getWindowManager().removeViewImmediate(mTopImage);
} catch (Exception ignored) {}
}
mBmp1 = null;
mBmp2 = null;
}
上面的代码只是为参考目的。你可以从下面的链接找到完整的演示。
相关问题
- 1. UIView垂直翻转动画
- 2. 圆形菜单与动画/转换的垂直切换
- 3. 动画垂直ViewPager
- 4. UIView的垂直翻转动画
- 5. ScrollViewer垂直偏移动画
- 6. css3/jquery动画/转换/:如何使图像垂直向后移动?
- 7. Viewpager Transform动画为垂直滑动
- 8. 动画:水平和垂直移动ImageButton
- 9. 在画布中垂直旋转图像
- 10. iOS上的垂直滚动动画'跳转'
- 11. Android:垂直画廊?
- 12. 垂直居中全屏div滚动条
- 13. Android - 使画廊垂直滚动
- 14. jQuery垂直动画栏教程
- 15. Android动画垂直图像视图
- 16. jQuery:动画到垂直位置
- 17. J2ME画布上的垂直滚动条
- 18. iPhone垂直视图控制器动画
- 19. iPhone dev:UIWebview在转动设备时转换垂直位置
- 20. jQuery slideDown函数垂直跳转动画结束
- 21. 如何反转此CSS3垂直下拉动画?
- 22. 转换垂直参考水平参考
- 23. 转换垂直列表阵列
- 24. 转换水平台垂直在Oracle
- 25. 如何垂直/向上转换?
- 26. 转换下拉菜单到垂直
- 27. 将水平表转换为垂直Postgres
- 28. 垂直画廊在Android
- 29. 画一条垂直线
- 30. 画布垂直指向线
+1哇!太棒了!非常感谢! :)我现在就试试! – Roylee 2013-04-20 04:31:37
那么它支持API 8? – Roylee 2013-04-20 07:08:11
@Roylee实际上,我们需要编写我们自己的代码,以便在代码中使用上层android api。 – 2013-04-20 09:11:09