Android 颜色选择器(ColorPicker)

先上图

1.测试界面

2. 调色板对话框

3.改变字体颜色

 

package com.xsl.colorpicker;

 

import android.app.Dialog;

import android.content.Context;

import android.graphics.Canvas;

import android.graphics.Color;

import android.graphics.LinearGradient;

import android.graphics.Paint;

import android.graphics.RectF;

import android.graphics.Shader;

import android.graphics.SweepGradient;

import android.os.Bundle;

import android.util.Log;

import android.view.MotionEvent;

import android.view.View;

import android.view.WindowManager;

 

public class ColorPickerDialog extends Dialog {

    private final boolean debug = true;

    private final String TAG = "ColorPicker";

     

    Context context;

    private String title;       //标题

    private int mInitialColor;  //初始颜色

    private OnColorChangedListener mListener;

 

    /**

     * 初始颜色黑色

     * @param context

     * @param title 对话框标题

     * @param listener 回调

     */

    public ColorPickerDialog(Context context, String title, 

            OnColorChangedListener listener) {

        this(context, Color.BLACK, title, listener);

    }

     

    /**

     * 

     * @param context

     * @param initialColor 初始颜色

     * @param title 标题

     * @param listener 回调

     */

    public ColorPickerDialog(Context context, int initialColor, 

            String title, OnColorChangedListener listener) {

        super(context);

        this.context = context;

        mListener = listener;

        mInitialColor = initialColor;

        this.title = title;

    }

 

    @Override

    protected void onCreate(Bundle savedInstanceState) {

        super.onCreate(savedInstanceState);

        WindowManager manager = getWindow().getWindowManager();

        int height = (int) (manager.getDefaultDisplay().getHeight() * 0.38f);       //0.5

        int width = (int) (manager.getDefaultDisplay().getWidth() * 0.5f);          //0.7

        ColorPickerView myView = new ColorPickerView(context, height, width);

        setContentView(myView);

        setTitle(title);

    }

     

    private class ColorPickerView extends View {

        private Paint mPaint;           //渐变色环画笔

        private Paint mCenterPaint;     //中间圆画笔

        private Paint mLinePaint;       //分隔线画笔

        private Paint mRectPaint;       //渐变方块画笔

         

        private Shader rectShader;      //渐变方块渐变图像

        private float rectLeft;         //渐变方块左x坐标

        private float rectTop;          //渐变方块右x坐标

        private float rectRight;        //渐变方块上y坐标

        private float rectBottom;       //渐变方块下y坐标

         

        private final int[] mCircleColors;      //渐变色环颜色

        private final int[] mRectColors;        //渐变方块颜色

         

        private int mHeight;                    //View高

        private int mWidth;   
  • 5
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值