以下代码是我尝试将mMyView发送到mPivotParent的子集的前面或后面,因此它将呈现在其他人的顶部或后面。在我的情况下,隐藏视图不就足够了。
mPivotParent是一个FrameLayout。
查看mPivotParent.mChildren
表明我的代码“有效”,因为正确设置了顺序。但它对z顺序没有影响。不仅如此,重新定位代码被调用的次数越多,帧速率就会越来越慢。共有4个孩子,mPivotParent.mChildrenCount
仍然保持在4个预期状态。
我的目标是API级别7。
@Override
public boolean onTouchEvent(MotionEvent event) {
Display display = getWindowManager().getDefaultDisplay();
float x = event.getRawX();
float sWidth = (int)display.getWidth();
float xLerpFromCenter = ((x / sWidth) - .5f) * 2.f; // [-1, 1]
mRotateAnimation.mfLerp = xLerpFromCenter;
if(xLerpFromCenter < -0.2f && mPivotParent.getChildAt(0) != mMyView)
{
mPivotParent.removeView(mMyView);
mPivotParent.addView(mMyView, 0);
refreshEverything();
}
else if(xLerpFromCenter > 0.2f && mPivotParent.getChildAt(0) == mMyView)
{
mPivotParent.removeView(mMyView);
mPivotParent.addView(mMyView, mPivotParent.getChildCount() - 1);
refreshEverything();
}
return super.onTouchEvent(event);
}
private void refreshEverything()
{
for(int i = 0; i < mPivotParent.getChildCount(); ++i)
{
mPivotParent.getChildAt(i).invalidate();
mPivotParent.getChildAt(i).requestLayout();
}
mPivotParent.invalidate();
mPivotParent.requestLayout();
}
答案 0 :(得分:5)
部分解决方案
这是一个效率低下的黑客,但它适用于我的目的,即将顶部项目发送到后面,保持所有其他项目的顺序相同。
private void putFrontAtBack()
{
for(int i = 0; i < mPivotParent.getChildCount() - 1; ++i)
{
mPivotParent.getChildAt(0).bringToFront();
}
refreshEverything();
}
注意: 这在任意重新排序的一般情况下不起作用。
答案 1 :(得分:1)
试试这个。
private void reorder(int[] order)
{
if(order == null || order.length != mPivotParent.getChildCount()) return;
for(int i = order.length - 1; i >= 0; i--)
{
mPivotParent.getChildAt(order[i]).bringToFront();
}
refreshEverything();
}
此代码提供任意重新排序。整数数组&#34; order&#34;用于表示每个视图的新顺序,其中order [n] = x表示childAt(x)的新顺序为n。