选择条

     群里有人问一个线型的选择条,分段彩色的。

     他的需求是这样的:

   


我的第一想法就是使用roundRect去实现,但是转念一想,roundRect只能是一种颜色,好吧,采用最笨的方法画圆+矩形,脑补图如下:


好吧,不要吐槽,我笨,所以只能想到这里,

开始上代码:



首先呢,我们来分析下,我需要什么参数来绘制这个view,,color,数值的大小,通过数值大小我们可以求出比例值,根据view的宽度*比例值那么就能自动适应:

上代码:

Bean

package com.example.colorline;

import java.io.Serializable;

import android.graphics.Color;

public class ZoomBean implements Serializable {
	
	private int realSize = 0;
	
	private int color = Color.BLUE;

	private float proportion = 0.0F;
	
	public ZoomBean(){}
	
	public ZoomBean(int realSize,int color){
		this.realSize = realSize;
		this.color = color;
	}
	
	public int getRealSize() {
		return realSize;
	}

	public void setRealSize(int realSize) {
		this.realSize = realSize;
	}

	public int getColor() {
		return color;
	}

	public void setColor(int color) {
		this.color = color;
	}

	public float getProportion() {
		return proportion;
	}

	public void setProportion(float proportion) {
		this.proportion = proportion;
	}
	
	
}

然后是View类:

package com.example.colorline;

import java.util.ArrayList;
import java.util.List;

import android.annotation.SuppressLint;
import android.content.Context;
import android.graphics.Canvas;
import android.graphics.Color;
import android.graphics.Paint;
import android.graphics.Path;
import android.graphics.Rect;
import android.graphics.RectF;
import android.util.AttributeSet;
import android.view.View;
import android.view.Window;

public class RoadLine extends View {
	
	private Paint paint = null;
	/**
	 * 白色间隔默认1px
	 */
	private int space = 1;
	
	private List<ZoomBean> zoomList = null;
	
	public RoadLine(Context context) {
		super(context);
		initWidget();
	}
	public RoadLine(Context context, AttributeSet attrs) {
		super(context, attrs);
		initWidget();
	}
	public RoadLine(Context context, AttributeSet attrs, int defStyle) {
		super(context, attrs, defStyle);
		initWidget();
	}
	
	
	private void initWidget(){
		
		setMinimumWidth(100);  
		
		paint = new Paint();
		paint.setAntiAlias(true);
		paint.setColor(Color.BLUE);
	}
	@SuppressLint("DrawAllocation")
	@Override
	protected void onDraw(Canvas canvas) {
		super.onDraw(canvas);
		
		int viewWidth = getWidth();
		int viewHeight = getHeight();
		
		int realDrwaWidth = viewWidth-viewHeight;//实际rect绘制的宽度
		Rect rect = new Rect(viewHeight/2, 0, viewWidth-viewHeight/2,viewHeight);//实际可以绘制的矩形范围
		
		if(zoomList == null||zoomList.size()==1){
			if(zoomList!=null)
				paint.setColor(zoomList.get(0).getColor());
			canvas.drawRect(rect, paint);
			canvas.drawOval(new RectF(0,0,viewHeight,viewHeight),paint);
			canvas.drawOval(new RectF(viewWidth-viewHeight,0,viewWidth,viewHeight),paint);
			return;
		}
		
		synchronized (zoomList) {
			getProportion(zoomList);
		}
		
		int afterX = viewHeight/2;
		for (int i = 0;i<zoomList.size();i++) {
			ZoomBean zoomBean = zoomList.get(i);
			paint.setColor(zoomBean.getColor());
			if(i==0)
				canvas.drawOval(new RectF(0,0,viewHeight,viewHeight),paint);
			else if(i == zoomList.size()-1)
				canvas.drawOval(new RectF(viewWidth-viewHeight,0,viewWidth,viewHeight),paint);
			int right = (int)((viewWidth-viewHeight)*zoomBean.getProportion());
			Rect childRect = null;
			childRect= new Rect(afterX, 0,afterX + right, viewHeight);
			canvas.drawRect(childRect, paint);
			afterX += right;
		}
		
	}
	
	
	private void getProportion(List<ZoomBean> zoomList) {
		float totalSize = 0.0F;
		for (ZoomBean zoomBean : zoomList) {
			totalSize+=zoomBean.getRealSize();
		}
		for (int i = 0;i<zoomList.size();i++) {
			zoomList.get(i).setProportion(zoomList.get(i).getRealSize()/totalSize);
		}
	}
	
	public int getSpace() {
		return space;
	}
	public void setSpace(int space) {
		this.space = space;
	}
	
	public void setData(List<ZoomBean> zoomList){
		this.zoomList = zoomList;
		invalidate();
	}

	public void appendData(ZoomBean zoomBean){
		if(this.zoomList == null)
			zoomList = new ArrayList<ZoomBean>();
		zoomList.add(zoomBean);
		invalidate();
	}
	
}

再然后呢是XML图纸文件:

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
     >
	
    <com.example.colorline.RoadLine
        android:id="@+id/raodLine"
        android:layout_width="fill_parent"
        android:layout_height="40dp"
        ></com.example.colorline.RoadLine>
    
</RelativeLayout>

再再然后呢是activity:

package com.example.colorline;

import java.util.ArrayList;
import java.util.List;

import android.os.Bundle;
import android.app.Activity;
import android.graphics.Color;
import android.view.Menu;

public class MainActivity extends Activity {
	
	private List<ZoomBean> zoomList = new ArrayList<ZoomBean>();
	
	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.activity_main);
		
		RoadLine roadLine = (RoadLine) findViewById(R.id.raodLine);
		initData();
		
		roadLine.setData(zoomList);
	}

	private void initData() {
		for(int i = 1;i<6;i++){
			if(i == 0)
				zoomList.add(new ZoomBean(i*10,Color.BLUE));
			if(i == 1)
				zoomList.add(new ZoomBean(i*10,Color.RED));
			if(i == 2)
				zoomList.add(new ZoomBean(i*10,Color.YELLOW));
			if(i == 3)
				zoomList.add(new ZoomBean(i*10,Color.GREEN));
			if(i == 4)
				zoomList.add(new ZoomBean(i*10,Color.CYAN));
		}
	}

}
。。上下效果图:


好吧,本人比较懒,只把主要的东西实现了,剩下的ruler跟字大家自己去draw吧,哈哈哈哈哈哈。。。。

注:大神勿喷


资源下载:http://download.csdn.net/detail/u010819959/9299903


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值