weiyi通讯录(三)仿微信下拉列表和android样式

2024-05-26 21:48

本文主要是介绍weiyi通讯录(三)仿微信下拉列表和android样式,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

这几天一直在找工作 就没有更新了 ,我还更新一点东西把,之前说过这个通讯录是仿微信的 所以今天介绍下拉列表的效果 

分享的是类似的代码 基本跟我的是一样。如果需要的联系人我把 或者加入我的交流群吧

-----------欢迎加入交流群 386451316 有问题一起讨论吧

代码下载:http://download.csdn.net/detail/u010982856/8232867

这里介绍两中方法  由于手机问题  不知道什么原因手机不能用 PopupWindow 方式 所以我使用的是activity的方式  很简单

先介绍activity 方式吧

方式一:

先说布局把


<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"android:layout_width="fill_parent"android:layout_height="fill_parent"android:background="#fcfcfc"android:orientation="vertical" ><RelativeLayoutandroid:id="@+id/title"android:layout_width="fill_parent"android:layout_height="45dp"android:background="@drawable/title_bar"android:gravity="center_vertical" ><ImageButtonandroid:id="@+id/title_btn"android:layout_width="67dp"android:layout_height="wrap_content"android:layout_alignParentLeft="true"android:layout_centerVertical="true"android:layout_marginLeft="5dp"android:background="@drawable/title_button"android:onClick="btnmainright"android:src="@drawable/title_btn_function" ></ImageButton><TextViewandroid:layout_width="wrap_content"android:layout_height="wrap_content"android:layout_centerInParent="true"android:text="微信"android:textColor="#ffffff"android:textSize="20sp" /><ImageButtonandroid:id="@+id/title_btn"android:layout_width="67dp"android:layout_height="wrap_content"android:layout_alignParentRight="true"android:layout_centerVertical="true"android:layout_marginRight="5dp"android:background="@drawable/title_button"android:onClick="btnmainright"android:src="@drawable/title_btn_function" /></RelativeLayout></LinearLayout>


<?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="fill_parent" ><RelativeLayoutandroid:layout_width="fill_parent"android:layout_height="fill_parent"android:layout_marginTop="50dp" ><LinearLayoutandroid:id="@+id/main_dialog_layout"android:layout_width="wrap_content"android:layout_height="wrap_content"android:layout_alignParentRight="true"android:layout_alignParentTop="true"android:background="@drawable/title_function_bg"android:orientation="vertical" ><LinearLayoutandroid:id="@+id/llayout01"android:layout_width="fill_parent"android:layout_height="wrap_content"android:layout_marginLeft="5dp"android:layout_marginRight="5dp"android:layout_marginTop="5dp"android:background="@drawable/title_list_selector"android:gravity="center_horizontal" ><TextViewandroid:layout_width="wrap_content"android:layout_height="wrap_content"android:layout_gravity="center_horizontal"android:padding="8dp"android:text="发起聊天"android:textColor="#fff"android:textSize="16sp" /></LinearLayout><ImageViewandroid:id="@+id/imageView5"android:layout_width="wrap_content"android:layout_height="wrap_content"android:src="@drawable/mm_title_functionframe_line" /><LinearLayoutandroid:id="@+id/llayout02"android:layout_width="fill_parent"android:layout_height="wrap_content"android:layout_marginLeft="5dp"android:layout_marginRight="5dp"android:background="@drawable/title_list_selector" ><ImageViewandroid:id="@+id/imageView2"android:layout_width="wrap_content"android:layout_height="wrap_content"android:layout_gravity="center_vertical"android:layout_marginLeft="8dp"android:src="@drawable/mm_title_btn_receiver_normal" /><TextViewandroid:layout_width="wrap_content"android:layout_height="wrap_content"android:padding="8dp"android:text="听筒模式"android:textColor="#fff"android:textSize="16sp" /></LinearLayout><ImageViewandroid:id="@+id/imageView5"android:layout_width="wrap_content"android:layout_height="wrap_content"android:src="@drawable/mm_title_functionframe_line" /><LinearLayoutandroid:id="@+id/llayout03"android:layout_width="fill_parent"android:layout_height="wrap_content"android:layout_marginLeft="5dp"android:layout_marginRight="5dp"android:background="@drawable/title_list_selector" ><ImageViewandroid:id="@+id/imageView3"android:layout_width="wrap_content"android:layout_height="wrap_content"android:layout_gravity="center_vertical"android:layout_marginLeft="8dp"android:src="@drawable/mm_title_btn_keyboard_normal" /><TextViewandroid:layout_width="wrap_content"android:layout_height="wrap_content"android:padding="8dp"android:text="登录网页"android:textColor="#fff"android:textSize="16sp" /></LinearLayout><ImageViewandroid:id="@+id/imageView5"android:layout_width="wrap_content"android:layout_height="wrap_content"android:src="@drawable/mm_title_functionframe_line" /><LinearLayoutandroid:id="@+id/llayout04"android:layout_width="fill_parent"android:layout_height="wrap_content"android:layout_marginBottom="3dp"android:layout_marginLeft="5dp"android:layout_marginRight="5dp"android:background="@drawable/title_list_selector" ><ImageViewandroid:id="@+id/imageView4"android:layout_width="wrap_content"android:layout_height="wrap_content"android:layout_gravity="center_vertical"android:layout_marginLeft="8dp"android:src="@drawable/mm_title_btn_qrcode_normal" /><TextViewandroid:layout_width="wrap_content"android:layout_height="wrap_content"android:padding="13dp"android:text="扫一扫"android:textColor="#fff"android:textSize="16sp" /></LinearLayout></LinearLayout></RelativeLayout></RelativeLayout>

