一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - Android - Android自定義view實現圖片選色器

Android自定義view實現圖片選色器

2022-02-27 16:40oden.su Android

這篇文章主要為大家詳細介紹了Android自定義view實現圖片選色器,具有一定的參考價值,感興趣的小伙伴們可以參考一下

簡介

本文介紹該自定義view的使用及實現的方法,主要實現以下幾個功能:

- 選取圓盤選色圖片上的顏色,實時監聽
- 可設置選色指示圖片,跟隨觸摸位置、指示所選顏色,示例中為白色圓環
- 可自己設置選色圖片(目前只支持圓形圖片)

github鏈接

使用效果

首先看下使用效果:

Android自定義view實現圖片選色器

使用示例

在項目中導入該庫

在工程的 build.gradle中加入:

?
1
2
3
4
5
6
allprojects {
  repositories {
   ...
   maven { url "https://jitpack.io" }
  }
 }

module的build.gradle中加入依賴:

?
1
2
3
dependencies {
   compile 'com.github.autume:ColorPickerView:1.0'
 }

xml

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
<RelativeLayout
  android:id="@+id/rl_picker"
  android:layout_below="@+id/img_color"
  android:layout_marginTop="30dp"
  android:layout_centerHorizontal="true"
  android:layout_width="wrap_content"
  android:layout_height="wrap_content">
 
  <colorpickerview.oden.com.colorpicker.ColorPickerView
   android:id="@+id/color_picker"
   android:layout_width="wrap_content"
   android:layout_height="wrap_content"/>
 
 
  <ImageView
   android:id="@+id/img_picker"
   android:layout_centerInParent="true"
   android:src="@mipmap/color_picker"
   android:layout_width="25dp"
   android:layout_height="25dp" />
 
 </RelativeLayout>

選色代碼

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
private void initRgbPicker() {
  colorPickerView = (ColorPickerView) findViewById(R.id.color_picker);
  colorPickerView.setImgPicker(MainActivity.this, img_picker, 25); //最后一個參數是該顏色指示圈的大小(dp)
  colorPickerView.setColorChangedListener(new ColorPickerView.onColorChangedListener() {
   @Override
   public void colorChanged(int red, int blue, int green) {
    img_color.setColorFilter(Color.argb(255, red, green, blue));
   }
 
   @Override
   public void stopColorChanged(int red, int blue, int green) {
 
   }
  });
 }

對外公開的API

?
1
2
3
public void setImgPicker(final Context context, final ImageView imgPicker, final int pickerViewWidth)
public void setImgResource(final int imgResource)
public void setColorChangedListener(onColorChangedListener colorChangedListener)

實現過程

attrs屬性

可通過picture_resource屬性設置用來選色的資源id,現僅支持圓形圖片

?
1
2
3
<declare-styleable name="ColorPickerView">
 <attr name="picture_resource" format="reference"/>
</declare-styleable>

xml

布局中就是放入一個ImageView控件

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
 xmlns:tools="http://schemas.android.com/tools"
 android:id="@+id/rl_root"
 tools:background="@color/black"
 android:layout_width="match_parent"
 android:layout_height="wrap_content">
 
 <ImageView
  android:id="@+id/img_color_rang"
  android:layout_width="wrap_content"
  android:layout_height="wrap_content"
  android:layout_centerInParent="true"
  android:src="@mipmap/lights_colors" />
 
 
</RelativeLayout>

屬性獲取及view初始化

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
private void initAttrs(Context context, AttributeSet attrs) {
  if (null != attrs) {
   TypedArray typedArray = context.obtainStyledAttributes(attrs, R.styleable.ColorPickerView);
   imgResource = typedArray.getResourceId(R.styleable.ColorPickerView_picture_resource, 0);
   typedArray.recycle();
  }
 }
 
 private void initView(Context context) {
  View view = LayoutInflater.from(context).inflate(R.layout.color_picker, this);
  imgColorRang = (ImageView) view.findViewById(R.id.img_color_rang);
  rl_root = (RelativeLayout) view.findViewById(R.id.rl_root);
 
  if (imgResource != 0)
   imgColorRang.setImageResource(imgResource);
 
  bitmap = ((BitmapDrawable) imgColorRang.getDrawable()).getBitmap();//獲取圓盤圖片
 }

顏色回調監聽

?
1
2
3
4
5
6
7
8
9
10
11
12
13
private onColorChangedListener colorChangedListener;//顏色變換監聽
 
public void setColorChangedListener(onColorChangedListener colorChangedListener) {
 this.colorChangedListener = colorChangedListener;
}
 
/**
 * 顏色變換監聽接口
 */
public interface onColorChangedListener {
 void colorChanged(int red, int blue, int green);
 void stopColorChanged(int red, int blue, int green);
}

觸摸事件

