我正在开发一个具有多个活动的应用程序,我想像 snapchat 那样实现滑动(左、右、上、下)活动(不是片段)之间的转换。我做了一些研究,但我没有找到合适的方法。可以有人建议我如何处理上述情况?谢谢。
2 回答
我不相信您可以通过使用活动来获得同样流畅的滑动。(有人随时纠正我)。您可以手动捕获滑动并加载下一个活动。您不会看到“预览”,这与单击按钮非常相似。
视图寻呼机提供的流畅性是由于碎片。同样(如果我没记错的话),一次只能向用户呈现一个活动。因此,您无法显示下一个活动的预览。片段解决了这个问题,因为你可以有多个片段。
我不确定您是否有充分的理由不使用片段。它们非常易于使用,您或多或少仍然可以使用活动。每个活动都有一个片段。
因此,虽然我不想在您想使用活动时回避回答问题,但我不相信您将能够继续使用活动并获得预期的结果。与尝试使用活动自定义功能相比,您将更容易使用片段。
http://developer.android.com/training/animation/screen-slide.html
http://developer.android.com/training/implementing-navigation/lateral.html
想要验证您不能同时进行 2 个活动。因此,无论您必须将功能从单个活动中拆分出来才能做到这一点。尽管您“可以”在没有碎片的情况下做到这一点,但您最终会得到一个复杂的解决方案。我建议使用 Android 提供的并将其转换为片段。它非常简单。
您可以通过 5 个布局将它们放在一起来做到这一点......例如,只有 1 个可见菜单......而不是当用户触摸右侧时,例如 layout_right 将弹出将尝试从右向左移动,但前提是用户将从右向左滑动布局...而不是 layout_right 将出现在 menu_layout 的第一个布局上...并且将开始淡入...如果用户想要转到菜单将向左向右滑动进入第一个布局菜单
一些例子:
private void slide(final View v) {
if (v.getLeft() != 0) {
Animation toLeft = new TranslateAnimation(v.getRight() - 72, 0, 0, 0);
toLeft.setDuration(animDuration);
toLeft.setAnimationListener(new AnimationListener() {
@Override
public void onAnimationStart(Animation animation) {
}
@Override
public void onAnimationRepeat(Animation animation) {
}
@Override
public void onAnimationEnd(Animation animation) {
v.clearAnimation();
RelativeLayout.LayoutParams params = (LayoutParams) v
.getLayoutParams();
params.leftMargin = 0;
params.rightMargin = 0;
v.setLayoutParams(params);
}
});
v.startAnimation(toLeft);
}
else {
Animation toRigh = new TranslateAnimation(0, -v.getWidth() - 72, 0, 0);
toRigh.setDuration(animDuration);
toRigh.setAnimationListener(new AnimationListener() {
@Override
public void onAnimationStart(Animation animation) {
}
@Override
public void onAnimationRepeat(Animation animation) {
}
@Override
public void onAnimationEnd(Animation animation) {
v.clearAnimation();
RelativeLayout.LayoutParams params = (LayoutParams) v
.getLayoutParams();
params.leftMargin = (int) -(v.getWidth() - v.getWidth() * .15f);
params.rightMargin = (int) (v.getWidth() * .85f);
v.setLayoutParams(params);
}
});
v.startAnimation(toRigh);
}
}
private void slideBack(final View v) {
if (v.getLeft() != 0) {
Animation toLeft = new TranslateAnimation(-v.getLeft(), 0, 0, 0);
toLeft.setDuration(animDuration + 100);
toLeft.setAnimationListener(new AnimationListener() {
@Override
public void onAnimationStart(Animation animation) {
}
@Override
public void onAnimationRepeat(Animation animation) {
}
@Override
public void onAnimationEnd(Animation animation) {
v.clearAnimation();
RelativeLayout.LayoutParams params = (LayoutParams) v
.getLayoutParams();
params.leftMargin = 0;
params.rightMargin = 0;
v.setLayoutParams(params);
}
});
v.startAnimation(toLeft);
}
}
@Override
public boolean onTouch(View v, MotionEvent event) {
if (event.getAction() == MotionEvent.ACTION_DOWN) {
xPos = (int) event.getX();
}
if (event.getAction() == MotionEvent.ACTION_MOVE) {
RelativeLayout.LayoutParams params = (LayoutParams) v.getLayoutParams();
if (params.rightMargin + 1 > 0) {
params.leftMargin = (int) (event.getRawX() - xPos);
params.rightMargin = (int) (-event.getRawX() + xPos);
v.setLayoutParams(params);
}
}
if (event.getAction() == MotionEvent.ACTION_UP) {
RelativeLayout.LayoutParams params = (LayoutParams) v.getLayoutParams();
if (params.rightMargin < v.getWidth() / 2) {
params.leftMargin = 0;
params.rightMargin = 0;
}
else {
params.leftMargin = (int) -(v.getWidth() - v.getWidth() * .15f);
params.rightMargin = (int) (v.getWidth() * .85f);
}
v.setLayoutParams(params);
}
return true;
}
}