我们下面使用Activity,模拟一个dialog:

首先看布局:

<?xml version="1.0" encoding="utf-8"?>

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="vertical"
android:layout_width="270dp"
android:layout_height="wrap_content"
android:gravity="center_horizontal"
> <!--标题-->
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="分享到哪里?"
android:textSize="18sp"
android:padding="10dp"
android:textColor="@color/dialog_title_color"
android:gravity="center_horizontal"
/> <!--分割线-->
<View
android:layout_width="match_parent"
android:layout_height="1dp"
android:background="@color/bg_action_bar_color"
/> <!--分享到哪里-->
<GridView
android:id="@+id/dialog_share_grid_view"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:listSelector="@drawable/empty_selector"
android:numColumns="3"
android:horizontalSpacing="10dp"
android:verticalSpacing="15dp"
android:layout_margin="10dp"
/>
</LinearLayout>

然后是该Activity

package cn.via.dageeeOrderFood.activity;

import android.app.Activity;
import android.os.Bundle;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.GridView;
import android.widget.ImageView;
import android.widget.TextView;
import cn.via.dageeeOrderFood.R; /**
* Created by Heyiyong on 2014-3-5 上午9:12.
*/
public class ShareActivity extends Activity {
private int[] shareIcons = {
R.drawable.ic_share_duanxin,
R.drawable.ic_share_pengyouquan,
R.drawable.ic_share_qq,
R.drawable.ic_share_qqkongjian,
R.drawable.ic_share_weixin,
}; private String[] shareTitles = {
"短信", "朋友圈", "QQ好友", "QQ空间", "微信"
}; public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.dialog_share); GridView gridView = (GridView) findViewById(R.id.dialog_share_grid_view);
gridView.setAdapter(new BaseAdapter() {
@Override
public int getCount() {
return shareIcons.length;
} @Override
public Object getItem(int i) {
return null;
} @Override
public long getItemId(int i) {
return 0;
} @Override
public View getView(int i, View view, ViewGroup viewGroup) {
View itemView = View.inflate(ShareActivity.this, R.layout.item_share_grid_view, null);
((ImageView) itemView.findViewById(R.id.item_share_img)).setImageResource(shareIcons[i]);
((TextView) itemView.findViewById(R.id.item_share_tv)).setText(shareTitles[i]);
return itemView;
}
});
}
}

gridView的item布局

<?xml version="1.0" encoding="utf-8"?>

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="vertical"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:gravity="center_horizontal"
android:background="@drawable/share_grid_view_item_selector_xml"
> <ImageView
android:id="@+id/item_share_img"
android:layout_width="56dp"
android:layout_height="56dp"
android:src="@drawable/ic_share_duanxin"
android:padding="4dp"
/> <TextView
android:id="@+id/item_share_tv"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="短信"
android:textSize="13sp"
android:layout_marginTop="3dp"
android:textColor="@color/dialog_content_color"
/>
</LinearLayout>

最后在AndroidManifest文件:

  <!--分享的dialogActivity-->
<activity
android:name=".activity.ShareActivity"
android:theme="@style/dialogActivity"
/>

其中theme为:

    <!--用activity模拟dialog-->
<style name="dialogActivity">
<item name="android:windowBackground">@android:color/transparent</item>
<item name="android:windowFrame">@null</item>
<item name="android:windowNoTitle">true</item>
<item name="android:windowIsFloating">true</item>
<item name="android:windowIsTranslucent">true</item>
<item name="android:windowContentOverlay">@null</item>
<item name="android:windowBackground">@drawable/dialog_bg_update</item>
<item name="android:windowAnimationStyle">@android:style/Animation.Dialog</item>
<item name="android:backgroundDimEnabled">true</item>
</style>

drawable/dialog_bg_update.xml

<?xml version="1.0" encoding="utf-8"?>

<shape xmlns:android="http://schemas.android.com/apk/res/android">
<solid android:color="@color/dialog_background_color"/>
<!--<stroke android:color="#ff5e5e5e" android:width="1dp"/>-->
<stroke android:color="@color/bg_action_bar_color" android:width="1dp"/>
<corners android:radius="10dp"/>
</shape>

drawable/share_grid_view_item_selector_xml.xml

<?xml version="1.0" encoding="utf-8"?>

<selector xmlns:android="http://schemas.android.com/apk/res/android">
<item android:state_pressed="true">
<shape xmlns:android="http://schemas.android.com/apk/res/android">
<solid android:color="@color/item_press_color"/>
<corners android:radius="5dp"/>
</shape>
</item>
<item>
<shape xmlns:android="http://schemas.android.com/apk/res/android">
<solid android:color="@color/dialog_background_color"/>
</shape>
</item>
</selector>