布局就这样了

接下来说Java代码了

import android.app.Activity;
import android.os.Bundle;
import android.view.MotionEvent;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.LinearLayout;/*** 	功能描述:弹出Activity界面* @author Striver_zw*   Date  2014-12-9*/
public class DialogActivity extends Activity implements OnClickListener{private LinearLayout layout01,layout02,layout03,layout04;@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_dialog);initView();}/*** 初始化组件*/private void initView(){//得到布局组件对象并设置监听事件layout01 = (LinearLayout)findViewById(R.id.llayout01);layout02 = (LinearLayout)findViewById(R.id.llayout02);layout03 = (LinearLayout)findViewById(R.id.llayout03);layout04 = (LinearLayout)findViewById(R.id.llayout04);layout01.setOnClickListener(this);layout02.setOnClickListener(this);layout03.setOnClickListener(this);layout04.setOnClickListener(this);}@Overridepublic boolean onTouchEvent(MotionEvent event){finish();return true;}@Overridepublic void onClick(View v) {}
}

还有注意的是 使用activity 要用到样式

在 AndroidManifest.xml文件中 配置

   <activity android:name="com.zw.weiyi.avtivity.DialogActivity" android:theme="@android:style/Theme.Translucent.NoTitleBar.Fullscreen" />

方式二:


<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"android:layout_width="wrap_content"android:layout_height="wrap_content"android:background="@drawable/title_function_bg"android:orientation="vertical" ><ListViewandroid:id="@+id/title_list"android:layout_width="120dp"android:layout_height="fill_parent"android:cacheColorHint="#00000000"android:divider="@drawable/mm_title_functionframe_line"android:listSelector="@drawable/title_list_selector"android:padding="3dp"android:scrollingCache="false" /></LinearLayout>

主要的还是代码,由于没使用这种方式  我也是找的别人写的了解的

