zoukankan      html  css  js  c++  java
  • ZoomBar 设计

      1 package com.example.canvasdemo;
      2 
      3 import android.content.Context;
      4 import android.graphics.Canvas;
      5 import android.graphics.Color;
      6 import android.graphics.EmbossMaskFilter;
      7 import android.graphics.Paint;
      8 import android.graphics.SweepGradient;
      9 import android.util.AttributeSet;
     10 import android.view.View;
     11 /**
     12  * 
     13  * @author liemng  QQ:859686819
     14  *
     15  */
     16 public class ZoomPinch extends View{
     17 
     18     private Paint mLinePaint;
     19     private Paint mPointPaint;
     20     private int mLineWitdh = 18;
     21     private int mPointPaintWitdh = 12;
     22     
     23     private String mForeground = "#FFFFFF";
     24     private String mBackground = "#ff0000";
     25     
     26     // 梯度渐变的填充颜色
     27     private int[] arcColors = new int[] { 0xFF48cbdc, 0xFF4c9fda, 0xFFeac83d,
     28             0xFFc7427e, 0xFF48cbdc, 0xFF48cbdc };
     29     
     30     public ZoomPinch(Context context, AttributeSet attrs, int defStyleAttr) {
     31         super(context, attrs, defStyleAttr);
     32         initData();
     33     }
     34 
     35     public ZoomPinch(Context context, AttributeSet attrs) {
     36         this(context, attrs, 0);
     37     }
     38 
     39     public ZoomPinch(Context context) {
     40         this(context, null);
     41     }
     42     
     43     public void initData(){
     44         //--绘制线段画笔
     45         mLinePaint = new Paint();
     46         //--抗锯齿
     47         mLinePaint.setAntiAlias(true);
     48         //--防抖
     49         mLinePaint.setDither(true);
     50         //--线段两端的形状
     51         mLinePaint.setStrokeCap(Paint.Cap.ROUND);
     52         // 线段的宽度
     53         mLinePaint.setStrokeWidth(mLineWitdh);
     54         //--画笔颜色
     55         mLinePaint.setColor(Color.parseColor("#000000"));
     56         
     57         //--设置光源的方向
     58         float[] direction = new float[]{ 1, 1, 1 };
     59         //--设置环境光亮度
     60         float light = 0.4f;
     61         //--选择要应用的反射等级
     62         float specular = 6;
     63         //--向mask应用一定级别的模糊
     64         float blur = 3.5f;
     65         EmbossMaskFilter emboss=new EmbossMaskFilter(direction,light,specular,blur);
     66         mLinePaint.setMaskFilter(emboss);
     67         
     68         //--绘制圆环的画笔
     69         mPointPaint = new Paint();
     70         //--抗锯齿
     71         mPointPaint.setAntiAlias(true);
     72         //--防抖
     73         mPointPaint.setDither(true);
     74         //--线段两端的形状
     75         mPointPaint.setStrokeCap(Paint.Cap.ROUND);
     76         //--线段的宽度
     77         mPointPaint.setStrokeWidth(mPointPaintWitdh);
     78         //--画笔颜色
     79         SweepGradient  mSweepGradient = new SweepGradient(mH/2, mW/2, arcColors, null);
     80         mPointPaint.setShader(mSweepGradient);
     81     }
     82     
     83     private int mH ;
     84     private int mW ;
     85     private int mMaxHight = 500;
     86     private int topsurplus = mLineWitdh/2 + 10;
     87     
     88     private int mProgres = 0;
     89     private float mTotalProgress = mMaxHight;
     90     
     91     private int inCircleR = 6;
     92     private int outCircleR = 14;
     93     
     94     private int currentLineProgress = 0;
     95     
     96     @Override
     97     protected void onSizeChanged(int w, int h, int oldw, int oldh) {
     98         // TODO Auto-generated method stub
     99         super.onSizeChanged(w, h, oldw, oldh);
    100         
    101         mH = w;
    102         mW = h;
    103     }
    104     
    105     @Override
    106     protected void onDraw(Canvas canvas) {
    107         // TODO Auto-generated method stub
    108         super.onDraw(canvas);
    109         //--平移画布
    110         canvas.translate(0, topsurplus);
    111         //--绘制背景色
    112         mLinePaint.setColor(Color.parseColor(mBackground));
    113         canvas.drawLine(mW/2, mMaxHight, mW/2, 0, mLinePaint);
    114         
    115         //--绘制前景色
    116         mLinePaint.setColor(Color.parseColor(mForeground));
    117         canvas.drawLine(mW/2, mMaxHight, mW/2, mMaxHight - currentLineProgress, mLinePaint);
    118         
    119         //--绘制圆环
    120         mPointPaint.setStyle(Paint.Style.STROKE);
    121         canvas.drawCircle(mW/2, mMaxHight - currentLineProgress , outCircleR, mPointPaint);
    122         mPointPaint.setStyle(Paint.Style.FILL);
    123         canvas.drawCircle(mW/2, mMaxHight - currentLineProgress , inCircleR, mPointPaint);
    124     }
    125     
    126     public void setBackgroup(String mBackgroup){
    127         this.mBackground = mBackgroup;
    128     }
    129     
    130     public void setForeground(String mForeground){
    131         this.mForeground = mForeground;
    132     }
    133     
    134     
    135     public void setProgress(float mProgress){
    136         if(this.mProgres >= mTotalProgress && mProgress > 0)
    137             return;
    138         this.mProgres += mProgress;
    139         
    140         float percent = mProgres/mTotalProgress;
    141         
    142         if(percent <0){
    143             this.mProgres = 0;
    144             return;
    145         }
    146         this.currentLineProgress = (int) (percent*mMaxHight);
    147         invalidate();
    148     }
    149     
    150     public void setMax(float mTotalProgress){
    151         if(mTotalProgress < 0)
    152             new IllegalArgumentException("invalid args && doubi");
    153         this.mTotalProgress = mTotalProgress;
    154     }
    155 }

    效果图如下:

    左侧增加文字属性:

    package com.example.canvasdemo;
    
    import android.content.Context;
    import android.graphics.Canvas;
    import android.graphics.Color;
    import android.graphics.EmbossMaskFilter;
    import android.graphics.Paint;
    import android.graphics.Paint.FontMetrics;
    import android.graphics.SweepGradient;
    import android.util.AttributeSet;
    import android.view.View;
    /**
     * 
     * @author liemng  QQ:859686819
     *
     */
    public class ZoomPinch extends View{
    
    	private Paint mLinePaint;
    	private Paint mPointPaint;
    	private int mLineWitdh = 18;
    	private int mPointPaintWitdh = 12;
    	
    	private String mForeground = "#FFFFFF";
    	private String mBackground = "#ff0000";
    	
    	private String[] mTips = new String[]{"1.0X", "2.0X", "3.0X", "4.0X"};
    	
    	// 梯度渐变的填充颜色
    	private int[] arcColors = new int[] { 0xFF48cbdc, 0xFF4c9fda, 0xFFeac83d,
    			0xFFc7427e, 0xFF48cbdc, 0xFF48cbdc };
    	
    	public ZoomPinch(Context context, AttributeSet attrs, int defStyleAttr) {
    		super(context, attrs, defStyleAttr);
    		initData();
    	}
    
    	public ZoomPinch(Context context, AttributeSet attrs) {
    		this(context, attrs, 0);
    	}
    
    	public ZoomPinch(Context context) {
    		this(context, null);
    	}
    	
    	public void initData(){
    		//--绘制线段画笔
    		mLinePaint = new Paint();
    		//--抗锯齿
    		mLinePaint.setAntiAlias(true);
    		//--防抖
    		mLinePaint.setDither(true);
    		//--线段两端的形状
    		mLinePaint.setStrokeCap(Paint.Cap.ROUND);
    		// 线段的宽度
    		mLinePaint.setStrokeWidth(mLineWitdh);
    		//--画笔颜色
    		mLinePaint.setColor(Color.parseColor("#000000"));
    		
    		//--设置光源的方向
    		float[] direction = new float[]{ 1, 1, 1 };
    		//--设置环境光亮度
    		float light = 0.4f;
    		//--选择要应用的反射等级
    		float specular = 6;
    		//--向mask应用一定级别的模糊
    		float blur = 3.5f;
    		EmbossMaskFilter emboss=new EmbossMaskFilter(direction,light,specular,blur);
    		mLinePaint.setMaskFilter(emboss);
    		
    		//--绘制圆环的画笔
    		mPointPaint = new Paint();
    		//--抗锯齿
    		mPointPaint.setAntiAlias(true);
    		//--防抖
    		mPointPaint.setDither(true);
    		//--线段两端的形状
    		mPointPaint.setStrokeCap(Paint.Cap.ROUND);
    		//--线段的宽度
    		mPointPaint.setStrokeWidth(mPointPaintWitdh);
    		//--画笔颜色
    		SweepGradient  mSweepGradient = new SweepGradient(mH/2, mW/2, arcColors, null);
    		mPointPaint.setShader(mSweepGradient);
    		
    		mTextPaint = new Paint();
    		mTextPaint.setTextSize(32);
    		mTextPaint.setColor(Color.parseColor("#FFFFFF"));
    	}
    	
    	private int averH;
    	
    	private int mH ;
    	private int mW ;
    	private int mMaxHight = 500;
    	private int topsurplus = mLineWitdh/2 + 10;
    	
    	private int mProgres = 0;
    	private float mTotalProgress = mMaxHight;
    	
    	private int inCircleR = 6;
    	private int outCircleR = 14;
    	
    	private int currentLineProgress = 0;
    	private Paint mTextPaint;
    	
    	@Override
    	protected void onSizeChanged(int w, int h, int oldw, int oldh) {
    		super.onSizeChanged(w, h, oldw, oldh);
    		
    		mH = w;
    		mW = h;
    	}
    	
    	@Override
    	protected void onDraw(Canvas canvas) {
    		super.onDraw(canvas);
    		//--平移画布
    		canvas.translate(0, topsurplus);
    		//--绘制背景色
    		mLinePaint.setColor(Color.parseColor(mBackground));
    		canvas.drawLine(mW/2, mMaxHight, mW/2, 0, mLinePaint);
    		
    		//--绘制前景色
    		mLinePaint.setColor(Color.parseColor(mForeground));
    		canvas.drawLine(mW/2, mMaxHight, mW/2, mMaxHight - currentLineProgress, mLinePaint);
    		
    		//--绘制圆环
    		mPointPaint.setStyle(Paint.Style.STROKE);
    		canvas.drawCircle(mW/2, mMaxHight - currentLineProgress , outCircleR, mPointPaint);
    		mPointPaint.setStyle(Paint.Style.FILL);
    		canvas.drawCircle(mW/2, mMaxHight - currentLineProgress , inCircleR, mPointPaint);
    		//--绘制左侧文字
    		for (int i = 0; i < mTips.length; i++) {
    			float textW = mTextPaint.measureText(mTips[i]);
    			FontMetrics fontMetrics = mTextPaint.getFontMetrics();
    			int textH = (int) (fontMetrics.descent - fontMetrics.ascent);
    			if(i == 0){
    				canvas.drawText(mTips[i], mW/2 - textW*3/2, mMaxHight, mTextPaint);
    				continue;
    			}
    			if(i == (mTips.length -1)){
    				canvas.drawText(mTips[i], mW/2 - textW*3/2, topsurplus, mTextPaint);
    				continue;
    			}
    			averH = mMaxHight/(mTips.length -1); 
    			
    			canvas.drawText(mTips[i], mW/2 - textW*3/2, mMaxHight - topsurplus - (averH*i - textH/2) , mTextPaint);
    		}
    		
    	}
    	
    	public void setBackgroup(String mBackgroup){
    		this.mBackground = mBackgroup;
    	}
    	
    	public void setForeground(String mForeground){
    		this.mForeground = mForeground;
    	}
    	
    	
    	public void setProgress(float mProgress){
    		if(this.mProgres >= mTotalProgress && mProgress > 0)
    			return;
    		this.mProgres += mProgress;
    		
    		float percent = mProgres/mTotalProgress;
    		
    		if(percent <0){
    			this.mProgres = 0;
    			return;
    		}
    		this.currentLineProgress = (int) (percent*mMaxHight);
    		invalidate();
    	}
    	
    	public void setMax(float mTotalProgress){
    		if(mTotalProgress < 0)
    			new IllegalArgumentException("invalid args && doubi");
    		this.mTotalProgress = mTotalProgress;
    	}
    }
    

    效果图如下:

    你得有足够的实力,你的原则和底线才会被人尊重。
  • 相关阅读:
    Codeforces Round #610 (Div. 2)C(贪心,思维)
    Educational Codeforces Round 80 (Rated for Div. 2)C(DP)
    BZOJ2190 仪仗队
    BZOJ3613 南园满地堆轻絮
    BZOJ1084 最大子矩阵
    BZOJ1036 树的统计Count
    BZOJ1452 Count
    BZOJ2242 计算器
    BZOJ2705 Longge的问题
    BZOJ1509 逃学的小孩
  • 原文地址:https://www.cnblogs.com/liemng/p/4937705.html
Copyright © 2011-2022 走看看