android 使用Activity做窗口弹出(模拟Dialog)的更多相关文章

  1. android PopupWindow实现从底部弹出或滑出选择菜单或窗口

    本实例弹出窗口主要是继承PopupWindow类来实现的弹出窗体,布局可以根据自己定义设计.弹出效果主要使用了translate和alpha样式实现,具体实习如下: 第一步:设计弹出窗口xml: &l ...

  2. MFC弹出模拟对话框

    Windows对话框分为两类:模态对话框和非模态对话框. 模态对话框是这样的对话框,当它弹出后,本应用程序其他窗口将不再接受用户输入,只有该对话框响应用户输入,在对它进行相应操作退出后,其他窗口才能继 ...

  3. Android ListView 长按列表弹出菜单

    Android ListView 长按列表弹出菜单 设置长按菜单 listView.setOnCreateContextMenuListener(new View.OnCreateContextMen ...

  4. JavaScript动态实现div窗口弹出&消失功能

    先积累一个JavaScript动态实现div窗口弹出&消失功能 首先是index.jsp代码 <html> <head> <link rel="styl ...

  5. 实现 像网易云音乐 播放列表那样的弹出型Dialog

    如图 所示是点击Test之后的 弹出的Dialog (请无视我工程的命名) 20161017/**加入点击回调,假设dialog里放了一个TextView*/ 得先写一个点击回调 public int ...

  6. CKEDITOR 4.6.X 版本 插件 弹出对话框 Dialog中 表格 Table 自定义样式Style 问题

    项目开发过程中,发现CKEDITOR 插件的弹出框 内 如果跟据项目需要写表格(table tr td),表格的边框等属性会被 CKEDITOR的清除或覆盖,导致表格很难看. 问题关键: 插件弹出框d ...

  7. Android Demo---实现从底部弹出窗口

    在前面的博文中,小编简单的介绍了如何制作圆角的按钮以及圆角的图片,伴着键盘和手指之间的舞步,迎来新的问题,不知道小伙伴有没有这样的经历,以App为例,点击头像的时候,会从底部弹出一个窗口,有从相册中选 ...

  8. 【Android】百度地图自定义弹出窗口

    我们使用百度地图的时候,点击地图上的Marker,会弹出一个该地点详细信息的窗口,如下左图所示,有时候,我们希望自己定义这个弹出窗口的内容,或者,干脆用自己的数据来构造这样的弹出窗口,但是,在百度地图 ...

  9. android中使用PopupWindow实现弹出窗口菜单

    结合上篇android中使用ViewPager实现图片拖动,我们实现了点击“帮助”按钮的功能,这一篇则是接着上一篇,让我们一起来完成“我的”按钮的功能,这一功能,则是使用PopupWindow来实现弹 ...

随机推荐

  1. 【转载】 c语言inline函数的使用

    c语言inline函数的使用 转载自:http://blog.chinaunix.net/uid-21843265-id-3056446.html 大学在教科书上学习过inline函数,定义为inli ...

  2. Web前端开发:SQL Jsp小项目(一)

    Jsp的学习算是告一段落,针对这段时间的学习,写了一个Jsp小项目来巩固学到的知识. 框架示意图 User list process UserAdd process 需要的界面效果: 需要工具:Ecl ...

  3. iOS开发——根据Url 获取图片尺寸

    转自:http://www.oschina.net/code/snippet_2248391_53038 // 根据图片url获取图片尺寸 +(CGSize)getImageSizeWithURL:( ...

  4. Koajs原理

    Koajs让习惯阻塞式代码写法的同学感到很舒服,再也不用盖楼式的callback了,而且也不需要学习Promise的then,catch这些新东西. 但实际上,Koajs这样的写法有点像是语言的语法糖 ...

  5. 找个输入IPoint在某个FeatureClass上距离最近的要素

      /// <summary> /// 得到输入点在输入图层上的最近点 /// </summary> /// <param name="randomPoints ...

  6. CAF(C++ actor framework)使用随笔(同步发送 异步与同步等待)(三)

    c). 同步发送, 等待响应, 超时后收到1个系统消息. 贴上代码 #include <iostream> #include "caf/all.hpp" #includ ...

  7. Unity基本操作一

    1,使对象进入摄像机镜头内align with view 2,太阳光 创建点point light,调节Intensity改变光照强度,上面的Range改变光照范围. 3,Animation选中Pla ...

  8. mysql 之路目录

    数据库介绍.常见分类 Mysql入门 Mysql安装配置 Mysql多实例安装配置 Mysql常用基本命令 Mysql数据库备份和恢复 Mysql日志 Mysql逻辑.物理备份和增量恢复 Mysql字 ...

  9. 表格细边框 并且CSS3加圆角

    .YJ table{width:625px;height:860px;text-align:center;overflow:hidden; background:#fff;border-radius: ...

  10. 【原】隐藏ultraGrid1指定列

    void uGrdAllFlight_InitializeRow(object sender, InitializeRowEventArgs e) { /***********TEST START** ...