高仿IOS的Android弹出框

所属分类: 软件编程 / IOS 阅读数: 435
收藏 0 赞 0 分享

本文实例为大家分享了Android弹出框的具体代码,供大家参考,具体内容如下

先看一下效果图,不过这是网上的图片。

效果不错,就借此拿来与大伙分享分享。

github源码地址:https://github.com/saiwu-bigkoo/Android-AlertView.

1.怎么用:添加依赖。

compile 'com.bigkoo:alertview:1.0.3'

2.实例demo(大家可以根据需要来选择自己需要的框框)。

package com.example.my.androidalertview;


import android.app.Activity;
import android.content.Context;
import android.os.Bundle;
import android.view.KeyEvent;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.view.inputmethod.InputMethodManager;
import android.widget.EditText;
import android.widget.Toast;

import com.bigkoo.alertview.AlertView;
import com.bigkoo.alertview.OnDismissListener;
import com.bigkoo.alertview.OnItemClickListener;

/**
 * 精仿iOSAlertViewController控件Demo
 */
public class MainActivity extends Activity implements OnItemClickListener, OnDismissListener {

 private AlertView mAlertView;//避免创建重复View,先创建View,然后需要的时候show出来,推荐这个做法
 private AlertView mAlertViewExt;//窗口拓展例子
 private EditText etName;//拓展View内容
 private InputMethodManager imm;

 @Override
 protected void onCreate(Bundle savedInstanceState) {
 super.onCreate(savedInstanceState);
 setContentView(R.layout.activity_main);
 imm = (InputMethodManager) getSystemService(Context.INPUT_METHOD_SERVICE);
 mAlertView = new AlertView("标题", "内容", "取消", new String[]{"确定"}, null, this, AlertView.Style.Alert, this).setCancelable(true).setOnDismissListener(this);
 //拓展窗口
 mAlertViewExt = new AlertView("提示", "请完善你的个人资料!", "取消", null, new String[]{"完成"}, this, AlertView.Style.Alert, this);
 ViewGroup extView = (ViewGroup) LayoutInflater.from(this).inflate(R.layout.alertext_form, null);
 etName = (EditText) extView.findViewById(R.id.etName);
 etName.setOnFocusChangeListener(new View.OnFocusChangeListener() {
  @Override
  public void onFocusChange(View view, boolean focus) {
  //输入框出来则往上移动
  boolean isOpen = imm.isActive();
  mAlertViewExt.setMarginBottom(isOpen && focus ? 120 : 0);
  System.out.println(isOpen);
  }
 });
 mAlertViewExt.addExtView(extView);
 }

 public void alertShow1(View view) {
 mAlertView.show();
 }

 public void alertShow2(View view) {
 new AlertView("标题", "内容", null, new String[]{"确定"}, null, this, AlertView.Style.Alert, this).show();
 }

 public void alertShow3(View view) {
 new AlertView(null, null, null, new String[]{"高亮按钮1", "高亮按钮2", "高亮按钮3"},
  new String[]{"其他按钮1", "其他按钮2", "其他按钮3", "其他按钮4", "其他按钮5", "其他按钮6",
   "其他按钮7", "其他按钮8", "其他按钮9", "其他按钮10", "其他按钮11", "其他按钮12"},
  this, AlertView.Style.Alert, this).show();
 }

 public void alertShow4(View view) {
 new AlertView("标题", null, "取消", new String[]{"高亮按钮1"}, new String[]{"其他按钮1", "其他按钮2", "其他按钮3"}, this, AlertView.Style.ActionSheet, this).show();
 }

 public void alertShow5(View view) {
 new AlertView("标题", "内容", "取消", null, null, this, AlertView.Style.ActionSheet, this).setCancelable(true).show();
 }

 public void alertShow6(View view) {
 new AlertView("上传头像", null, "取消", null,
  new String[]{"拍照", "从相册中选择"},
  this, AlertView.Style.ActionSheet, this).show();
 }

 public void alertShowExt(View view) {
 mAlertViewExt.show();
 }

 private void closeKeyboard() {
 //关闭软键盘
 imm.hideSoftInputFromWindow(etName.getWindowToken(), 0);
 //恢复位置
 mAlertViewExt.setMarginBottom(0);
 }

 @Override
 public void onItemClick(Object o, int position) {
 closeKeyboard();
 //判断是否是拓展窗口View,而且点击的是非取消按钮
 if (o == mAlertViewExt && position != AlertView.CANCELPOSITION) {
  String name = etName.getText().toString();
  if (name.isEmpty()) {
  Toast.makeText(this, "啥都没填呢", Toast.LENGTH_SHORT).show();
  } else {
  Toast.makeText(this, "hello," + name, Toast.LENGTH_SHORT).show();
  }

  return;
 }
 Toast.makeText(this, "点击了第" + position + "个", Toast.LENGTH_SHORT).show();
 }

