- 浏览: 157393 次
- 性别:
- 来自: 五指山
-
文章分类
最新评论
-
dengdonglin888:
qq_30221445 写道你好 请问这种数据能解吗 < ...
Simple XML -
qq_30221445:
你好 请问这种数据能解吗 <request> ...
Simple XML -
画个逗号给明天qu:
画个逗号给明天qu 写道
Android上传文件到服务器 -
画个逗号给明天qu:
...
Android上传文件到服务器 -
alranger:
我在jsp页面加上这一段代码后,问题还是存在。
解决Ext在ie9报错:不支持extjs对象的“createContextualFragment属性或方法”
转载自:http://blog.csdn.net/panyongjie2577/article/details/7346033
android 自动检测版本在这里就不用说了,今天想和大家一起分享的是如何将下载更新文件最小化到任务栏下载,替代掉丑陋的对话框提示下载,对话框提示下载的用户体验相当不好,我们把它修改成为后台下载这样可以改善用户的使用体验。
废话就不多说了,直接贴代码。首先要创建一个Service来执行下载更新文件的任务:
public class UpdateService extends Service{
private NotificationManager nm;
private Notification notification;
private File tempFile=null;
private boolean cancelUpdate=false;
private MyHandler myHandler;
private int download_precent=0;
private RemoteViews views;
private int notificationId=1234;
@Override
public IBinder onBind(Intent intent) {
return null;
}
@Override
public void onStart(Intent intent,int startId){
super.onStart(intent, startId);
}
@Override
public int onStartCommand(Intent intent,int flags,int startId){
nm=(NotificationManager)getSystemService(NOTIFICATION_SERVICE);
notification=new Notification();
notification.icon=android.R.drawable.stat_sys_download;
//notification.icon=android.R.drawable.stat_sys_download_done;
notification.tickerText=getString(R.string.app_name)+"更新";
notification.when=System.currentTimeMillis();
notification.defaults=Notification.DEFAULT_LIGHTS;
//设置任务栏中下载进程显示的views
views=new RemoteViews(getPackageName(),R.layout.update);
notification.contentView=views;
PendingIntent contentIntent=PendingIntent.getActivity(this,0,new Intent(this,City.class),0);
notification.setLatestEventInfo(this,"","", contentIntent);
//将下载任务添加到任务栏中
nm.notify(notificationId,notification);
myHandler=new MyHandler(Looper.myLooper(),this);
//初始化下载任务内容views
Message message=myHandler.obtainMessage(3,0);
myHandler.sendMessage(message);
//启动线程开始执行下载任务
downFile(intent.getStringExtra("url"));
return super.onStartCommand(intent, flags, startId);
}
@Override
public void onDestroy(){
super.onDestroy();
}
//下载更新文件
private void downFile(final String url) {
new Thread() {
public void run(){
try {
HttpClient client = new DefaultHttpClient();
// params[0]代表连接的url
HttpGet get = new HttpGet(url);
HttpResponse response = client.execute(get);
HttpEntity entity = response.getEntity();
long length = entity.getContentLength();
InputStream is = entity.getContent();
if (is != null) {
File rootFile=new File(Environment.getExternalStorageDirectory(), "/pinke");
if(!rootFile.exists()&&!rootFile.isDirectory())
rootFile.mkdir();
tempFile = new File(Environment.getExternalStorageDirectory(),
"/pinke/"+url.substring(url.lastIndexOf("/")+1));
if(tempFile.exists())
tempFile.delete();
tempFile.createNewFile();
//已读出流作为参数创建一个带有缓冲的输出流
BufferedInputStream bis = new BufferedInputStream(is);
//创建一个新的写入流,讲读取到的图像数据写入到文件中
FileOutputStream fos = new FileOutputStream(tempFile);
//已写入流作为参数创建一个带有缓冲的写入流
BufferedOutputStream bos = new BufferedOutputStream(fos);
int read;
long count=0;
int precent=0;
byte[] buffer=new byte[1024];
while( (read = bis.read(buffer)) != -1 && !cancelUpdate){
bos.write(buffer,0,read);
count+=read;
precent=(int)(((double)count/length)*100);
//每下载完成5%就通知任务栏进行修改下载进度
if(precent-download_precent>=5){
download_precent=precent;
Message message=myHandler.obtainMessage(3,precent);
myHandler.sendMessage(message);
}
}
bos.flush();
bos.close();
fos.flush();
fos.close();
is.close();
bis.close();
}
if(!cancelUpdate){
Message message=myHandler.obtainMessage(2,tempFile);
myHandler.sendMessage(message);
}else{
tempFile.delete();
}
} catch (ClientProtocolException e) {
Message message=myHandler.obtainMessage(4,"下载更新文件失败");
myHandler.sendMessage(message);
} catch (IOException e) {
Message message=myHandler.obtainMessage(4,"下载更新文件失败");
myHandler.sendMessage(message);
} catch(Exception e){
Message message=myHandler.obtainMessage(4,"下载更新文件失败");
myHandler.sendMessage(message);
}
}
}.start();
}
//安装下载后的apk文件
private void Instanll(File file,Context context){
Intent intent = new Intent(Intent.ACTION_VIEW);
intent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
intent.setAction(android.content.Intent.ACTION_VIEW);
intent.setDataAndType(Uri.fromFile(file),"application/vnd.android.package-archive");
context.startActivity(intent);
}
/*事件处理类*/
class MyHandler extends Handler{
private Context context;
public MyHandler(Looper looper,Context c){
super(looper);
this.context=c;
}
@Override
public void handleMessage(Message msg){
super.handleMessage(msg);
if(msg!=null){
switch(msg.what){
case 0:
Toast.makeText(context,msg.obj.toString(), Toast.LENGTH_SHORT).show();
break;
case 1:
break;
case 2:
//下载完成后清除所有下载信息,执行安装提示
download_precent=0;
nm.cancel(notificationId);
Instanll((File)msg.obj,context);
//停止掉当前的服务
stopSelf();
break;
case 3:
//更新状态栏上的下载进度信息
views.setTextViewText(R.update_id.tvProcess,"已下载"+download_precent+"%");
views.setProgressBar(R.update_id.pbDownload,100,download_precent,false);
notification.contentView=views;
nm.notify(notificationId,notification);
break;
case 4:
nm.cancel(notificationId);
break;
}
}
}
}
}
下载更新提示的布局xml:
<?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:orientation="vertical"
android:background="#f2f2f2" >
<LinearLayout
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:orientation="horizontal"
android:gravity="center">
<ImageView
android:id="@+update_id/ivLogo"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:src="@drawable/logo"
android:layout_margin="10dip" />
<LinearLayout
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:orientation="vertical"
android:layout_weight="1"
android:layout_marginRight="10dip">
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:textColor="@color/deepblack"
android:text="@string/app_name"
android:textSize="18dip"
android:textStyle="bold"/>
<ProgressBar
android:id="@+update_id/pbDownload"
android:layout_width="fill_parent"
android:layout_height="12dip"
android:progress="0"
android:max="100"
android:progressDrawable="@drawable/pb_style"
style="?android:attr/progressBarStyleHorizontal"
mce_style="?android:attr/progressBarStyleHorizontal" />
<TextView
android:id="@+update_id/tvProcess"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:textColor="@color/deepblack"
android:text="已下载0%"
android:textSize="12dip"
android:textStyle="bold" />
</LinearLayout>
</LinearLayout>
</LinearLayout>
在外面需要调用下载任务的地方使用startService(intent)来调用这个Service就可以了,最终的效果图片
转载自:http://blog.csdn.net/panyongjie2577/article/details/7346033
<!--EndFragment-->发表评论
-
xUtils简介
2014-11-25 10:04 886xUtils 包含了很多实用的android工具。 xU ... -
直接拿来用!最火的Android开源项目
2014-07-25 11:01 736转 http://www.admin10000.com/d ... -
Android APK反编译详解(附图)
2014-03-28 10:56 860http://blog.csdn.net/ithomer/ar ... -
小米人
2014-02-17 17:23 722http://www.xiaomiren.net/ -
android开发之gallery 兑现滚动一张且短距离滑动实现滚动
2013-07-02 15:28 710http://www.myexception.cn/andro ... -
TextView显示插入的图片
2013-07-01 11:29 764http://orgcent.com/android-text ... -
TextView使用SpannableString设置复合文本
2013-07-01 11:29 699http://orgcent.com/android-text ... -
转:::Android TextView文字横向自动滚动(跑马灯)
2013-06-17 11:45 1546TextView实现文字滚动需要以下几个要点: 1.文字长度长 ... -
相片滤镜开源
2013-04-27 15:01 775https://github.com/daizhenjun/I ... -
android图片特效处理之模糊效果
2013-04-27 14:57 871http://blog.csdn.net/sjf0115/ar ... -
android图片处理方法(不断收集中)
2013-04-27 14:57 601http://gundumw100.iteye.com/blo ... -
Android, WindowsPhone7, IOS ,vc2010平台40多套图片滤镜开源
2013-04-27 14:56 706http://www.cnblogs.com/daizhj/a ... -
移动云存储平台
2013-04-25 16:13 938http://bmob.cn 关于Bmob 对于很多 ... -
android ExpandableListView简单应用及listview模拟ExpandableListView
2013-02-28 11:45 732http://blog.csdn.net/jj120522/a ... -
android_App集成支付宝
2013-02-28 11:43 830http://www.cnblogs.com/qianxude ... -
Android Pull Refresh View 插件
2012-12-01 12:43 895Android Pull Refresh View htt ... -
Android-TelephoneManager(转载)
2012-10-09 22:08 1424好文章齐分享。原文地址:http://blog.si ... -
android 开源 listview separato
2012-08-27 22:51 698http://code.google.com/p/androi ... -
fragment开源项目 学习
2012-08-13 12:02 968https://github.com/tisa007/Andr ... -
Fragment学习
2012-08-13 11:53 715http://www.eoeandroid.com/threa ...
相关推荐
在Android开发中,沉浸式状态栏(Immersive Status Bar)是一种常见的设计手法,它能够使应用的内容无缝地延伸到状态栏下方,提供更全面、更沉浸的用户体验。这种技术尤其在游戏和全屏应用中非常受欢迎,因为它最大...
本文将深入探讨如何在Android 4.4(KitKat)及更高版本上实现沉浸式状态栏、变色状态栏、透明状态栏以及如何修改状态栏的颜色和透明度。 1. **Android沉浸式状态栏** Android沉浸式模式主要通过`SYSTEM_UI_FLAG_...
本文将详细讲解如何实现一个Android应用,它能在后台执行文件下载任务,并在状态栏显示下载进度,下载完成后自动提示用户安装。这个功能的实现主要涉及以下几个关键知识点: 1. **IntentService**: - ...
在Android开发中,"沉浸式状态栏"是一个热门话题,它能够让应用的界面无缝地...不过,随着Android系统的不断更新,新的API和功能可能会提供更多优化沉浸式状态栏的方法,因此开发者需要持续关注Android开发的最新动态。
`android:fitsSystemWindows="true"`会让布局自动避开状态栏。 2. **在Java代码中设置透明状态栏**: ```java if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT) { Window window = getWindow(); ...
3. **旗标组合**:在Android 4.4(KitKat)及以后版本,可以使用`SYSTEM_UI_FLAG_IMMERSIVE`和`SYSTEM_UI_FLAG_IMMERSIVE_STICKY`旗标,这些旗标允许应用在用户滑动屏幕时短暂显示状态栏,之后自动隐藏,提供了一种...
在Android 5.0(Lollipop)及以上版本,引入了Material Design,状态栏颜色可以根据主题颜色自动调整。我们可以通过设置`colorPrimaryDark`属性在`styles.xml`中自定义状态栏颜色: ```xml <!-- Customize your ...
`android:fitsSystemWindows="true"` 属性会让布局自动适配状态栏和导航栏,使其内容不会被遮挡。 此外,如果你使用的是Fragment,可以在onCreateView或onViewCreated方法中获取状态栏高度,然后对Fragment内的布局...
- **颜色过渡**:通过` android:fitsSystemWindows="true"`在布局文件中实现内容自动适应系统窗口,避免被状态栏遮挡。 - **自定义过渡**:若需自定义过渡动画,可以使用`ViewPropertyAnimator`来实现状态栏的渐变...
而沉浸式状态栏允许状态栏半透明或完全透明,使得应用界面可以"沉浸"在状态栏之下,增强视觉连续性。 实现沉浸式状态栏有几种方法: 1. **使用主题设置**:在AndroidManifest.xml中,为对应的Activity设置`android...
本教程将深入探讨如何在Android应用中实现沉浸式状态栏以及标题栏随着滑动而改变颜色的效果。 首先,我们需要理解“沉浸式状态栏”的概念。在Android中,沉浸式状态栏意味着状态栏的颜色会与应用内容融为一体,给人...
在Android系统中,状态栏和导航栏是用户界面的重要组成部分,它们提供了系统信息显示和应用程序间的导航功能。在某些应用场景下,比如全屏游戏或沉浸式视频观看时,开发者可能需要动态地控制这些元素的显示与隐藏,...
在Android开发中,沉浸式状态栏(Immersion Bar)是一种流行的设计趋势,它使得应用界面能够无缝延伸到状态栏下方,创造出更为统一且沉浸式的用户体验。这种设计在现代应用程序中非常常见,尤其在游戏和全屏展示内容...
为避免这种情况,可以在布局XML文件中使用`android:fitsSystemWindows="true"`属性,使内容自动避开状态栏区域。 6. **自定义字体和颜色** 如果希望自定义状态栏中的文字颜色和图标颜色,可以使用` android:...
在Android开发中,沉浸式状态栏是一种流行的设计趋势,它能提供更为美观且无边界的用户体验,让应用的内容无缝地延伸到状态栏区域。本文将深入探讨“Android沉浸式状态栏”的实现方法、应用场景以及相关的代码实践。...
1. **Android通知系统**:Android的通知系统允许应用在状态栏显示通知,提供与用户交互的途径。开发者可以创建不同级别的通知,如默认、低优先级或高优先级,以适应不同情况。 2. **Notification**对象:创建通知的...
在Android系统中,状态栏和导航栏是用户界面的重要组成部分,它们提供了系统信息以及应用程序的控制。在Android 7.1(API级别25)中,开发者可以通过编程方式实现状态栏和导航栏的隐藏与显示,以达到更沉浸式的用户...
在布局XML文件中,可以通过`android:fitsSystemWindows="true"`属性来自动适应状态栏高度,但需要注意,此属性在某些设备上可能无法处理虚拟按键。 3. **动态设置状态栏透明**:使用`WindowCompat`的`setFlags()`...
在“状态栏显示进度的版本更新”中,我们关注的是如何在用户界面中提供一个直观、友好的更新体验,特别是通过状态栏来展示下载进度。这种设计能够使用户在使用应用的同时,对后台的更新过程有清晰的认知,避免了因...
`可以让应用布局完全延伸到状态栏之下,然后配合`android:fitsSystemWindows="true"`来确保内容不会被状态栏遮挡。 2. 顶部状态栏改色(Changing Status Bar Color) Android系统允许开发者自定义状态栏的颜色,以...