首页
/ ArcNavigationView 开源项目教程

ArcNavigationView 开源项目教程

2024-08-16 00:21:15作者:贡沫苏Truman
ArcNavigationView
Another approach to create NavigationDrawer with Material concepts

项目介绍

ArcNavigationView 是一个基于 Material Design 概念的导航抽屉实现,它提供了独特的曲线边缘效果,为传统的滑动式侧边栏带来了视觉上的新颖感。此项目由 Roman Zavarnitsyn 创建于2017年,灵感源自Florent Champigny的ArcLayout,并在此基础上进行了调整优化。遗憾的是,该项目已被作者于2020年6月28日归档,目前处于只读状态。

项目快速启动

要将 ArcNavigationView 快速集成到您的项目中,您需要完成以下步骤:

添加依赖

首先,在您的Android项目的 build.gradle(Module级别)文件中的 dependencies 块添加以下依赖:

dependencies {
    implementation 'com.rom4ek:arcnavigationview:2.0.0'
}

然后同步 Gradle 以使新依赖生效。

XML布局配置

在您的XML布局文件中,替换常规的 DrawerLayout 为 ArcNavigationView,如下面的示例所示:

<android.support.v4.widget.DrawerLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    android:id="@+id/drawer_layout"
    android:layout_width="match_parent"
    android:layout_height="match_parent">

    <!-- 主内容视图 -->
    
    <!-- ArcNavigationView 实例 -->
    <com.rom4ek.arcnavigationview.ArcNavigationView
        android:id="@+id/nav_view"
        android:layout_width="wrap_content"
        android:layout_height="match_parent"
        android:layout_gravity="start"
        app:menu="@menu/activity_main_drawer"
        app:arc_width="96dp"
        app:arc_cropDirection="cropInside"/>

</android.support.v4.widget.DrawerLayout>

记得设置您的菜单资源(@menu/activity_main_drawer)和适当的宽度。

支持右对齐

若要让导航抽屉出现在屏幕右侧,使用 endright 重力,并确保支持右到左(RTL)布局。

应用案例和最佳实践

为了防止子视图在使用右对齐模式时被裁剪,特别是在从左到右(LTR)布局中,应确保应用支持RTL方向:

  1. AndroidManifest.xml<application> 标签内加入 android:supportsRtl="true"
  2. 在 ArcNavigationView 中添加 android:layoutDirection="rtl"

此外,推荐在API 21及以上版本中启用状态栏和导航栏的半透明效果,这可以通过在对应的styles.xml中添加以下代码实现:

<style name="AppTheme.TranslucentBars">
    <item name="android:windowTranslucentStatus">true</item>
    <item name="android:windowTranslucentNavigation">true</item>
</style>

并确保在运行时将该主题应用于相应的Activity。

典型生态项目

由于此仓库已归档,目前没有直接相关或延伸的“典型生态项目”来讨论。然而,对于那些寻求类似UI效果的开发者来说,可能需要探索最新的开源项目或Material Design的官方组件更新,以寻找新的解决方案或者灵感。


本教程提供了一个基础框架,引导您开始使用 ArcNavigationView。尽管项目不再维护,但在许多旧项目中,它仍能发挥价值,或是作为自定义UI设计的一个学习案例。开发新项目时,建议考虑官方库的最新更新或其他活跃的开源替代品,以获得持续的支持和兼容性。

ArcNavigationView
Another approach to create NavigationDrawer with Material concepts
热门项目推荐
相关项目推荐

项目优选

收起
CangjieCommunity
为仓颉编程语言开发者打造活跃、开放、高质量的社区环境
Markdown
669
0
RuoYi-Vue
🎉 基于SpringBoot,Spring Security,JWT,Vue & Element 的前后端分离权限管理系统,同时提供了 Vue3 的版本
Java
136
18
openHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
12
7
redis-sdk
仓颉语言实现的Redis客户端SDK。已适配仓颉0.53.4 Beta版本。接口设计兼容jedis接口语义,支持RESP2和RESP3协议,支持发布订阅模式,支持哨兵模式和集群模式。
Cangjie
322
26
advanced-java
Advanced-Java是一个Java进阶教程,适合用于学习Java高级特性和编程技巧。特点:内容深入、实例丰富、适合进阶学习。
JavaScript
75.83 K
19.04 K
qwerty-learner
为键盘工作者设计的单词记忆与英语肌肉记忆锻炼软件 / Words learning and English muscle memory training software designed for keyboard workers
TSX
15.56 K
1.44 K
Jpom
🚀简而轻的低侵入式在线构建、自动部署、日常运维、项目监控软件
Java
1.41 K
292
Yi-Coder
Yi Coder 编程模型,小而强大的编程助手
HTML
30
5
easy-es
Elasticsearch 国内Top1 elasticsearch搜索引擎框架es ORM框架,索引全自动智能托管,如丝般顺滑,与Mybatis-plus一致的API,屏蔽语言差异,开发者只需要会MySQL语法即可完成对Es的相关操作,零额外学习成本.底层采用RestHighLevelClient,兼具低码,易用,易拓展等特性,支持es独有的高亮,权重,分词,Geo,嵌套,父子类型等功能...
Java
1.42 K
231
taro
开放式跨端跨框架解决方案,支持使用 React/Vue/Nerv 等框架来开发微信/京东/百度/支付宝/字节跳动/ QQ 小程序/H5/React Native 等应用。 https://taro.zone/
TypeScript
35.34 K
4.77 K