import java.util.ArrayList;import android.content.Context;
import android.graphics.Rect;
import android.graphics.drawable.BitmapDrawable;
import android.view.Gravity;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.view.ViewGroup.LayoutParams;
import android.widget.AdapterView;
import android.widget.AdapterView.OnItemClickListener;
import android.widget.BaseAdapter;
import android.widget.ListView;
import android.widget.PopupWindow;
import android.widget.TextView;/***	功能描述:标题按钮上的弹窗(继承自PopupWindow)*/
public class TitlePopup extends PopupWindow {private Context mContext;//列表弹窗的间隔protected final int LIST_PADDING = 10;//实例化一个矩形private Rect mRect = new Rect();//坐标的位置(x、y)private final int[] mLocation = new int[2];//屏幕的宽度和高度private int mScreenWidth,mScreenHeight;//判断是否需要添加或更新列表子类项private boolean mIsDirty;//位置不在中心private int popupGravity = Gravity.NO_GRAVITY;	//弹窗子类项选中时的监听private OnItemOnClickListener mItemOnClickListener;//定义列表对象private ListView mListView;//定义弹窗子类项列表private ArrayList<ActionItem> mActionItems = new ArrayList<ActionItem>();			public TitlePopup(Context context){//设置布局的参数this(context, LayoutParams.WRAP_CONTENT, LayoutParams.WRAP_CONTENT);}public TitlePopup(Context context, int width, int height){this.mContext = context;//设置可以获得焦点setFocusable(true);//设置弹窗内可点击setTouchable(true);	//设置弹窗外可点击setOutsideTouchable(true);//获得屏幕的宽度和高度mScreenWidth = Util.getScreenWidth(mContext);mScreenHeight = Util.getScreenHeight(mContext);//设置弹窗的宽度和高度setWidth(width);setHeight(height);setBackgroundDrawable(new BitmapDrawable());//设置弹窗的布局界面setContentView(LayoutInflater.from(mContext).inflate(R.layout.title_popup, null));initUI();}/*** 初始化弹窗列表*/private void initUI(){mListView = (ListView) getContentView().findViewById(R.id.title_list);mListView.setOnItemClickListener(new OnItemClickListener() {@Overridepublic void onItemClick(AdapterView<?> arg0, View arg1, int index,long arg3) {//点击子类项后,弹窗消失dismiss();if(mItemOnClickListener != null)mItemOnClickListener.onItemClick(mActionItems.get(index), index);}}); }/*** 显示弹窗列表界面*/public void show(View view){//获得点击屏幕的位置坐标view.getLocationOnScreen(mLocation);//设置矩形的大小mRect.set(mLocation[0], mLocation[1], mLocation[0] + view.getWidth(),mLocation[1] + view.getHeight());//判断是否需要添加或更新列表子类项if(mIsDirty){populateActions();}//显示弹窗的位置showAtLocation(view, popupGravity, mScreenWidth - LIST_PADDING - (getWidth()/2), mRect.bottom);}/*** 设置弹窗列表子项*/private void populateActions(){mIsDirty = false;//设置列表的适配器mListView.setAdapter(new BaseAdapter() {			@Overridepublic View getView(int position, View convertView, ViewGroup parent) {TextView textView = null;if(convertView == null){textView = new TextView(mContext);textView.setTextColor(mContext.getResources().getColor(android.R.color.white));textView.setTextSize(14);//设置文本居中textView.setGravity(Gravity.CENTER);//设置文本域的范围textView.setPadding(0, 10, 0, 10);//设置文本在一行内显示(不换行)textView.setSingleLine(true);}else{textView = (TextView) convertView;}ActionItem item = mActionItems.get(position);//设置文本文字textView.setText(item.mTitle);//设置文字与图标的间隔textView.setCompoundDrawablePadding(10);//设置在文字的左边放一个图标textView.setCompoundDrawablesWithIntrinsicBounds(item.mDrawable, null , null, null);return textView;}@Overridepublic long getItemId(int position) {return position;}@Overridepublic Object getItem(int position) {return mActionItems.get(position);}@Overridepublic int getCount() {return mActionItems.size();}}) ;}/*** 添加子类项*/public void addAction(ActionItem action){if(action != null){mActionItems.add(action);mIsDirty = true;}}/*** 清除子类项*/public void cleanAction(){if(mActionItems.isEmpty()){mActionItems.clear();mIsDirty = true;}}/*** 根据位置得到子类项*/public ActionItem getAction(int position){if(position < 0 || position > mActionItems.size())return null;return mActionItems.get(position);}			/*** 设置监听事件*/public void setItemOnClickListener(OnItemOnClickListener onItemOnClickListener){this.mItemOnClickListener = onItemOnClickListener;}/*** @author yangyu*	功能描述:弹窗子类项按钮监听事件*/public static interface OnItemOnClickListener{public void onItemClick(ActionItem item , int position);}
}

