本文将用两个方法来写类似汽车荷载的进度
用linearLayout的addvIEw方法加上for循环
用自定义控件的方法
先上截图
1. 用linearLayout的addvIEw方法加上for循环
1.1 processtest01.xml文件:
<?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:orIEntation="horizontal" > <linearLayout androID:ID="@+ID/ll" androID:layout_wIDth="wrap_content" androID:layout_height="wrap_content" androID:orIEntation="horizontal"> </linearLayout></linearLayout>
1.2 linearLayout的子布局vIEw01.xml
<?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:orIEntation="vertical" > <ImageVIEw androID:ID="@+ID/hezai_img" androID:layout_wIDth="12.5dp" androID:layout_height="31.5dp"/></linearLayout>
1.3 Processtest01.java
package com.example.progresstest;import androID.app.Activity;import androID.os.Bundle;import androID.vIEw.LayoutInflater;import androID.vIEw.VIEw;import androID.Widget.ImageVIEw;import androID.Widget.linearLayout;public class Processtest01 extends Activity { private linearLayout ll; @OverrIDe protected voID onCreate(Bundle savedInstanceState) { // Todo auto-generated method stub super.onCreate(savedInstanceState); setContentVIEw(R.layout.processtest01); ll = (linearLayout) findVIEwByID(R.ID.ll); setProcess(16); } private voID setProcess(int green){ LayoutInflater inflater = this.getLayoutInflater(); //有进度就填充绿色图片 for (int i = 0; i < green; i++) { VIEw v = inflater.inflate(R.layout.vIEw01,null); ImageVIEw img = (ImageVIEw) v.findVIEwByID(R.ID.hezai_img); img.setimageResource(R.drawable.green); ll.addVIEw(v); } //没有进度就填充灰色图片 for (int i = 0; i < 24-green; i++) { VIEw v = inflater.inflate(R.layout.vIEw01,null); ImageVIEw img = (ImageVIEw) v.findVIEwByID(R.ID.hezai_img); img.setimageResource(R.drawable.gray); ll.addVIEw(v); } }}
1.4 这里涉及了两个带边界的图片元素
最后得到的截图
这种方法有好处也有坏处。这种方法简单易懂,且耗内存少,运行速度快等,但若要不同的颜色,就要自己截不同大小,不同颜色的图片,并且还要左右带间距的,比较麻烦。下面的一种方法是自定义控件的方法,也是有好有坏。
2 用自定义控件的方法
2.1 myprocesstest.xml文件
<?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:orIEntation="vertical" > <com.example.progresstest.HezaiProgress androID:layout_margintop="20dp" androID:layout_gravity="center" androID:ID="@+ID/process" androID:layout_wIDth="wrap_content" androID:layout_height="wrap_content" > </com.example.progresstest.HezaiProgress></linearLayout>
这里的com.example.progresstest是HezaiProgress所在的包名,HezaiProgress是自定义的控件代码。
2.2 HezaiProgress.java文件
package com.example.progresstest;import androID.content.Context;import androID.graphics.Canvas;import androID.graphics.color;import androID.graphics.Paint;import androID.graphics.Rect;import androID.util.AttributeSet;import androID.util.Log;import androID.vIEw.VIEw;import androID.vIEw.VIEw.MeasureSpec;import androID.Widget.ImageVIEw;import androID.Widget.linearLayout;import androID.Widget.linearLayout.LayoutParams;public class HezaiProgress extends VIEw{ private int process = 10; private int wIDth,height; private int h = 32; private int w = 12; private int divIDeWIDth=5; private int maxCount = 24; private int processcolor=color.GREEN; private int j = 1; private int num = 0; public int getProcesscolor() { return processcolor; } /** * 自定义颜色,输入的是“#ffffff”形式的颜色字符串 * @param processcolor */ public voID setProcesscolor(String processcolor) { char c = processcolor.charat(0); int r = 0; int g = 0; int b = 0; //默认颜色为绿色 int rgb = color.GREEN; if(c=='#'){ for(int i = 1;i<processcolor.length();i++){ c = processcolor.charat(i); if(i<3){ r += rOrgOrb(c,i); } else if(i<5){ g += rOrgOrb(c,i); }else{ b += rOrgOrb(c,i); } } rgb = color.rgb(r,g,b); } this.processcolor = rgb; } private int rOrgOrb(char c,int i){ num++; char b = 0; if(c>='0'&&c<='9'){ //j是用于判断是十六进制的哪一位 if(i==j){ //十六进制的右数第二位 b += Integer.valueOf(c)*16; } if(i==j+1){ //十六进制的右数第一位 b += Integer.valueOf(c); } } //十六进制的大写字母形式 if(c>='A'&&c<='F'){ if(i==j){ //ascii码减去55,如A的ASCII码为65,减去55后等于10 b += ((int)c-55)*16; } if(i==j+1){ b += (int)c-55; } } //十六进制的小写字母形式 if(c>='a'&&c<='f'){ if(i==j){ //ascii码减去87,如a的ASCII码为97,减去87后等于10 b += ((int)c-87)*16; } if(i==j+1){ b += (int)c-87; } } //若计数为偶数,则给j加2 if(num%2==0){ j=j+2; } return b; } //得到最大进度数 public int getMaxCount() { return maxCount; } //设置最大进度数 public voID setMaxCount(int maxCount) { this.maxCount = maxCount; } //得到进度 public int getProcess() { return process; } //设置进度 public voID setProcess(int process) { this.process = process; } //设置间隔宽度 public voID setdivIDeWIDth(int divIDeWIDth){ this.divIDeWIDth = divIDeWIDth; } public HezaiProgress(Context context,AttributeSet attrs,int defStyle) { super(context,attrs,defStyle); // Todo auto-generated constructor stub } public HezaiProgress(Context context,AttributeSet attrs) { this(context,0); // Todo auto-generated constructor stub } public HezaiProgress(Context context) { this(context,null); // Todo auto-generated constructor stub } @OverrIDe protected voID onDraw(Canvas canvas) { // Todo auto-generated method stub super.onDraw(canvas); setHezai(16,canvas); } //设置进度条高度 public voID setProcessHeight(int h){ if(h==0) this.h = 32; else this.h = h; } //设置进度条宽度 public voID setProcessWIDth(int w){ if(w==0) this.w = 12; else this.w = w; } private voID setHezai(int process,Canvas canvas){ Rect rect; Paint paint; int tmp = 2; //进度取整,如果进度条总宽度大于指定控件宽度,则只显示整数个进度 if(process*(w+tmp)+tmp>wIDth) process = wIDth/(w+divIDeWIDth); //显示进度 for (int i = 0;i<process;i++){ rect = new Rect(tmp,2,w+tmp,h); paint = new Paint(); tmp=tmp+w+divIDeWIDth; paint.setcolor(processcolor); canvas.drawRect(rect,paint); } //显示灰色进度,及默认没进度状态状态 for (int i = 0; i < maxCount-process; i++) { rect = new Rect(tmp,h); paint = new Paint(); tmp=tmp+w+divIDeWIDth; paint.setcolor(color.rgb(211,211,211)); canvas.drawRect(rect,paint); } } //dp转换成px private int diptopx(int dip){ float scale = getContext().getResources().getdisplayMetrics().density; return (int) (dip * scale + 0.5f * (dip >= 0 ? 1 : -1));//加0.5是为了四舍五入 } @OverrIDe protected voID onMeasure(int wIDthMeasureSpec,int heightmeasureSpec) { // Todo auto-generated method stub super.onMeasure(wIDthMeasureSpec,heightmeasureSpec); int wIDthSpecMode = MeasureSpec.getMode(wIDthMeasureSpec); int heightSpecMode = MeasureSpec.getMode(heightmeasureSpec); int wIDthSpecsize = MeasureSpec.getSize(wIDthMeasureSpec); int heightSpecsize = MeasureSpec.getSize(heightmeasureSpec); //MeasureSpec.EXACTLY,精确尺寸 if (wIDthSpecMode == MeasureSpec.EXACTLY || wIDthSpecMode == MeasureSpec.AT_MOST) { wIDth = wIDthSpecsize; } else { //如果不是精确尺寸,则显示设置尺寸或默认尺寸 wIDth = w; } //MeasureSpec.AT_MOST,最大尺寸,只要不超过父控件允许的最大尺寸即可,MeasureSpec.UnspecIFIED未指定尺寸 if (heightSpecMode == MeasureSpec.AT_MOST || heightSpecMode == MeasureSpec.UnspecIFIED) { //显示设置尺寸或默认尺寸 height = diptopx(h); } else { height = heightSpecsize; } //设置控件实际大小 setMeasuredDimension(wIDth,height); }}
代码里做了详细注释,这里就不在说了。
2.3 Processtest.java
package com.example.progresstest;import androID.app.Activity;import androID.os.Bundle;public class Processtest extends Activity { private HezaiProgress process; @OverrIDe protected voID onCreate(Bundle savedInstanceState) { // Todo auto-generated method stub super.onCreate(savedInstanceState); setContentVIEw(R.layout.myprocesstest); process = (HezaiProgress) findVIEwByID(R.ID.process); //设置进度高度 process.setProcessHeight(63); //设置进度宽度 process.setProcessWIDth(25); //设置间隔宽度 process.setdivIDeWIDth(10); //设置进度颜色 process.setProcesscolor("#008b8b"); }}
这里比第一种方法好的地方就是可以随意改变高度,宽度,间隔宽度,进度颜色等,而且只需要一句代码就行,因为前面已经封装好了,但似乎比较耗内存。
这里是改变颜色后的截图,就是本博客的第一张图:
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程小技巧。
总结以上是内存溢出为你收集整理的Android自定义荷载进度的两种方法全部内容,希望文章能够帮你解决Android自定义荷载进度的两种方法所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)