You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

52 lines
4.8 KiB

<<<<<<< HEAD
# OSChina Android [客户端](http://www.oschina.net/app/)
##写在前面的话
从2.3版本开始项目已经完成了gradle化完全迁移到了android studio如果想使用eclipse进行该项目的学习可以clone [tag v2.2.1](http://git.oschina.net/oschina/android-app/tree/v2.2.1/)不过需要注意的是eclipse需要按照开发环境中提到的进行butterknife注解设置
##开发环境
由于使用了较多的Eclipse项目Library项目目前使用的是Eclipse。需要提示的是由于butterknife注解特性Eclipse需要开启注解功能详细方法参考[这里](http://www.jcodecraeer.com/a/anzhuokaifa/androidkaifa/2015/0102/2247.html)。对于使用Android Studio的开发者可能你们需要等待一段时间项目目前正在Gradle化。当然我们也欢迎由你来转换项目并通过PullRequest提交给我们充分发挥社区化协作的优势。
##项目简述
1. 底部导航
* 主界面的底部TAB导航采用[FragmentTabHost](http://git.oschina.net/oschina/osc-android-app/blob/master/osc-android-app/src/net/oschina/app/ui/MainTab.java)点击底部按钮时切换Fragment。中间的快捷操作按钮使用的是[自定义dialog](http://git.oschina.net/oschina/osc-android-app/blob/master/osc-android-app/src/net/oschina/app/ui/QuickOptionDialog.java),通过点击时加入动画效果实现。
2. 一级界面
* 包括资讯、动弹两个模块,采用[ViewPagerFragment](http://git.oschina.net/oschina/osc-android-app/blob/master/osc-android-app/src/net/oschina/app/viewpagerfragment/NewsViewPagerFragment.java)根据滑动到不同页面显示不同信息。
3. 详情界面
* 详情界面包括[博客详情](http://git.oschina.net/oschina/osc-android-app/blob/master/osc-android-app/src/net/oschina/app/fragment/BlogDetailFragment.java)[动弹详情](http://git.oschina.net/oschina/osc-android-app/blob/master/osc-android-app/src/net/oschina/app/fragment/TweetDetailFragment.java)[新闻详情](http://git.oschina.net/oschina/osc-android-app/blob/master/osc-android-app/src/net/oschina/app/fragment/NewsDetailFragment.java)[帖子详情](http://git.oschina.net/oschina/osc-android-app/blob/master/osc-android-app/src/net/oschina/app/fragment/PostDetailFragment.java) [活动详情](http://git.oschina.net/oschina/osc-android-app/blob/master/osc-android-app/src/net/oschina/app/fragment/EventDetailFragment.java)等……是通过在Fragment中的WebView直接loadData()加载一段html数据并显示。
* 而详情Fragment的显示则是通过一个外部DetailActivity来根据传入的参数不同来加载不同的Fragment。
4. 链接跳转
* 整个应用打开链接的规则都定义在UIHelper.openBrowser()方法中本方法会根据不同的url去解析如果是www.oschina.net的链接则会调用相应的界面去展示如果是git.oschina.net我们目前会使用手机自带的浏览器打开(之后会改为使用[OscGit客户端](http://git.oschina.net/oschina/git-osc-android-project)打开)如果不是oschina的站内链接则使用内置浏览器打开。
5. 侧滑菜单
* [侧滑菜单](http://git.oschina.net/oschina/osc-android-app/blob/master/osc-android-app/src/net/oschina/app/ui/NavigationDrawerFragment.java)采用系统的DrawerLayout实现。关于很多朋友好奇的左上角箭头是采用的开源控件[DrawerArrowDrawable](http://git.oschina.net/oschina/osc-android-app/blob/master/osc-android-app/src/net/oschina/app/widget/DrawerArrowDrawable.java)(准确的说不应该是控件而是一个Drawable)
##依赖包介绍
1. jar包依赖
* 网络请求库 **android-async-http** http://loopj.com/android-async-http/
* 注解绑定控件 **butterknife** http://jakewharton.github.io/butterknife/
* 网络图片加载库 **KJFrameForAndroid** http://git.oschina.net/kymjs/KJFrameForAndroid
* XML解析库 **xstream** http://xstream.codehaus.org/
2. 源码依赖
* **PhotoView-library** :用于图片预览界面展示
* **UmengShareLib** :用于分享到第三方平台
##开源协议
Copyright (C) 2014, The OSChina Open Source Project
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 2 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License along
with this program; if not, write to the Free Software Foundation, Inc.,
51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
=======
#osc-android-app
>>>>>>> 096f8630d9ff1ecb7e413fdf8860848fc381ad9f