之前做的小程序需要这么一个东西,查了一下好像也没人发布过这类组件,就动手撸了一个小程序的简单的拾色器组件。
微信小程序拾色器(颜色选择器)组件☕
❗❗ 由于本人水平的原因,在使用该组件时的一些设置限制的比较严格,请务必认真阅读本文档。
git clone https://github.com/KirisakiAria/we-color-picker.git
将项目中src目录下的全部文件拷贝到/components/color-picker中,在使用该组件的页面对应json文件中添加:
"usingComponents": {
"color-picker":"/components/color-picker/color-picker"
}
具体如何引入组件请参考微信小程序官方文档
仿照PS的色相立方体制作而成
<color-picker class="color-picker" colorData="{{colorData}}" rpxRatio="{{rpxRatio}}" bindchangecolor="onChangeColor"></color-picker>
❗❗ color-picker自身和其祖先元素切勿使用定位样式(除非拾色器右上角与页面右上角重合的特殊情况),否则将导致拾色器选择点位置错误。
colorData: {
//基础色相,即左侧色盘右上顶点的颜色,由右侧的色相条控制
hueData: {
colorStopRed: 255,
colorStopGreen: 0,
colorStopBlue: 0,
},
//选择点的信息(左侧色盘上的小圆点,即你选择的颜色)
pickerData: {
x: 0, //选择点x轴偏移量
y: 480, //选择点y轴偏移量
red: 0,
green: 0,
blue: 0,
hex: '#000000'
},
//色相控制条的位置
barY: 0
},
rpxRatio: 1 //此值为你的屏幕CSS像素宽度/750,单位rpx实际像素
//设置rpxRatio
wx.getSystemInfo({
success(res) {
_this.setData({
rpxRatio: res.screenWidth / 750
})
}
})
//选择改色时触发(在左侧色盘触摸或者切换右侧色相条)
onChangeColor(e) {
//e.detail.colorData与参数中的colorData一致
}
<color-picker data-id="0" class="color-picker" colorData="{{colorData0}}" rpxRatio="{{rpxRatio}}" bindchangecolor="onChangeColor"></color-picker>
<color-picker data-id="1" class="color-picker" colorData="{{colorData1}}" rpxRatio="{{rpxRatio}}" bindchangecolor="onChangeColor"></color-picker>
<color-picker data-id="2" class="color-picker" colorData="{{colorData2}}" rpxRatio="{{rpxRatio}}" bindchangecolor="onChangeColor"></color-picker>
<!--More...-->
//设置多个参数即可
colorData0: {
//...
},
colorData1: {
//...
},
colorData2: {
//...
},
//More...
onChangeColor(e) {
//这里我使用了dataset来存储标志,用来判断时哪个拾色器发生变化
const index = e.target.dataset.id
this.setData({
[`colorData${index}`]: e.detail.colorData
})
}
wechat: thereshegoes
email: xiaoli350791904@hotmail.com
6 个评论
为什么颜色显示框是一种颜色,不渐变
不跟手。不流畅。能否优化下
您好,请问,我在使用插件的过程中,发布体验版和正式版会出现这个情况,删除插件就没有了,请问有没有解决办法?
https://developers.weixin.qq.com/community/develop/doc/000e4a96f98258eb92a15653a61400
怎么调大小
赞一个!
大佬 我想问一下mpvue中如何使用这个组件
emmm不好意思,没用过mpvue这类小程序框架..