- 浏览: 1846632 次
- 性别:
- 来自: 深圳
文章分类
- 全部博客 (665)
- 闲话 (17)
- ruby (1)
- javascript (40)
- linux (7)
- android (22)
- 开发过程 (11)
- 哥也读读源代码 (13)
- JVM (1)
- ant (2)
- Hibernate (3)
- jboss (3)
- web service (17)
- https (4)
- java基础 (17)
- spring (7)
- servlet (3)
- 杂记 (39)
- struts2 (10)
- logback (4)
- 多线程 (2)
- 系统诊断 (9)
- UI (4)
- json (2)
- Java EE (7)
- eclipse相关 (4)
- JMS (1)
- maven (19)
- 版本管理 (7)
- sso (1)
- ci (1)
- 设计 (18)
- 戒烟 (4)
- http (9)
- 计划 (4)
- HTML5 (3)
- chrome extensions (5)
- tomcat源码阅读 (4)
- httpd (5)
- MongoDB (3)
- node (2)
最新评论
-
levin_china:
勾选了,还是找不到
用spring annotation声明的bean,当打包在jar中时,无法被扫描到 -
GGGGeek:
我用的maven-3.5.0,还没有遇到这种情况,使用jar ...
用spring annotation声明的bean,当打包在jar中时,无法被扫描到 -
GGGGeek:
受益匪浅,从组织项目结构,到技术细节,讲的很到位,只是博主不再 ...
一个多maven项目聚合的实例 -
Aaron-Joe-William:
<?xml version="1.0" ...
hibernate逆向工程 -
li272355201:
http://archive.apache.org/dist/ ...
tomcat源码阅读(一)——环境搭建
这篇博客是参考helloandroid兄的腾讯微博应用,我整理了一下。完整项目的介绍请在http://helloandroid.iteye.com/看
首先是效果图:
我把helloandroid兄的源代码整理了一下,并梳理了涉及到的知识点,总结如下:
1、TabActivity的使用
可以看到,TabActivity是继承自Activity,包含了一个TabHost组件。TabHost组件则是继承自FrameLayout的ViewGroup。
TabHost组件本身的id必须是@android:id/tabhost,它必须包含一个FrameLayout,并且该FrameLayout的id必须是@android:id/tabcontent,此外还要包含一个TabWidget,id是@android:id/tabs。
FrameLayout可以放置每个单独的Activity,而TabWidget则是每个Tab页签。默认第一个页签对应的Activity,会首先显示在FrameLayout里。然后每次点击其他的Tab页签,对应的Activity就会切换显示到FrameLayout里。这个有点类似html中的frameset的概念
2、在main.xml中有一行
作用是引入另一个View文件,head_line.xml
用这种方式可以实现View组件的复用,是很方便的,可以学习一下这种方式。把要复用的View写在单独的xml文件里,然后在其他需要的地方,只要直接include就可以了
3、每个Tab页签对应的View是tab_item.xml
然后在java代码中进行组装
这部分的详细说明,可以看google提供的API
4、然后这个页面中用到了selector的概念,即当要动态改变某些组件的属性,如颜色,字体大小等,可以用selector来进行动态选择,这里有点类似CSS中的伪类的概念
上面代码的意思是,根据按钮控件是否按下,是否选择,在运行时动态决定颜色。通过同样的方式,还可以动态决定一个按钮的图片
5、这个页面还用到了一个比较特殊的技巧,就是通过xml,而不是静态图片来绘制背景
上面代码中的android:background="@drawable/header",指向drawable文件夹中的header.xml
可以看到,这个控件的背景色,是用xml绘制出来的。不过这个技巧我在别的地方见的比较少,感觉比较冷门
关于TabHost组件的知识点,就简单介绍这些。详细的内容,请到helloandroid.iteye.com里看
首先是效果图:
我把helloandroid兄的源代码整理了一下,并梳理了涉及到的知识点,总结如下:
1、TabActivity的使用
public class MainActivity extends TabActivity { private TabHost tabHost; @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.main); tabHost = getTabHost(); populateTab(); } /** * 组装tab控件 */ private void populateTab() { Resources res = getResources(); populateTabItem(R.drawable.tab_home_selector, res.getString(R.string.tab_home), new Intent(this, HomeActivity.class)); populateTabItem(R.drawable.tab_atme_selector, res.getString(R.string.tab_refer), new Intent(this, ReferActivity.class)); populateTabItem(R.drawable.tab_message_selector, res.getString(R.string.tab_secret), new Intent(this, MessageActivity.class)); populateTabItem(R.drawable.tab_explore_selector, res.getString(R.string.tab_search), new Intent(this, SearchActivity.class)); populateTabItem(R.drawable.tab_focus_selector, res.getString(R.string.tab_attention), new Intent(this, AttentionActivity.class)); } /** * 生成tab_item * * @param imageResourceSelector * 图片选择器 * @param text * 文本 * @param intent * intent */ private void populateTabItem(int imageResourceSelector, String text, Intent intent) { View view = View.inflate(this, R.layout.tab_item, null);// 拼装view ((ImageView) view.findViewById(R.id.tab_item_imageview)) .setImageResource(imageResourceSelector); ((TextView) view.findViewById(R.id.tab_item_textview)).setText(text); TabSpec spec = tabHost.newTabSpec(text).setIndicator(view) .setContent(intent);// 将view注入spec tabHost.addTab(spec); } }
<?xml version="1.0" encoding="UTF-8"?> <TabHost android:id="@android:id/tabhost" android:layout_width="fill_parent" android:layout_height="fill_parent" xmlns:android="http://schemas.android.com/apk/res/android"> <RelativeLayout android:orientation="vertical" android:layout_width="fill_parent" android:layout_height="fill_parent"> <include android:id="@+id/head_line" layout="@layout/head_line" android:layout_width="fill_parent" android:layout_height="wrap_content" /> <FrameLayout android:id="@android:id/tabcontent" android:layout_below="@id/head_line" android:layout_width="fill_parent" android:layout_height="fill_parent" android:layout_weight="1.0" /> <TabWidget android:id="@android:id/tabs" android:background="@drawable/tab_bkg" android:layout_gravity="bottom" android:layout_height="60.0dip" android:layout_width="fill_parent" android:fadingEdge="none" android:fadingEdgeLength="0.0px" android:paddingLeft="0.0dip" android:paddingTop="2.0dip" android:paddingRight="0.0dip" android:paddingBottom="0.0dip" android:layout_alignParentBottom="true" android:layout_alignParentTop="false" /> </RelativeLayout> </TabHost>
可以看到,TabActivity是继承自Activity,包含了一个TabHost组件。TabHost组件则是继承自FrameLayout的ViewGroup。
TabHost组件本身的id必须是@android:id/tabhost,它必须包含一个FrameLayout,并且该FrameLayout的id必须是@android:id/tabcontent,此外还要包含一个TabWidget,id是@android:id/tabs。
FrameLayout可以放置每个单独的Activity,而TabWidget则是每个Tab页签。默认第一个页签对应的Activity,会首先显示在FrameLayout里。然后每次点击其他的Tab页签,对应的Activity就会切换显示到FrameLayout里。这个有点类似html中的frameset的概念
2、在main.xml中有一行
<include android:id="@+id/head_line" layout="@layout/head_line" android:layout_width="fill_parent" android:layout_height="wrap_content" />
作用是引入另一个View文件,head_line.xml
<RelativeLayout android:background="@drawable/header" android:layout_width="fill_parent" android:layout_height="wrap_content" xmlns:android="http://schemas.android.com/apk/res/android"> <Button android:id="@+id/top_btn_left" android:textColor="@color/button_text_selector" android:background="@drawable/top_refresh_selector" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_marginLeft="12.0dip" android:layout_alignParentLeft="true" android:layout_centerVertical="true" /> <Button android:id="@+id/top_btn_right" android:textColor="@color/button_text_selector" android:background="@drawable/top_edit_selector" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_marginRight="12.0dip" android:layout_alignParentRight="true" android:layout_centerVertical="true" /> <TextView android:id="@+id/top_title" android:textSize="22.0sp" android:textColor="@color/head_line_text" android:ellipsize="middle" android:gravity="center_horizontal" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="@string/user_name" android:singleLine="true" android:layout_toLeftOf="@id/top_btn_right" android:layout_toRightOf="@id/top_btn_left" android:layout_centerInParent="true" android:layout_alignWithParentIfMissing="true" /> </RelativeLayout>
用这种方式可以实现View组件的复用,是很方便的,可以学习一下这种方式。把要复用的View写在单独的xml文件里,然后在其他需要的地方,只要直接include就可以了
3、每个Tab页签对应的View是tab_item.xml
<?xml version="1.0" encoding="UTF-8"?> <LinearLayout android:orientation="vertical" android:layout_width="fill_parent" android:layout_height="wrap_content" xmlns:android="http://schemas.android.com/apk/res/android"> <ImageView android:id="@+id/tab_item_imageview" android:layout_width="fill_parent" android:layout_height="32.0dip" android:scaleType="fitCenter" /> <TextView android:id="@+id/tab_item_textview" android:layout_width="fill_parent" android:layout_height="wrap_content" android:gravity="center" android:singleLine="true" android:marqueeRepeatLimit="1" android:textSize="11.0sp" android:ellipsize="marquee" /> </LinearLayout>
然后在java代码中进行组装
View view = View.inflate(this, R.layout.tab_item, null);// 拼装view ((ImageView) view.findViewById(R.id.tab_item_imageview)) .setImageResource(imageResourceSelector); ((TextView) view.findViewById(R.id.tab_item_textview)).setText(text); TabSpec spec = tabHost.newTabSpec(text).setIndicator(view) .setContent(intent);// 将view注入spec tabHost.addTab(spec);
这部分的详细说明,可以看google提供的API
4、然后这个页面中用到了selector的概念,即当要动态改变某些组件的属性,如颜色,字体大小等,可以用selector来进行动态选择,这里有点类似CSS中的伪类的概念
android:textColor="@color/button_text_selector"
<?xml version="1.0" encoding="UTF-8"?> <selector xmlns:android="http://schemas.android.com/apk/res/android"> <item android:state_pressed="true" android:color="@color/button_text_pressed" /> <item android:state_selected="true" android:color="@color/button_text_pressed" /> <item android:color="@color/button_text_normal" /> </selector>
上面代码的意思是,根据按钮控件是否按下,是否选择,在运行时动态决定颜色。通过同样的方式,还可以动态决定一个按钮的图片
<selector xmlns:android="http://schemas.android.com/apk/res/android"> <item android:state_focused="false" android:state_selected="false" android:state_pressed="false" android:drawable="@drawable/top_edit_normal" /> <item android:state_focused="false" android:state_selected="true" android:state_pressed="false" android:drawable="@drawable/top_edit_press" /> <item android:state_focused="true" android:state_selected="false" android:state_pressed="false" android:drawable="@drawable/top_edit_normal" /> <item android:state_focused="true" android:state_selected="true" android:state_pressed="false" android:drawable="@drawable/top_edit_press" /> <item android:state_pressed="true" android:drawable="@drawable/top_edit_press" /> </selector>
5、这个页面还用到了一个比较特殊的技巧,就是通过xml,而不是静态图片来绘制背景
<RelativeLayout android:background="@drawable/header" android:layout_width="fill_parent" android:layout_height="wrap_content" xmlns:android="http://schemas.android.com/apk/res/android">
上面代码中的android:background="@drawable/header",指向drawable文件夹中的header.xml
<?xml version="1.0" encoding="UTF-8"?> <shape android:shape="rectangle" xmlns:android="http://schemas.android.com/apk/res/android"> <gradient android:startColor="#ff6c7078" android:endColor="#ffa6abb5" android:angle="270.0" android:type="linear" /> </shape>
可以看到,这个控件的背景色,是用xml绘制出来的。不过这个技巧我在别的地方见的比较少,感觉比较冷门
关于TabHost组件的知识点,就简单介绍这些。详细的内容,请到helloandroid.iteye.com里看
发表评论
-
最近半个月开发小结
2011-12-05 22:16 13201、有一个方法,有一段 ... -
android培训文档提纲(四)
2011-11-27 23:28 12531、生命周期方法onSaveInstanceState()是在 ... -
Tasks and Back Stack
2011-11-22 23:47 1187Even though the activities may ... -
上周开发过程中几个简单问题的总结
2011-11-21 13:18 1369上周开发中组员遇到几个问题,都不是大问题,但都耽搁了一些时间。 ... -
android培训文档提纲(三)
2011-11-12 23:47 17721、Activity和Service组件是Context的子类 ... -
android的Log组件和logcat命令
2011-11-12 23:03 6333项目进入开发阶段了, ... -
android培训文档提纲(二)
2011-11-07 21:10 1671一、Each Activity can make an ... -
android培训文档提纲(一)
2011-10-23 14:05 1614最近项目快要进入开发 ... -
顶部有一排按钮,最底下还有FooterView的ListView页面
2011-08-13 15:46 3308先上效果图: 下面详细说说这个页面是怎么做出来的: 1、 ... -
PendingIntent
2011-08-08 16:02 1564在开发SMS等应用时,有时调用相关的API会要求提供一个类型为 ... -
android数据持久化总结
2011-08-06 12:23 19241、 通过Context.getSharedPreferenc ... -
intent and service
2011-08-04 00:07 1426明天才开始讨论包需求 ... -
最近两周android总结
2011-08-01 23:42 1621最近2周预研做得差不多 ... -
没有单元测试,怎能写代码
2011-07-25 17:56 1575项目前期的技术点预研完成了,最近开始做原型开发。 之前没有在 ... -
android process and thread
2011-07-18 16:31 1703前三周android预研中,把可能用到的技术点都识别了,并完成 ... -
android第三周小结
2011-07-18 10:16 13691. 系统自带的通讯录应用,联系人名单保存在data/data ... -
onPause()方法的特殊性
2011-07-15 17:11 2938onPause(), onStop(), onDestroy( ... -
activity存在的三种状态
2011-07-15 16:44 1782An activity can exist in essent ... -
android第二周小结
2011-07-14 10:50 11681. 做了短信侦听的Broadca ... -
android一周小结
2011-07-04 21:26 1239做了一周android预研,总结以下几条: 1. 用DDMS ...
相关推荐
标题提到的"ActionBar用Tab+ViewPager+Fragment实现快速导航"是一种常见的做法,它充分利用了Android SDK提供的组件和模式来创建一个可滑动、分页的界面,使用户能够轻松地在多个内容区域之间切换。以下是对这个主题...
- 实现3DM网站的文章内容在移动端上的展示,包括按照网站分类进行归类和分页展示。 - 支持根据网站的不同分类展示相应文章,并实现分页加载功能。 #### 三、具体功能需求 - **启动页**:设计简洁明了的启动界面...
有了这个新的分页扩展名,您将获得精美的新分页,其中的背景墙纸会随着您在网络中浏览而随机变化,而在该领域没有任何区别。 借助Gravity Falls Wallpaper New Tab扩展程序,除了改组壁纸以外,您还可以获得其他一些...
3. **上拉加载更多**:此功能用于分页加载内容,用户向上滑动屏幕时,更多内容会自动加载。这在内容数量庞大的应用中很有用,避免一次性加载所有数据导致的性能问题和用户界面的拥堵。它有助于优化用户体验,让用户...
- 控件数量不宜过多,超过10个时考虑使用分页显示,同时支持快捷键Ctrl+Tab进行页面切换。 - 默认按钮应支持Enter键选择,按下后自动执行相应操作。 - 非法输入后,可编辑控件应给出提示并自动获取焦点。 - Tab...
9. **无障碍性(Accessibility)**:确保自动完成功能对辅助技术友好,如支持键盘导航(Tab和Enter键)和屏幕阅读器。 10. **库与框架**:实际开发中,可以使用现有的JS库(如jQuery UI Autocomplete、Typeahead.js...
* 分页界面要支持在页面间快捷切换,常见组合快捷键 Ctrl+Tab。 * 默认按钮要支持 Enter 操作,即按 Enter 后自动实施默认按钮对应操作。 * 可写控件检测到非法输入后应给出说明并能自动取得焦点。 * Tab 键次序和...
分页是Chrome使用者界面中最重要的元素,为梯形设计,其位于窗口的最上方而非控制按钮的下方(与Opera类似)。这项改变与许多目前的分页浏览器做法不同。不同窗口的分页可轻易的利用拖曳的方式交换配置。每一个...
相同功能的按钮用框区分,减少鼠标移动,按功能划分界面区块,支持键盘导航,控制界面控件数量,使用分页界面,设定默认按钮,处理非法输入,保持Tab键顺序一致,合理使用下拉框和选项框,以及采用通用术语。...
7. **Ctrl + SHIFT + C**: 显示类视图窗口 - 展示项目中的类结构,方便导航。 8. **F4**: 显示属性窗口 - 在选定对象时,显示其属性和详细信息。 9. **SHIFT + F4**: 显示项目属性窗口 - 修改项目设置和配置。 10...
- 或者,使用视图模式中的“分页预览”查看整个工作簿。 **38. 快速删除工作表中的空行** - 使用条件格式化功能,标记出空行 -> 使用筛选功能选择空行 -> 删除。 **39. 绘制斜线表头** - 选中单元格 -> 在“开始”...