用滑动条做调色板

创建一个简单的程序:通过调节滑动条来设定画板颜色。我们
要创建一个窗口来显示显色,还有三个滑动条来设置 B,G,R 的颜色。当我们
滑动滚动条是窗口的颜色也会发生相应改变。默认情况下窗口的起始颜色为黑。
cv2.getTrackbarPos() 函数的一个参数是滑动条的名字,第二个参数
是滑动条被放置窗口的名字,第三个参数是滑动条的默认位置。第四个参数是
滑动条的最大值,第五个函数是回调函数,每次滑动条的滑动都会调用回调函
数。回调函数通常都会含有一个默认参数,就是滑动条的位置。在本例中这个
函数不用做任何事情,我们只需要 pass 就可以了。
滑动条的另外一个重要应用就是用作转换按钮。默认情况下 OpenCV 本
身不带有按钮函数。所以我们使用滑动条来代替。在我们的程序中,我们要创
建一个转换按钮,只有当装换按钮指向 ON 时,滑动条的滑动才有用,否则窗
户口都是黑的。

# -*- coding: utf-8 -*-
"""
Created on Sun May 5 13:51:34 2019
@author: nwpujun
"""
import cv2
import numpy as np
def nothing(x):
    pass
# 创建一副黑色图像
img=np.zeros((300,512,3),np.uint8)
#高300宽512
cv2.namedWindow(‘image‘)
cv2.createTrackbar(‘R‘,‘image‘,0,255,nothing)
#1.滑动条名字 2.滑动条被放置窗口的名字 3.默认位置 4.最大值 5.回调函数
cv2.createTrackbar(‘G‘,‘image‘,0,255,nothing)
cv2.createTrackbar(‘B‘,‘image‘,0,255,nothing)
switch=‘0:OFF\n1:ON‘
cv2.createTrackbar(switch,‘image‘,0,1,nothing)
#转换按钮
while(1):
    cv2.imshow(‘image‘,img)
    k=cv2.waitKey(1)&0xFF
    if k==27:
        break
    r=cv2.getTrackbarPos(‘R‘,‘image‘)
    g=cv2.getTrackbarPos(‘G‘,‘image‘)
    b=cv2.getTrackbarPos(‘B‘,‘image‘)
    s=cv2.getTrackbarPos(switch,‘image‘)
    if s==0:
        img[:]=0
    else:
        img[:]=[b,g,r]
cv2.destroyAllWindows()

原文地址:https://www.cnblogs.com/nwpujun/p/10813420.html

时间: 2024-10-03 23:04:37

用滑动条做调色板的相关文章

python opencv:使用滑动条做调色板

cv2.getTrackbarPos() 函数的 一个参数是滑动条的名字, 第二个参数是滑动条被放置窗口的名字, 第三个参数是滑动条的默认位置. 第四个参数是滑动条的最大值, 第五个函数是回调函数,每次滑动条的滑动都会调用回调函数. 回调函数通常都会含有一个默认参数,就是滑动条的位置. 在本例中这个函数不用做任何事情,我们只需要 pass 就可以了 滑动条的另外一个重要应用就是用作转换按钮. 默认情况下 OpenCV 本身不带有按钮函数. 所以我们使用滑动条来代替. 在我们的程序中,我们要创建一

Python OpenCV 用滑动条做调色板

# -*- coding: utf-8 -*- import cv2 import numpy as np def nothing(x): pass img = np.zeros((300, 512, 3), np.uint8) cv2.namedWindow('image') cv2.createTrackbar('R', 'image', 0, 255, nothing) cv2.createTrackbar('G', 'image', 0, 255, nothing) cv2.create

Android模仿三星手机系统滑动条滑动时滑块变大的特效

使用三星手机的过程中发现三星手机系统自带的滑动条有一个特效,比如调节亮度的滑动条,在滑动滑块的过程中,滑块会变大,功能很小但是体验却很好,于是决定做一个这样的效果出来,好了废话不多说了,下面开始实现 我们知道在SeekBar控件中有两个很重要的属性,一个是进度条(即android:progressDrawable属性),一个是滑块(即android:thumb属性),我们主要用到的是滑块的特效,这里就把进度条的配置稍微的介绍一下,先上代码: 在res/xml文件夹下创建seekbar_progr

滑动条效果

准备将自己做的滑动条效果都放在这篇博文下. 自己的第一个成果 css body{ background: black; } #slider_1{ width: 400px; height: 2px; border-radius: 1px; display: -webkit-flex; position: relative; margin: 30px auto; } #oSlider{ width: 15px; height: 15px; position: absolute; border: 1

手风琴效果和滑动条

由于本周开始编写 宝石迷阵这款益智游戏,其中涉及到的两个效果我觉得很有趣. 手风琴:点击一级餐单,二级菜单动态弹出:再次点击一级菜单,二级菜单缩回: 实现方法如下: 首先,用CSS和HTML规划9个框,其中第1.4.7个相对大一点,作为我们的一级餐单.其他尺寸小的就用来做二级餐单. 其次,再每个一级菜单中嵌入一个A标签,改标签引用一个能够让我们达到效果的函数. 以下是我的函数,有点搓,但是有效果 var clickno = 1;        //这个是标记变量,干嘛的呢,当标记为-1时,说第一

Libgdx之ProgressBar (进度条) Slider(滑动条)

ProgressBar 即进度条,extends Widget.展示了在给定范围内时间/加载进度.PreferHeight是由给定的背景图片或者knob的最大高度决定的,默认的宽度width是140. Slider 滑动条,一般在游戏中设置调节音量或者调节游戏难度等等. Slider就是一水平的指示条,允许用户设值.Extends ProgressBar 因此也具有一个min max值,一个移动步调. 同理PreferHeight是由给定的背景图片或者knob的最大高度决定的,默认的宽度widt

简单的滑动条

今天要做个滑动条 如图: 用jqueryUI实现 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>简单的滑动条插件</title> <link rel="stylesheet" href="js/jQueryUi/jquery-ui.min.css">

OpenCV中通过滑动条阈值分割多通道图像

1.阈值分割 阈值分割法是一种基于区域的图像分割技术.其基本原理是:通过设定不同的特征阈值,把图像象素点分为若干类.根据图像阈值化算法所依据的信息源,可将阈值化方法分为五类:1) 基于聚类的方法:数据聚类中,总的数据集被划分为属性相似的子类,例如将灰度级聚类成为两部分:前景物体部分和背景部分.2) 基于直方图的方法:在直方图的峰.谷和直方图的圆滑曲线上进行分析.3) 基于熵的方法:熵方法将区域分为背景区域和前景区域,前景区域通常是物体部分(在一些热红外图像中,背景部分是物体) .该方法是通过最小

使用OpenCV滑动条写成的简单调色器,实时输出RGB值

好久没有写博客了,最近在看OpenCV,于是动手写了个简单的RGB调色器,在终端实时输出RGB的值.通过这个程序学习滑动条的使用.程序中主要用到cvCreateTrackbar ,其用法如下: cvCreateTrackbar 创建trackbar并将它添加到指定的窗口. CV_EXTERN_C_FUNCPTR( void (*CvTrackbarCallback)(int pos) ); int cvCreateTrackbar( const char* trackbar_name, cons