Hello开发人员和程序员。我刚开始学习android app开发。找到了很棒的导航栏样式,并希望开发类似的设计。它有背景图像,滚动时会移动。
请帮我开发一样。谢谢。我添加了一个示例gif作为链接。
答案 0 :(得分:1)
这可以通过使用导航抽屉的自定义布局以及DrawerLayout.DrawerListener
的自定义实现来实现。下面是一个非常简单的示例,可以很容易地适应Android Studio的“新项目 - >导航抽屉活动”生成的代码。
<?xml version="1.0" encoding="utf-8"?>
<android.support.v4.widget.DrawerLayout
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:id="@+id/drawer_layout"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:fitsSystemWindows="true"
tools:openDrawer="start">
<include
layout="@layout/app_bar_main"
android:layout_width="match_parent"
android:layout_height="match_parent"/>
<FrameLayout
android:id="@+id/nav_view"
android:layout_width="@dimen/navdrawer_width"
android:layout_height="match_parent"
android:layout_gravity="start"
android:background="#ccc">
<ImageView
android:id="@+id/image"
android:layout_width="256dp"
android:layout_height="256dp"
android:layout_gravity="center"
android:src="@drawable/mydrawable"/>
</FrameLayout>
</android.support.v4.widget.DrawerLayout>
public class MainActivity extends AppCompatActivity {
private ImageView iv;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
iv = (ImageView) findViewById(R.id.image);
DrawerLayout drawer = (DrawerLayout) findViewById(R.id.drawer_layout);
DrawerLayout.DrawerListener listener = new MyActionBarDrawerListener();
drawer.addDrawerListener(listener);
}
private class MyActionBarDrawerListener extends DrawerLayout.SimpleDrawerListener {
@Override
public void onDrawerSlide(View drawerView, float slideOffset) {
super.onDrawerSlide(drawerView, slideOffset);
int navdrawerWidth = getResources().getDimensionPixelSize(R.dimen.navdrawer_width);
float closedAmount = (1 - slideOffset);
int marginStart = 2 * (int) (navdrawerWidth * closedAmount);
ViewGroup.MarginLayoutParams params = (ViewGroup.MarginLayoutParams) iv.getLayoutParams();
MarginLayoutParamsCompat.setMarginStart(params, marginStart);
iv.setLayoutParams(params);
}
}
}
解决方案的核心是您提供背景图像,但在抽屉滑动时更新其marginStart
属性。您可以摆弄确切的数字以获得您喜欢的滑动量。
请注意,为了提高可读性,我省略了很多代码。在实践中,您可能会MyActionBarDrawerListener
从ActionBarDrawerToggle
延伸,以便获得导航图标等。
答案 1 :(得分:0)
看起来并不那么难,但它仍然不那么容易因为这种效果据说是Parallax effect
。我做了一个坚实的谷歌搜索,但仍然无法找到一个有用的库。所以你必须自己做这件事
步骤
完成抽屉布局后,添加图片作为片段的背景
调用mSlidingDrawer.addDrawerListner(new YourDrawerListner())
方法//就像Ben P。
onDrawerSlide(View drawerView, float slideOffset)
onDrawerSlide(...)
中使用偏移量mImage.animate().setTranslationX(offset).start()
Ben P.答案更好但你可以使用我的也只是将Ben P.的DrawerListner部分添加到我的答案中
是视差效应。基于元素的相对运动