Android开发之模仿UC浏览器的菜单
这个内容内容涉及到的了两个知识点:
PopupWindow:使用PopupWindow创建一个简单的菜单
使用TabHost创建标签:这个网上好多教程随便看看就好。
实现思路:
观察一下UC浏览器的菜单我们可以发现,UC的菜单就是一个个标签页显示在了PopupWindow上,所以可以想到使用PopupWindow+TabHost来实现类似的效果。这样做,在标签页中我们可以使用android提供布局对象随意设置布局。
下面来看代码:
想要实现这种效果的菜单,默认的PopupWindow明显需要重写:
- public class MyMenu extends PopupWindow {
- private TabHost tabHost; //标签页窗口
- private LayoutInflater inflater; //用于加载tabhost
- private View layout;
- private Context context;
- //构造函数
- public MyMenu(Context context, int width, int height) {
- super(context);
- this.context = context;
- inflater = LayoutInflater.from(this.context);
- //创建标签页
- initTab();
- //设置默认选项
- setWidth(width); //宽
- setHeight(height); //高
- setContentView(tabHost); //把标签页设置到PopupWindow上
- }
- //实例化标签页
- private void initTab(){
- layout = inflater.inflate(R.layout.menu,null);
- tabHost = (TabHost)layout. findViewById(android.R.id.tabhost); //获取tabhost
- tabHost.setBackgroundColor(Color.argb(60,144,144,150)); //设置背景色
- tabHost.setup(); //使用findViewById()加载tabhost时在调用addTab前必须调用
- /**
- * addTab()添加标签页
- * tabHost.newTabSpec("Fitst") 创建一个tab
- * setIndicator("A") 设置指针
- * setContent(R.id.tab1)设置内容
- */
- tabHost.addTab(tabHost.newTabSpec("Fitst").setIndicator("A").setContent(R.id.tab1));
- tabHost.addTab(tabHost.newTabSpec("SECOND").setIndicator("B").setContent(R.id.tab2));
- tabHost.addTab(tabHost.newTabSpec("THIRD").setIndicator("C").setContent(R.id.tab3));
- tabHost.setCurrentTab(1); //设置默认选种标签
- }
- //获取选项卡中的组件
- public View getOption(int id){
- return layout.findViewById(id);
- }
- }
复制代码
菜单的布局文件res/layout/menu.xml
- <?xml version="1.0" encoding="utf-8"?>
- <TabHost xmlns:android="http://schemas.android.com/apk/res/android"
- android:id="@android:id/tabhost"
- android:layout_width="fill_parent"
- android:layout_height="fill_parent"
- >
- <LinearLayout
- android:orientation="vertical"
- android:layout_height="fill_parent"
- android:layout_width="fill_parent">
- <TabWidget
- android:id="@android:id/tabs"
- android:layout_height="40dp"
- android:layout_width="fill_parent"
- />
- <FrameLayout
- android:id="@android:id/tabcontent"
- android:layout_width="fill_parent"
- android:layout_height="fill_parent">
- <LinearLayout
- android:layout_width="fill_parent"
- android:layout_height="fill_parent"
- android:id="@+id/tab1">
- <Button
- android:layout_height="wrap_content"
- android:layout_width="wrap_content"
- android:text="Tab one"
- android:id="@+id/first_button"
- />
- </LinearLayout>
- <LinearLayout
- android:layout_width="fill_parent"
- android:layout_height="fill_parent"
- android:id="@+id/tab2">
- <TextView
- android:layout_height="wrap_content"
- android:layout_width="wrap_content"
- android:text="Tab two"
- />
- </LinearLayout>
- <LinearLayout
- android:layout_width="fill_parent"
- android:layout_height="fill_parent"
- android:id="@+id/tab3">
- <TextView
- android:layout_height="wrap_content"
- android:layout_width="wrap_content"
- android:text="Tab three"目前菜单的样子还是比较丑陋了,美化大家自己发挥好了!/>
- </LinearLayout>
- </FrameLayout>
- </LinearLayout>
- </TabHost>
在Activity中使用:
- public class MyActivity extends Activity
- {
- private MyMenu menu;
- private LinearLayout linear;
- @Override
- public void onCreate(Bundle savedInstanceState)
- {
- super.onCreate(savedInstanceState);
- setContentView(R.layout.main);
- init();
- }
- //组件初始化
- private void init(){
- linear = (LinearLayout) findViewById(R.id.popMenu);
- int width = getWindowManager().getDefaultDisplay().getWidth()-15; //菜单的宽度
- int heigth = getWindowManager().getDefaultDisplay().getHeight()/3; //菜单的高度
- menu = new MyMenu(this, width,heigth);
- Button button= (Button) menu.getOption(R.id.first_button); //获取菜单第一个标签页中的按钮
- //添加点击事件
- button.setOnClickListener(new Button.OnClickListener(){
- public void onClick(View v) {
- Toast.makeText(MyActivity.this,"tab one",Toast.LENGTH_SHORT).show();
- }
- });
- }
- //显示菜单
- private void show(){
- menu.showAtLocation(linear, Gravity.BOTTOM|Gravity.CENTER_HORIZONTAL,0,0);
- }
- @Override
- public boolean onKeyDown(int keyCode, KeyEvent event) {
- //按以下菜单按键展示菜单 按两下隐藏菜单
- if(!menu.isShowing()&&keyCode == KeyEvent.KEYCODE_MENU){
- show();
- }
- else{
- menu.dismiss();
- }
- return true;
- }
- }
Android开发之模仿UC浏览器的菜单的更多相关文章
- 前端开发在手机UC浏览器上遇到的坑
1.user-scalable问题 写手机页面都会加一个meta标签 <meta content="width=device-width, initial-scale=1.0, max ...
- Android开发工程师文集-提示框,菜单,数据存储,组件篇
提示框,菜单,数据存储,组件篇 Toast Toast.makeText(context, text, 时间).show(); setDuration();//设置时间 setGravity();// ...
- Android开发学习之3大类菜单
在Android系统中,菜单可以分为三类:选项菜单(Option Menu),上下文菜单(Context Menu)以及子菜单(Sub Menu). 一.选项菜单(Option Menu) 创建选项菜 ...
- Android 开发一定要看的15个实战项目
前言: 虽说网上有太多的Android课程,但是大多都是视频,有Android在线开发环境的几乎没有,但是对于学习Android的人来说拥有在线的Android开发环境是非常好的,可以随时动手操作学习 ...
- UC浏览器插件开发
pip install UC浏览器插件是个什么玩意? 如图所看到的,便是UC的插件面板. UC通过开放浏览器插件api, 使开发人员可以进行插件的开发. 插件种类: 1 : extension. 就是 ...
- UC浏览器调试移动端网站
准备工作: UC浏览器开发版网址 UC浏览器开发者版下载地址 下载adb_tool 步骤: 1.将adb_tool解压,把里面的文件复制到 C:\Windows\SysWOW64 文件夹下面. 2.运 ...
- 站在巨人的肩膀上学习Android开发
我们知道,一開始最好的学习方法是模仿,尤其是模仿巨人. 那说到Android开发的模仿自然就是分析并研究主流程序的布局.实现方法.进而提升自己的技术. 第一招----逆向project 要分析&quo ...
- Android 高仿UC浏览器监控剪切板弹出悬浮窗功能
UC浏览器应该是android手机里 最流行的浏览器之一了,他们有一个功能 相信大家都体验过,就是如果你复制了什么文字,(在其他app中 复制也有这个效果!,所以能猜到肯定是监控了剪切板),就会弹出一 ...
- android仿微信红包动画、Kotlin综合应用、Xposed模块、炫酷下拉视觉、UC浏览器滑动动画等源码
Android精选源码 仿微信打开红包旋转动画 使用Kotlin编写的Android应用,内容你想象不到 Android手机上的免Root Android系统日志Viewer 一个能让微信 Mater ...
随机推荐
- oracle 表空间自己主动扩展大小
select a.FILE_NAME,a.AUTOEXTENSIBLE,a.MAXBYTES,a.INCREMENT_BY from dba_data_files a; --AUTOEXTENSI ...
- go语言基础之同级目录
1.同级目录 分文件编程(多个源文件),必须放在src目录 同一个目录,包名必须一样 设置GOPATH环境变量 go env 查看go相关环境路径 GO PATH: 在windows系统中,添加go环 ...
- 玩转OpenStack
一.OpenStack包含那些内容 1.预备知识 首先会有虚拟化和云计算的“预备知识”,会介绍 KVM,IaaS 等技术. 2.OpenStack核心 包含OpenStack的架构和和各个核心组件. ...
- iOS开发-UINavigationController简单介绍
导航条或者说导航栏目现在在App中基本上也算是标配,类似于父子级别的味道在里面,UINavigationController就是负责简化这一实现功能的,属于iOS开发中比较常用的一种容器View co ...
- word 文档如何加密
给Word文档加密主要有以下几个方法:文件加密文件菜单设置:1.打开需要加密的Word文档.2.选“文件”的“另存为”,出现“另存为”对话框,在“工具”中选“常规选项”,出现“保存”选项卡.3.分别在 ...
- [Backbone]5. Model & View, toggle between Models and Views -- 2
Dr. Goodparts is pretty flaky and has been cancelling a lot of appointments lately. He's asked for a ...
- 最新phpstudy2016安装教程及流程
最新phpstudy2016安装教程及流程,帮助站长快速搭建网站服务器平台! phpstudy软件简介 该程序包集成最新的Apache+Nginx+LightTPD+PHP+MySQL+phpMyAd ...
- Python中参数多个值的表示法
今天在写Python脚本时,调用了数据管理-制图综合-融合工具,在ArcGIS里操作的参数设置如下: 如果融合字段只有一个那好办,如果融合字段有多个我该怎么表达,查看帮助文档中的示例代码明白了: 所以 ...
- linux上安装BeatifulSoup(第三方python库)
1. 什么是beatifulsoup? beatifulsoup官网http://www.crummy.com/software/BeautifulSoup/ BeatifulSoup是用Python ...
- 使用 Spring 2.5 TestContext 测试框架
Spring 2.5 TestContext 测试框架用于测试基于 Spring 的程序,TestContext 测试框架和低版本 Spring 测试框架没有任何关系,是一个全新的基于注解的测试框架, ...