自定义ShareDialog视图
1. share_item.xml
- <?xml version="1.0" encoding="utf-8"?>
- <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
- android:layout_width="fill_parent"
- android:layout_height="wrap_content"
- android:background="#00ffffff"
- android:padding="30dp"
- >
- <ImageView
- android:id="@+id/imageView1"
- android:layout_width="wrap_content"
- android:layout_height="30dp"
- android:layout_alignParentTop="true"
- android:layout_centerHorizontal="true"
- android:src="@drawable/ic_launcher"/>
- <TextView
- android:id="@+id/textView1"
- android:layout_width="wrap_content"
- android:layout_height="wrap_content"
- android:layout_below="@+id/imageView1"
- android:layout_centerHorizontal="true"
- android:layout_marginTop="2dp"
- android:text="TextView"/>
- </RelativeLayout>
2.
share_dialog.xml
- <?xml version="1.0" encoding="utf-8"?>
- <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
- android:layout_width="fill_parent"
- android:layout_height="wrap_content"
- android:background="#00ffffff"
- android:padding="30dp"
- >
- <ImageView
- android:id="@+id/imageView1"
- android:layout_width="wrap_content"
- android:layout_height="30dp"
- android:layout_alignParentTop="true"
- android:layout_centerHorizontal="true"
- android:src="@drawable/ic_launcher"/>
- <TextView
- android:id="@+id/textView1"
- android:layout_width="wrap_content"
- android:layout_height="wrap_content"
- android:layout_below="@+id/imageView1"
- android:layout_centerHorizontal="true"
- android:layout_marginTop="2dp"
- android:text="TextView"/>
- </RelativeLayout>
3. ShareDialog.java
- package com.zps.sharedemo;
- import android.app.AlertDialog;
- import android.content.Context;
- import android.view.Gravity;
- import android.view.View.OnClickListener;
- import android.view.Window;
- import android.widget.AdapterView.OnItemClickListener;
- import android.widget.GridView;
- import android.widget.RelativeLayout;
- import android.widget.SimpleAdapter;
- import java.util.ArrayList;
- import java.util.HashMap;
- import java.util.List;
- public class ShareDialog {
- private AlertDialog dialog;
- private GridView gridView;
- private RelativeLayout cancelButton;
- private SimpleAdapter saImageItems;
- private int[] image = { R.drawable.a1, R.drawable.a2, R.drawable.a3,
- R.drawable.a4 };
- private String[] name = { "微博", "微信好友", "朋友圈", "QQ" };
- public ShareDialog(Context context) {
- dialog = new AlertDialog.Builder(context).create();
- dialog.show();
- Window window = dialog.getWindow();
- window.setGravity(Gravity.BOTTOM); // 非常重要:设置对话框弹出的位置
- window.setContentView(R.layout.share_dialog);
- gridView = (GridView) window.findViewById(R.id.share_gridView);
- cancelButton = (RelativeLayout) window.findViewById(R.id.share_cancel);
- List<HashMap<String, Object>> shareList = new ArrayList<HashMap<String, Object>>();
- for (int i = 0; i < image.length; i++) {
- HashMap<String, Object> map = new HashMap<String, Object>();
- map.put("ItemImage", image[i]);// 添加图像资源的ID
- map.put("ItemText", name[i]);// 按序号做ItemText
- shareList.add(map);
- }
- saImageItems = new SimpleAdapter(context, shareList,
- R.layout.share_item, new String[] { "ItemImage", "ItemText" },
- new int[] { R.id.imageView1, R.id.textView1 });
- gridView.setAdapter(saImageItems);
- }
- public void setCancelButtonOnClickListener(OnClickListener Listener) {
- cancelButton.setOnClickListener(Listener);
- }
- public void setOnItemClickListener(OnItemClickListener listener) {
- gridView.setOnItemClickListener(listener);
- }
- /**
- * 关闭对话框
- */
- public void dismiss() {
- dialog.dismiss();
- }
- }
4. MainActivity.java
- package com.zps.sharedemo;
- import java.util.HashMap;
- import android.app.Activity;
- import android.os.Bundle;
- import android.view.View;
- import android.widget.AdapterView;
- import android.widget.Button;
- public class MainActivity extends Activity implements View.OnClickListener
- {
- private Button shareButton;
- ShareDialog shareDialog;
- @Override
- protected void onCreate(Bundle savedInstanceState) {
- super.onCreate(savedInstanceState);
- setContentView(R.layout.activity_main);
- initView();
- }
- private void initView() {
- shareButton = (Button) findViewById(R.id.shareButton);
- shareButton.setOnClickListener(this);
- }
- @Override
- public void onClick(View v) {
- switch (v.getId()) {
- case R.id.shareButton:
- shareDialog = new ShareDialog(this);
- shareDialog.setCancelButtonOnClickListener(new View.OnClickListener() {
- @Override
- public void onClick(View v) {
- shareDialog.dismiss();
- }
- });
- shareDialog.setOnItemClickListener(new AdapterView.OnItemClickListener() {
- @Override
- public void onItemClick(AdapterView<?> arg0, View arg1,
- int arg2, long arg3) {
- HashMap<String, Object> item = (HashMap<String, Object>) arg0.getItemAtPosition(arg2);
- if (item.get("ItemText").equals("微博")) {
- } else if (item.get("ItemText").equals("微信好友")) {
- } else if (item.get("ItemText").equals("朋友圈")) {
- } else if (item.get("ItemText").equals("QQ")) {
- }
- shareDialog.dismiss();
- }
- });
- break;
- default:
- break;
- }
- }
- }
5. activity_main.xml
- <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
- xmlns:tools="http://schemas.android.com/tools"
- android:layout_width="match_parent"
- android:layout_height="match_parent"
- android:paddingBottom="@dimen/activity_vertical_margin"
- android:paddingLeft="@dimen/activity_horizontal_margin"
- android:paddingRight="@dimen/activity_horizontal_margin"
- android:paddingTop="@dimen/activity_vertical_margin"
- tools:context=".MainActivity" >
- <TextView
- android:layout_width="wrap_content"
- android:layout_height="wrap_content"
- android:text="@string/hello_world" />
- <Button
- android:id="@+id/shareButton"
- android:layout_width="wrap_content"
- android:layout_height="wrap_content" />
- </RelativeLayout>
自定义ShareDialog视图的更多相关文章
- UICollectionView(集合视图)以及自定义集合视图
一.UICollectionView集合视图 其继承自UIScrollView. UICollectionView类是iOS6新引进的API,用于展示集合视图,布局 ...
- Android 自定义View修炼-自定义HorizontalScrollView视图实现仿ViewPager效果
开发过程中,需要达到 HorizontalScrollView和ViewPager的效果,于是直接重写了HorizontalScrollView来达到实现ViewPager的效果. 实际效果图如下: ...
- 自定义View视图
自定义View视图文件查找逻辑 之前MVC5和之前的版本中,我们要想对View文件的路径进行控制的话,则必须要对IViewEngine接口的FindPartialView或FindView方法进行重写 ...
- 自定义MVC视图引擎ViewEngine 创建Model的专属视图
MVC内置的视图引擎有WebForm view engine和Razor view engine,当然也可以自定义视图引擎ViewEngine.本文想针对某个Model,自定义该Model的专属视图. ...
- Swift自定义头视图和尾视图
var data: [[String]]! override func viewDidLoad() { super.viewDidLoad() // Do any additional setup a ...
- ASP.NET MVC 自定义Razor视图WorkContext
概述 1.在ASP.NET MVC项目开发的过程中,我们经常需要在cshtml的视图层输出一些公用信息 比如:页面Title.服务器日期时间.页面关键字.关键字描述.系统版本号.资源版本号等 2.普通 ...
- Office365学习笔记—Xslt自定义列表视图
1,在Office365中需要添加自定义的视图!用Spd添加视图,这儿我添加一个testView! (1)打开testView.aspx将</ZoneTemplate>节点中的内容全部删除 ...
- 解读ASP.NET 5 & MVC6系列(16):自定义View视图文件查找逻辑
之前MVC5和之前的版本中,我们要想对View文件的路径进行控制的话,则必须要对IViewEngine接口的FindPartialView或FindView方法进行重写,所有的视图引擎都继承于该IVi ...
- sap表维护工具来维护自定义表&视图簇的使用
一.通过表维护工具维护自定义表 1.SE11创建表 2.se11界面的菜单:实用程序->Table Maintenance Generator其实这里就是调用SE54 3.sm30 调用维护好的 ...
随机推荐
- ExtJs3带条件的分页查询的实现
使用ExtJs的同志们一定知道GridPanel哈~神器一般,非常方便的显示表格类型的数据,例如神马用户列表.产品列表.销售单列表.XXXX列表等.从数据库中查询所需的数据,以列表的形式显示出来,我们 ...
- oracle——DDL
一.一些概念 定义: 主键--唯一标识一条记录,不能有重复的,不允许为空 外键--表的外键是另一表的主键, 外键可以有重复的, 可以是空值 索引--该字段没有重复值,但可以有一个空值 作用: 主键-- ...
- 坑人的 try catch finally
一直以为这样可以关闭 fs, 其实不行 static void Main(string[] args) { FileStream fs = null; try { fs = new FileStrea ...
- sigleSchool 存储过程例1
CREATE OR REPLACE PROCEDURE SINGLSCHOOL( PICIID IN VARCHAR2, SCHOOLID IN NUMBER, SCHETYPE IN number, ...
- 暑假学习日记:Splay树
从昨天开始我就想学这个伸展树了,今天花了一个上午2个多小时加下午2个多小时,学习了一下伸展树(Splay树),学习的时候主要是看别人博客啦~发现下面这个博客挺不错的http://zakir.is-pr ...
- 【QT】视频播放+文件选择
折腾了两个小时,太久没用了,找了半天的感觉. 先是在视频播放 的代码基础上加选择视频的按钮,开始总是显示两个框,后来发现需要用QSplitter来实现同时有多个框的情况. 把中心窗口设为这个split ...
- Hadoop-eclipse-plugin插件安装
Hadoop-eclipse-plugin插件安装 学习Hadoop有一段时间了,以前每次的做法都是先在win下用eclipse写好Mapreduce程序,然后打成jar文件,上传到linux下用ha ...
- hdu 1426 Sudoku Killer
题目:http://acm.hdu.edu.cn/showproblem.php?pid=1426 #include<stdio.h> #include<math.h> #in ...
- My_Plan
离清北夏令营不远了,今天时间也不太多了,貌似并不够我写一道题 所以就先挖个坑制定个计划啦 从5.10到5.20 先制定十天的计划吧 1.考试题的每道题目都要改出来并做总结 2.数位DP练习(十道+总结 ...
- 目标检测的图像特征提取之(三)Haar特征
1.Haar-like特征 Haar-like特征最早是由Papageorgiou等应用于人脸表示,Viola和Jones在此基础上,使用3种类型4种形式的特征. Haar特征分为三类:边缘特征.线性 ...