这个内容内容涉及到的了两个知识点:

PopupWindow:使用PopupWindow创建一个简单的菜单

使用TabHost创建标签:这个网上好多教程随便看看就好。

实现思路:

观察一下UC浏览器的菜单我们可以发现,UC的菜单就是一个个标签页显示在了PopupWindow上,所以可以想到使用PopupWindow+TabHost来实现类似的效果。这样做,在标签页中我们可以使用android提供布局对象随意设置布局。

下面来看代码:

想要实现这种效果的菜单,默认的PopupWindow明显需要重写:

  1. public class MyMenu extends PopupWindow {
  2. private TabHost tabHost;    //标签页窗口
  3. private LayoutInflater inflater;     //用于加载tabhost
  4. private View layout;
  5. private Context context;
  6. //构造函数
  7. public MyMenu(Context context, int width, int height) {
  8. super(context);
  9. this.context = context;
  10. inflater = LayoutInflater.from(this.context);
  11. //创建标签页
  12. initTab();
  13. //设置默认选项
  14. setWidth(width);          //宽
  15. setHeight(height);        //高
  16. setContentView(tabHost);  //把标签页设置到PopupWindow上
  17. }
  18. //实例化标签页
  19. private void initTab(){
  20. layout =  inflater.inflate(R.layout.menu,null);
  21. tabHost = (TabHost)layout. findViewById(android.R.id.tabhost);       //获取tabhost
  22. tabHost.setBackgroundColor(Color.argb(60,144,144,150));              //设置背景色
  23. tabHost.setup();           //使用findViewById()加载tabhost时在调用addTab前必须调用
  24. /**
  25. * addTab()添加标签页
  26. *      tabHost.newTabSpec("Fitst")  创建一个tab
  27. *      setIndicator("A") 设置指针
  28. *      setContent(R.id.tab1)设置内容
  29. */
  30. tabHost.addTab(tabHost.newTabSpec("Fitst").setIndicator("A").setContent(R.id.tab1));
  31. tabHost.addTab(tabHost.newTabSpec("SECOND").setIndicator("B").setContent(R.id.tab2));
  32. tabHost.addTab(tabHost.newTabSpec("THIRD").setIndicator("C").setContent(R.id.tab3));
  33. tabHost.setCurrentTab(1);                                            //设置默认选种标签
  34. }
  35. //获取选项卡中的组件
  36. public  View getOption(int id){
  37. return layout.findViewById(id);
  38. }
  39. }

复制代码

菜单的布局文件res/layout/menu.xml

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <TabHost xmlns:android="http://schemas.android.com/apk/res/android"
  3. android:id="@android:id/tabhost"
  4. android:layout_width="fill_parent"
  5. android:layout_height="fill_parent"
  6. >
  7. <LinearLayout
  8. android:orientation="vertical"
  9. android:layout_height="fill_parent"
  10. android:layout_width="fill_parent">
  11. <TabWidget
  12. android:id="@android:id/tabs"
  13. android:layout_height="40dp"
  14. android:layout_width="fill_parent"
  15. />
  16. <FrameLayout
  17. android:id="@android:id/tabcontent"
  18. android:layout_width="fill_parent"
  19. android:layout_height="fill_parent">
  20. <LinearLayout
  21. android:layout_width="fill_parent"
  22. android:layout_height="fill_parent"
  23. android:id="@+id/tab1">
  24. <Button
  25. android:layout_height="wrap_content"
  26. android:layout_width="wrap_content"
  27. android:text="Tab   one"
  28. android:id="@+id/first_button"
  29. />
  30. </LinearLayout>
  31. <LinearLayout
  32. android:layout_width="fill_parent"
  33. android:layout_height="fill_parent"
  34. android:id="@+id/tab2">
  35. <TextView
  36. android:layout_height="wrap_content"
  37. android:layout_width="wrap_content"
  38. android:text="Tab   two"
  39. />
  40. </LinearLayout>
  41. <LinearLayout
  42. android:layout_width="fill_parent"
  43. android:layout_height="fill_parent"
  44. android:id="@+id/tab3">
  45. <TextView
  46. android:layout_height="wrap_content"
  47. android:layout_width="wrap_content"
  48. android:text="Tab   three"目前菜单的样子还是比较丑陋了,美化大家自己发挥好了!/>
  49. </LinearLayout>
  50. </FrameLayout>
  51. </LinearLayout>
  52. </TabHost>

在Activity中使用:

  1. public class MyActivity extends Activity
  2. {
  3. private MyMenu menu;
  4. private LinearLayout linear;
  5. @Override
  6. public void onCreate(Bundle savedInstanceState)
  7. {
  8. super.onCreate(savedInstanceState);
  9. setContentView(R.layout.main);
  10. init();
  11. }
  12. //组件初始化
  13. private void init(){
  14. linear = (LinearLayout) findViewById(R.id.popMenu);
  15. int width = getWindowManager().getDefaultDisplay().getWidth()-15;      //菜单的宽度
  16. int heigth = getWindowManager().getDefaultDisplay().getHeight()/3;     //菜单的高度
  17. menu = new MyMenu(this, width,heigth);
  18. Button button= (Button) menu.getOption(R.id.first_button); //获取菜单第一个标签页中的按钮
  19. //添加点击事件
  20. button.setOnClickListener(new Button.OnClickListener(){
  21. public void onClick(View v) {
  22. Toast.makeText(MyActivity.this,"tab one",Toast.LENGTH_SHORT).show();
  23. }
  24. });
  25. }
  26. //显示菜单
  27. private void show(){
  28. menu.showAtLocation(linear, Gravity.BOTTOM|Gravity.CENTER_HORIZONTAL,0,0);
  29. }
  30. @Override
  31. public boolean onKeyDown(int keyCode, KeyEvent event) {
  32. //按以下菜单按键展示菜单 按两下隐藏菜单
  33. if(!menu.isShowing()&&keyCode == KeyEvent.KEYCODE_MENU){
  34. show();
  35. }
  36. else{
  37. menu.dismiss();
  38. }
  39. return true;
  40. }
  41. }

