仿iOS的网络请求的加载框
2016-04-13 14:51
656 查看
/**
* 发送请求后的加载框
*
* @param myView
* @param msg
*/
public void showPopupWindow(View myView, String msg) {
PopupWindow popupWindow ;
View contentView = LayoutInflater.from(mContext).inflate(R.layout.loading_progress_dialog, null);
TextView load_msg = (TextView) contentView.findViewById(R.id.tv_loading_message);
load_msg.setText(msg);
contentView.setFocusable(true);
contentView.setFocusableInTouchMode(true);
popupWindow = new PopupWindow(contentView, ViewGroup.LayoutParams.WRAP_CONTENT, ViewGroup.LayoutParams.WRAP_CONTENT);
popupWindow.setFocusable(true);
popupWindow.setOutsideTouchable(false);
contentView.setOnKeyListener(new View.OnKeyListener() {
@Override
public boolean onKey(View v, int keyCode, KeyEvent event) {
popupWindow.dismiss();
return false;
}
});
popupWindow.showAtLocation(myView, Gravity.CENTER | Gravity.CENTER_HORIZONTAL, 0, 0);
}
myView这个参数表示的是弹窗所在的这个界面的布局,即整体布局
弹窗的布局:
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="@drawable/tips_bg"
android:gravity="center"
android:orientation="vertical"
android:padding="10dp" >
<ProgressBar
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:indeterminateDrawable="@drawable/frame_loading" />
<TextView
android:id="@+id/tv_loading_message"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginTop="5dp"
android:textColor="@color/white"
android:textSize="15sp" />
</LinearLayout>
frame_loading中的写法
<?xml version="1.0" encoding="UTF-8"?>
<animation-list xmlns:android="http://schemas.android.com/apk/res/android"
android:oneshot="false" >
<item android:duration="150">
<clip
android:clipOrientation="horizontal"
android:drawable="@drawable/loading_01"
android:gravity="left" />
</item>
<item android:duration="150">
<clip
android:clipOrientation="horizontal"
android:drawable="@drawable/loading_02"
android:gravity="left" />
</item>
<item android:duration="150">
<clip
android:clipOrientation="horizontal"
android:drawable="@drawable/loading_03"
android:gravity="left" />
</item>
<item android:duration="150">
<clip
android:clipOrientation="horizontal"
android:drawable="@drawable/loading_04"
android:gravity="left" />
</item>
<item android:duration="150">
<clip
android:clipOrientation="horizontal"
android:drawable="@drawable/loading_05"
android:gravity="left" />
</item>
<item android:duration="150">
<clip
android:clipOrientation="horizontal"
android:drawable="@drawable/loading_06"
android:gravity="left" />
</item>
<item android:duration="150">
<clip
android:clipOrientation="horizontal"
android:drawable="@drawable/loading_07"
android:gravity="left" />
</item>
<item android:duration="150">
<clip
android:clipOrientation="horizontal"
android:drawable="@drawable/loading_08"
android:gravity="left" />
</item>
<item android:duration="150">
<clip
android:clipOrientation="horizontal"
android:drawable="@drawable/loading_09"
android:gravity="left" />
</item>
<item android:duration="150">
<clip
android:clipOrientation="horizontal"
android:drawable="@drawable/loading_10"
android:gravity="left" />
</item>
<item android:duration="150">
<clip
android:clipOrientation="horizontal"
android:drawable="@drawable/loading_11"
android:gravity="left" />
</item>
<item android:duration="150">
<clip
android:clipOrientation="horizontal"
android:drawable="@drawable/loading_12"
android:gravity="left" />
</item>
</animation-list>
刚写微博,不会多张上传,所以只附上一张示例图片,其他的可以去网上找一找.
代码都上传上来了,有兴趣的可以试一试,如果不满意popupWindow 的每次都要写myview,可以换成dialog,效果也是可以的。
* 发送请求后的加载框
*
* @param myView
* @param msg
*/
public void showPopupWindow(View myView, String msg) {
PopupWindow popupWindow ;
View contentView = LayoutInflater.from(mContext).inflate(R.layout.loading_progress_dialog, null);
TextView load_msg = (TextView) contentView.findViewById(R.id.tv_loading_message);
load_msg.setText(msg);
contentView.setFocusable(true);
contentView.setFocusableInTouchMode(true);
popupWindow = new PopupWindow(contentView, ViewGroup.LayoutParams.WRAP_CONTENT, ViewGroup.LayoutParams.WRAP_CONTENT);
popupWindow.setFocusable(true);
popupWindow.setOutsideTouchable(false);
contentView.setOnKeyListener(new View.OnKeyListener() {
@Override
public boolean onKey(View v, int keyCode, KeyEvent event) {
popupWindow.dismiss();
return false;
}
});
popupWindow.showAtLocation(myView, Gravity.CENTER | Gravity.CENTER_HORIZONTAL, 0, 0);
}
myView这个参数表示的是弹窗所在的这个界面的布局,即整体布局
弹窗的布局:
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="@drawable/tips_bg"
android:gravity="center"
android:orientation="vertical"
android:padding="10dp" >
<ProgressBar
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:indeterminateDrawable="@drawable/frame_loading" />
<TextView
android:id="@+id/tv_loading_message"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginTop="5dp"
android:textColor="@color/white"
android:textSize="15sp" />
</LinearLayout>
frame_loading中的写法
<?xml version="1.0" encoding="UTF-8"?>
<animation-list xmlns:android="http://schemas.android.com/apk/res/android"
android:oneshot="false" >
<item android:duration="150">
<clip
android:clipOrientation="horizontal"
android:drawable="@drawable/loading_01"
android:gravity="left" />
</item>
<item android:duration="150">
<clip
android:clipOrientation="horizontal"
android:drawable="@drawable/loading_02"
android:gravity="left" />
</item>
<item android:duration="150">
<clip
android:clipOrientation="horizontal"
android:drawable="@drawable/loading_03"
android:gravity="left" />
</item>
<item android:duration="150">
<clip
android:clipOrientation="horizontal"
android:drawable="@drawable/loading_04"
android:gravity="left" />
</item>
<item android:duration="150">
<clip
android:clipOrientation="horizontal"
android:drawable="@drawable/loading_05"
android:gravity="left" />
</item>
<item android:duration="150">
<clip
android:clipOrientation="horizontal"
android:drawable="@drawable/loading_06"
android:gravity="left" />
</item>
<item android:duration="150">
<clip
android:clipOrientation="horizontal"
android:drawable="@drawable/loading_07"
android:gravity="left" />
</item>
<item android:duration="150">
<clip
android:clipOrientation="horizontal"
android:drawable="@drawable/loading_08"
android:gravity="left" />
</item>
<item android:duration="150">
<clip
android:clipOrientation="horizontal"
android:drawable="@drawable/loading_09"
android:gravity="left" />
</item>
<item android:duration="150">
<clip
android:clipOrientation="horizontal"
android:drawable="@drawable/loading_10"
android:gravity="left" />
</item>
<item android:duration="150">
<clip
android:clipOrientation="horizontal"
android:drawable="@drawable/loading_11"
android:gravity="left" />
</item>
<item android:duration="150">
<clip
android:clipOrientation="horizontal"
android:drawable="@drawable/loading_12"
android:gravity="left" />
</item>
</animation-list>
刚写微博,不会多张上传,所以只附上一张示例图片,其他的可以去网上找一找.
代码都上传上来了,有兴趣的可以试一试,如果不满意popupWindow 的每次都要写myview,可以换成dialog,效果也是可以的。
相关文章推荐
- Hyperscan 介绍与安装
- WARN (org.apache.commons.httpclient.HttpMethodBase:1511) - Cookie rejected 警告
- Linux网络编程--recv函数返回值详解
- 使用Jmeter进行http接口测试
- 使用SSH设置映射端口跳转,解决网络限制问题
- tomcat下配置https
- 通过SecureCRT设置代理,访问网络中web界面
- 从网上整理了一些关于比较时间大小和请求网络时间的代码,在这里展示一下
- tcp/ip三次握手
- 2015年ACM-ICPC亚洲区域赛合肥站网络预选赛H题——The Next (位运算)
- nagios网络流量监控(附pnp模板)
- 计算机网络学习笔记--数据链据层上的设备详解
- TCP/IP(十二)TCP的超时与重传
- Openwrt上Php+Mysql+Lighttpd的安装配置
- 转载 :Android中判断网络
- IOS学习 网络 SSZipArchive 解压缩文件
- BP人工神经网络
- 5.1 网络基础
- 使用pagerank计算商业服务网络中节点的重要性
- VideoView (Vitamioplayer使用)播放网络视频