觸摸事件寫在父控件上,可以統一處理用來選色的view及指示選色位置的view(imgPicker),imgPicker為指示顯示位置的圓框,若設置了則跟隨手指移動。

 

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
private void initTouchListener() {
 rl_root.setOnTouchListener(new OnTouchListener() {
  @Override
  public boolean onTouch(View v, MotionEvent event) {
 
   if (range_radius == 0) {
    range_radius = imgColorRang.getWidth() / 2; //圓盤半徑
    centreX = imgColorRang.getRight() - range_radius;
    centreY = imgColorRang.getBottom() - imgColorRang.getHeight() / 2;
    select_radius = range_radius - pickerViewPadding/5;
   }
 
   float xInView = event.getX();
   float yInView = event.getY();
   Log.d(TAG, "xInView: " + xInView + ",yInView: " + yInView + ",left: " + imgColorRang.getLeft() + ",top: " + imgColorRang.getTop() + ",right: " +imgColorRang.getRight() + ",bottom: " + imgColorRang.getBottom());
 
   //觸摸點與圓盤圓心距離
   float diff = (float) Math.sqrt((centreY - yInView) * (centreY - yInView) + (centreX - xInView) *
     (centreX - xInView));
 
   //在選色圖片內則進行讀取顏色等操作
   if (diff <= select_radius) {
 
    //選色位置指示,若設置了則移動到點取的位置
    if (imgPicker != null ) {
     int xInWindow = (int) event.getX();
     int yInWindow = (int) event.getY();
     int left = xInWindow + v.getLeft() - imgPicker.getWidth() / 2;
     int top = yInWindow + v.getTop() - imgPicker.getWidth() / 2;
     int right = left + imgPicker.getWidth();
     int bottom = top + imgPicker.getHeight();
 
     imgPicker.layout(left, top, right, bottom);
    }
 
 
    if ((event.getY() - imgColorRang.getTop()) < 0)
     return true;
    //讀取顏色
    int pixel = bitmap.getPixel((int) (event.getX() - imgColorRang.getLeft()), (int) (event.getY() - imgColorRang.getTop())); //獲取選擇像素
    if (colorChangedListener != null) {
     if (event.getAction() == MotionEvent.ACTION_UP) {
      colorChangedListener.stopColorChanged(Color.red(pixel), Color.blue(pixel), Color.green(pixel));
     }else {
      colorChangedListener.colorChanged(Color.red(pixel), Color.blue(pixel), Color.green(pixel));
     }
    }
    Log.d(TAG, "radValue=" + Color.red(pixel) + " blueValue=" + Color.blue(pixel) + " greenValue" + Color.green(pixel));
   }
   return true;
  }
 });
}

設置指示圖標

設置圖標,同時根據圖標的大小設置控件的padding避免在邊界處顯示不全的問題。

?
1
2
3
4
5
6
7
8
9
10
11
public void setImgPicker(final Context context, final ImageView imgPicker, final int pickerViewWidth) {
  this.imgPicker = imgPicker;
  pickerViewPadding = dip2px(context, pickerViewWidth/2);
  new Handler().postDelayed(new Runnable() {
   @Override
   public void run() {
    rl_root.setPadding(pickerViewPadding, pickerViewPadding, pickerViewPadding, pickerViewPadding);
    bitmap = ((BitmapDrawable) imgColorRang.getDrawable()).getBitmap();//獲取圓盤圖片
   }
  },10);
 }

總結

ok,至此,一個比較簡單的選色器就完成了。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持服務器之家。

原文鏈接:https://blog.csdn.net/yaodong379/article/details/70147486

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 色图片小说| 95在线观看精品视频 | 国产精品二区高清在线 | 日韩黄色录像 | 艹逼的视频 | 农村妇女野战bbxxx | 四虎国产成人亚洲精品 | 国产精品一区二区国产 | 日本成熟bbxxxxxxxx | 蜜桃成熟时1997在线看免费看 | 日本www视频在线观看 | 国产大秀视频一区二区三区 | 美女视频91| 亚洲一卡2卡4卡5卡6卡残暴在线 | 插鸡视频在线观看 | 国产精品刺激好大好爽视频 | 亚洲一区二区精品视频 | 精品一区二区三区在线播放 | 欧美一级欧美三级 | 单亲乱l仑在线观看免费观看 | 91制片厂制作传媒免费版樱花 | 精品久久伦理中文字幕 | 3d动漫被吸乳羞羞 | 狠狠色狠狠色综合婷婷tag | 美女扒开两腿露出尿口的视频 | 变态 另类 国产 亚洲 | 奇米成人 | 国产麻豆精品原创 | 91粉色视频在线导航 | 3x免费高清视频 | 亚洲一欧洲中文字幕在线 | 我的美女奴隶 | 无码人妻丰满熟妇啪啪网不卡 | 日本福利视频网站 | 激情影院免费观看 | 国产午夜一区二区在线观看 | 午夜爱爱片| 亚洲国产一区二区三区a毛片 | 狠狠夜夜久久日日91av | 猫咪社区在线播放 | 91精品免费国产高清在线 |