【问题标题】:How to cleanly superpose ScrollableViews in Android如何在 Android 中干净地叠加 ScrollableViews
【发布时间】:2012-04-19 05:49:48
【问题描述】:

为了实现导航栏ala Facebook 我有以下布局配置:

<FrameLayout
  android:layout_width="match_parent"
  android:layout_height="match_parent"
>
   <!-- This is the Lower Layer hosting the navbar -->
   <LinearLayout
      android:layout_width="match_parent"
      android:layout_height="match_parent"
   >
      <!-- ListView representing the navbar -->
      <ListView 
       />
   </LinearLayout>

   <!-- This is the Top Layer hosting the Content -->
   <FrameLayout 
      android:layout_width="match_parent"
      android:layout_height="match_parent"
   > 
      <!-- This is where the View of the Content will be injected -->
   </FrameLayout>
</FrameLayout>

所以基本的想法是,当我想打开 navbar 时,我只需将 TopLayer 向右移动,导航栏就会显示出来。 现在这很好用,我可以与 navbar 的 ListView 交互,以便在应用程序中导航,只要注入到 TopLayer 中的视图不是 ScrollableView(比如另一个ListViewScrollViewWebView)。

例如,当TopLayerWebView实例时,我无法滚动并与导航栏的 ListView进行交互,因为滚动的是WebView(尽管我把它移到了右边)。

我想叠加许多ScrollableView 并不是一件容易的事,但我希望有一些技巧可以克服这些问题。

感谢您的帮助!

编辑

顺便说一句,这就是我转移TopLayerview 的方式(使用TranslateAnimation):

TranslateAnimation translateAnim = new TranslateAnimation(0.0F, mListView.getWidth(), 0.0F, 0.0F);
translateAnim.setDuration(..);
translateAnim.setFillAfter(true);
mTopLayerView.startAnimation(translateAnim);

【问题讨论】:

    标签: android android-layout android-side-navigation


    【解决方案1】:

    根据我的应用 - Android UI Patterns (https://play.google.com/store/apps/details?id=com.groidify.uipatterns),Facebook 导航和动画有 2 个示例实现,这是:

    如果有效,你可以试一试吗?

    【讨论】:

      【解决方案2】:

      原来问题不是由于叠加ScrollableViews 或其他原因,而是由于使用TranslateAnimation 时动画视图的逻辑位置(即:不可见)仍然绑定到其原始位置。因此,当我以为我在点击导航项时,实际上我正在与我认为已经移动的ContentView 进行交互。

      现在我正在使用ObjectAnimator,它解决了这个问题并且效果很好。我只需要确保与 Pre-Honeycomb 设备的兼容性(我正在考虑使用 NineOldAndroids 解决这个问题。如果有人知道使用旧动画 API 正确解决此问题的任何其他替代方法,请随时回答此 question) .

      【讨论】:

        猜你喜欢
        • 1970-01-01
        • 1970-01-01
        • 2016-08-06
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 2013-03-01
        • 2014-01-11
        相关资源
        最近更新 更多