工具类

import android.content.Context;
import android.view.View;
import android.view.inputmethod.InputMethodManager;/***	功能描述:常量工具类*/
public class Util {/*** 得到设备屏幕的宽度*/public static int getScreenWidth(Context context) {return context.getResources().getDisplayMetrics().widthPixels;}/*** 得到设备屏幕的高度*/public static int getScreenHeight(Context context) {return context.getResources().getDisplayMetrics().heightPixels;}/*** 得到设备的密度*/public static float getScreenDensity(Context context) {return context.getResources().getDisplayMetrics().density;}/*** 把密度转换为像素*/public static int dip2px(Context context, float px) {final float scale = getScreenDensity(context);return (int) (px * scale + 0.5);}
}

import android.content.Context;
import android.graphics.drawable.Drawable;/***	功能描述:弹窗内部子类项(绘制标题和图标)*/
public class ActionItem {//定义图片对象public Drawable mDrawable;//定义文本对象public CharSequence mTitle;public ActionItem(Drawable drawable, CharSequence title){this.mDrawable = drawable;this.mTitle = title;}public ActionItem(Context context, int titleId, int drawableId){this.mTitle = context.getResources().getText(titleId);this.mDrawable = context.getResources().getDrawable(drawableId);}public ActionItem(Context context, CharSequence title, int drawableId) {this.mTitle = title;this.mDrawable = context.getResources().getDrawable(drawableId);}
}
以上就是两种方式

接下来说一些android中 样式把:

样式大全
android:theme="@android:style/Theme.Dialog"   将一个Activity显示为对话框模式
android:theme="@android:style/Theme.NoTitleBar"  不显示应用程序标题栏
android:theme="@android:style/Theme.NoTitleBar.Fullscreen"  不显示应用程序标题栏,并全屏
android:theme="@android:style/Theme.Light"  背景为白色
android:theme="@android:style/Theme.Light.NoTitleBar"  白色背景并无标题栏
android:theme="@android:style/Theme.Light.NoTitleBar.Fullscreen"  白色背景,无标题栏,全屏
android:theme="@android:style/Theme.Black"  背景黑色
android:theme="@android:style/Theme.Black.NoTitleBar"  黑色背景并无标题栏
android:theme="@android:style/Theme.Black.NoTitleBar.Fullscreen"    黑色背景,无标题栏,全屏
android:theme="@android:style/Theme.Wallpaper"  用系统桌面为应用程序背景
android:theme="@android:style/Theme.Wallpaper.NoTitleBar"  用系统桌面为应用程序背景,且无标题栏
android:theme="@android:style/Theme.Wallpaper.NoTitleBar.Fullscreen"  用系统桌面为应用程序背景,无标题栏,全屏
android:theme="@android:style/Translucent" 半透明效果
android:theme="@android:style/Theme.Translucent.NoTitleBar"  半透明并无标题栏
android:theme="@android:style/Theme.Translucent.NoTitleBar.Fullscreen"  半透明效果,无标题栏,全屏

这篇关于weiyi通讯录(三)仿微信下拉列表和android样式的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1005682

相关文章