 @Override
 public void onDismiss(Object o) {
 closeKeyboard();
 Toast.makeText(this, "消失了", Toast.LENGTH_SHORT).show();
 }

 @Override
 public boolean onKeyDown(int keyCode, KeyEvent event) {
 if (keyCode == KeyEvent.KEYCODE_BACK && event.getRepeatCount() == 0) {
  if (mAlertView != null && mAlertView.isShowing()) {
  mAlertView.dismiss();
  return false;
  }
 }

 return super.onKeyDown(keyCode, event);

 }
}

布局文件:

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
 android:layout_width="match_parent"
 android:orientation="vertical"
 android:layout_height="match_parent" android:paddingLeft="@dimen/activity_horizontal_margin"
 android:paddingRight="@dimen/activity_horizontal_margin"
 android:paddingTop="@dimen/activity_vertical_margin"
 android:paddingBottom="@dimen/activity_vertical_margin">

 <Button android:text="hey,alert !!!click here~~~" android:layout_width="match_parent"
 android:layout_marginTop="5dp"
 android:layout_height="50dp"
 android:onClick="alertShow1"/>
 <Button android:text="hey,alert !!!click here~~~" android:layout_width="match_parent"
 android:layout_marginTop="5dp"
 android:layout_height="50dp"
 android:onClick="alertShow2"/>
 <Button android:text="hey,alert !!!click here~~~" android:layout_width="match_parent"
 android:layout_marginTop="5dp"
 android:layout_height="50dp"
 android:onClick="alertShow3"/>
 <Button android:text="hey,actionsheet !!!click here~~~" android:layout_width="match_parent"
 android:layout_marginTop="5dp"
 android:layout_height="50dp"
 android:onClick="alertShow4"/>
 <Button android:text="hey,actionsheet !!!click here~~~" android:layout_width="match_parent"
 android:layout_marginTop="5dp"
 android:layout_height="50dp"
 android:onClick="alertShow5"/>
 <Button android:text="hey,actionsheet !!!click here~~~" android:layout_width="match_parent"
 android:layout_marginTop="5dp"
 android:layout_height="50dp"
 android:onClick="alertShow6"/>
 <Button android:text="窗口拓展点这里" android:layout_width="match_parent"
 android:layout_marginTop="5dp"
 android:layout_height="50dp"
 android:onClick="alertShowExt"/>

</LinearLayout>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

更多精彩内容其他人还在看

iOS开发笔记--详解UILabel的相关属性设置

这篇文章主要介绍了iOS开发笔记--详解UILabel的相关属性设置,对初学者具有一定的参考价值,有需要的可以了解一下。
收藏 0 赞 0 分享

iOS中获取系统相册中的图片实例

这篇文章主要介绍了iOS中获取系统相册中的图片实例,具有一定的参考价值没有需要的朋友可以了解一下。
收藏 0 赞 0 分享

iOS 检测网络状态的两种方法

一般有Reachability和AFNetworking监测两种方式,都是第三方的框架,下文逐一详细给大家讲解,感兴趣的朋友一起看看吧
收藏 0 赞 0 分享

IOS 性能优化中离屏渲染

本文主要介绍了IOS 性能优化中离屏渲染的资料,提供了几种方法讲解了优化,有需要的小伙伴可以参考下
收藏 0 赞 0 分享

iOS获取当前设备型号等信息(全)包含iPhone7和iPhone7P

这篇文章主要介绍了iOS获取当前设备型号设备信息的总结包含iPhone7和iPhone7P,包括ios7之前之后的获取方式,本文接的非常详细,具有参考借鉴价值,需要的朋友可以参考下
收藏 0 赞 0 分享

iOS实现爆炸的粒子效果示例代码

之前在网上看到了一个Android实现的爆炸效果,感觉非常不错,所以自己尝试用iOS来实现下效果,现在将实现的过程、原理以及遇到的问题分享给大家,有需要的朋友们可以参考借鉴,下面来一起看看吧。
收藏 0 赞 0 分享

iOS毕业设计之天气预报App

这篇文章主要为大家详细介绍了iOS毕业设计之天气预报App,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
收藏 0 赞 0 分享

iOS轻点、触摸和手势代码开发

这篇文章主要为大家详细介绍了iOS轻点、触摸和手势代码开发,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
收藏 0 赞 0 分享

iOS 实现多代理的方法及实例代码

这篇文章主要介绍了iOS 实现多代理的方法及实例代码的相关资料,需要的朋友可以参考下
收藏 0 赞 0 分享

iOS文字渐变色效果的实现方法

在大家日常开发iOS的过程中,可能会遇到要实现文字渐变色的效果,这篇文章文章通过示例代码和详细的步骤介绍了如何利用iOS实现文字渐变色的效果,实现后的很不错,感兴趣的朋友们下面来一起看看吧。
收藏 0 赞 0 分享
查看更多