Android开发之模仿UC浏览器的菜单的更多相关文章

  1. 前端开发在手机UC浏览器上遇到的坑

    1.user-scalable问题 写手机页面都会加一个meta标签 <meta content="width=device-width, initial-scale=1.0, max ...

  2. Android开发工程师文集-提示框,菜单,数据存储,组件篇

    提示框,菜单,数据存储,组件篇 Toast Toast.makeText(context, text, 时间).show(); setDuration();//设置时间 setGravity();// ...

  3. Android开发学习之3大类菜单

    在Android系统中,菜单可以分为三类:选项菜单(Option Menu),上下文菜单(Context Menu)以及子菜单(Sub Menu). 一.选项菜单(Option Menu) 创建选项菜 ...

  4. Android 开发一定要看的15个实战项目

    前言: 虽说网上有太多的Android课程,但是大多都是视频,有Android在线开发环境的几乎没有,但是对于学习Android的人来说拥有在线的Android开发环境是非常好的,可以随时动手操作学习 ...

  5. UC浏览器插件开发

    pip install UC浏览器插件是个什么玩意? 如图所看到的,便是UC的插件面板. UC通过开放浏览器插件api, 使开发人员可以进行插件的开发. 插件种类: 1 : extension. 就是 ...

  6. UC浏览器调试移动端网站

    准备工作: UC浏览器开发版网址 UC浏览器开发者版下载地址 下载adb_tool 步骤: 1.将adb_tool解压,把里面的文件复制到 C:\Windows\SysWOW64 文件夹下面. 2.运 ...

  7. 站在巨人的肩膀上学习Android开发

    我们知道,一開始最好的学习方法是模仿,尤其是模仿巨人. 那说到Android开发的模仿自然就是分析并研究主流程序的布局.实现方法.进而提升自己的技术. 第一招----逆向project 要分析&quo ...

  8. Android 高仿UC浏览器监控剪切板弹出悬浮窗功能

    UC浏览器应该是android手机里 最流行的浏览器之一了,他们有一个功能 相信大家都体验过,就是如果你复制了什么文字,(在其他app中 复制也有这个效果!,所以能猜到肯定是监控了剪切板),就会弹出一 ...

  9. android仿微信红包动画、Kotlin综合应用、Xposed模块、炫酷下拉视觉、UC浏览器滑动动画等源码

    Android精选源码 仿微信打开红包旋转动画 使用Kotlin编写的Android应用,内容你想象不到 Android手机上的免Root Android系统日志Viewer 一个能让微信 Mater ...

随机推荐

  1. Java:字符串类简单的正则表达式

    class Test { public static void main(String[] args) { String str = "xia..as....yuan.com"; ...

  2. PHP语言基础之MySql 05 By ACReaper

    PHP的基本语法学完后,我们马上学下PHP如何和MySql进行交互.PHP和MySql进行交互的API可以分为两类,一类是面向过程的,一类是面向对象的,面向对象的我们等复习完面向对象再介绍,现在先介绍 ...

  3. 浅议 android下的context

    android学习中,最开始学习的一个类是activities,你是否知道他与context之间 的关系,我们经常用startactivities来唤起一个activities他的定义有在哪里了,他是 ...

  4. 安装Oracle之后解决掉的问题分享

    TNS-03505: 无法解析名称                                                            在测试tnsping的时候始终显示这么个问题. ...

  5. XXX全球 IP 地址库

    XXX全球 IP 地址库 Bulgaria 93.123.23.1 93.123.23.2 93.123.23.3 93.123.23.4 93.123.23.5 93.123.23.6 93.123 ...

  6. Eclipse.ini參数设置(Maven Integration for Eclipse JDK Warning)

    安装EclipseMaven插件后,Eclipse启动问题:Maven Integration for Eclipse JDK Warning.  解决方法: 1. 设置Eclipse使用的JRE为本 ...

  7. 设置tableViewCell背景颜色

    1 2 3 4 5 6 7 8 9 10 11 12 13 //方法一: cell.contentView.backgroundColor = [UIColor redColor]; //方法二: U ...

  8. wepy - 入手

    wepy官方文档: https://tencent.github.io/wepy/document.html#/ ESLint:一般用来校验JavaScript代码是否符合规范,不符合预期就报错(程序 ...

  9. base64 图片编码之再优化

    首先进入网站: http://b64.io/ 最多可减少图片体积容量近70%,建议不要优化base 64 图片格式为gif , 已实测如果用gif的话会增加容量.

  10. PHP高级教程-包含

    PHP 包含文件 PHP include 和 require 语句 在 PHP 中,您可以在服务器执行 PHP 文件之前在该文件中插入一个文件的内容. include 和 require 语句用于在执 ...