Android 悬浮窗开发示例((动态权限请求 | 前台服务和通知 | 悬浮窗创建 )

《Android悬浮窗开发示例((动态权限请求|前台服务和通知|悬浮窗创建)》本文介绍了Android悬浮窗的实现效果,包括动态权限请求、前台服务和通知的使用,悬浮窗权限需要动态申请并引导... 目录一、悬浮窗 动态权限请求1、动态请求权限2、悬浮窗权限说明3、检查动态权限4、申请动态权限5、权限设置完毕后

Python如何计算两个不同类型列表的相似度

《Python如何计算两个不同类型列表的相似度》在编程中,经常需要比较两个列表的相似度,尤其是当这两个列表包含不同类型的元素时,下面小编就来讲讲如何使用Python计算两个不同类型列表的相似度吧... 目录摘要引言数字类型相似度欧几里得距离曼哈顿距离字符串类型相似度Levenshtein距离Jaccard相

Android里面的Service种类以及启动方式

《Android里面的Service种类以及启动方式》Android中的Service分为前台服务和后台服务,前台服务需要亮身份牌并显示通知,后台服务则有启动方式选择,包括startService和b... 目录一句话总结:一、Service 的两种类型:1. 前台服务(必须亮身份牌)2. 后台服务(偷偷干

Redis存储的列表分页和检索的实现方法

《Redis存储的列表分页和检索的实现方法》在Redis中,列表(List)是一种有序的数据结构,通常用于存储一系列元素,由于列表是有序的,可以通过索引来访问元素,因此可以很方便地实现分页和检索功能,... 目录一、Redis 列表的基本操作二、分页实现三、检索实现3.1 方法 1:客户端过滤3.2 方法

CSS自定义浏览器滚动条样式完整代码

《CSS自定义浏览器滚动条样式完整代码》:本文主要介绍了如何使用CSS自定义浏览器滚动条的样式,包括隐藏滚动条的角落、设置滚动条的基本样式、轨道样式和滑块样式,并提供了完整的CSS代码示例,通过这些技巧,你可以为你的网站添加个性化的滚动条样式,从而提升用户体验,详细内容请阅读本文,希望能对你有所帮助...

Android kotlin语言实现删除文件的解决方案

《Androidkotlin语言实现删除文件的解决方案》:本文主要介绍Androidkotlin语言实现删除文件的解决方案,在项目开发过程中,尤其是需要跨平台协作的项目,那么删除用户指定的文件的... 目录一、前言二、适用环境三、模板内容1.权限申请2.Activity中的模板一、前言在项目开发过程中,尤

C语言小项目实战之通讯录功能

《C语言小项目实战之通讯录功能》:本文主要介绍如何设计和实现一个简单的通讯录管理系统,包括联系人信息的存储、增加、删除、查找、修改和排序等功能,文中通过代码介绍的非常详细,需要的朋友可以参考下... 目录功能介绍:添加联系人模块显示联系人模块删除联系人模块查找联系人模块修改联系人模块排序联系人模块源代码如下

Python实现将实体类列表数据导出到Excel文件

《Python实现将实体类列表数据导出到Excel文件》在数据处理和报告生成中,将实体类的列表数据导出到Excel文件是一项常见任务,Python提供了多种库来实现这一目标,下面就来跟随小编一起学习一... 目录一、环境准备二、定义实体类三、创建实体类列表四、将实体类列表转换为DataFrame五、导出Da

vue解决子组件样式覆盖问题scoped deep

《vue解决子组件样式覆盖问题scopeddeep》文章主要介绍了在Vue项目中处理全局样式和局部样式的方法,包括使用scoped属性和深度选择器(/deep/)来覆盖子组件的样式,作者建议所有组件... 目录前言scoped分析deep分析使用总结所有组件必须加scoped父组件覆盖子组件使用deep前言

Android数据库Room的实际使用过程总结

《Android数据库Room的实际使用过程总结》这篇文章主要给大家介绍了关于Android数据库Room的实际使用过程,详细介绍了如何创建实体类、数据访问对象(DAO)和数据库抽象类,需要的朋友可以... 目录前言一、Room的基本使用1.项目配置2.创建实体类(Entity)3.创建数据访问对象(DAO