当前位置: 首页 > news >正文

.flv 网站播放班级优化大师头像

.flv 网站播放,班级优化大师头像,网站 兼容性,长沙一站式网站建设【1】引言 前序已经掌握了使用cv2.circle()绘制圆形的基本操作,相关链接为: python学opencv|读取图像(二十)使用cv2.circle()绘制圆形-CSDN博客 由于圆形本身绘制起来比较简单,因此可以自由操作的空间也就大&#x…

【1】引言

前序已经掌握了使用cv2.circle()绘制圆形的基本操作,相关链接为:

python学opencv|读取图像(二十)使用cv2.circle()绘制圆形-CSDN博客

由于圆形本身绘制起来比较简单,因此可以自由操作的空间也就大,我们今天就尝试多一些花样,做一次进阶探索。

【2】代码探索

【2.1】同心圆

绘制同心圆的基本思路是,确认好圆心以后,逐个修改半径,然后输出图像即可。

还是以之前的代码为基础,增加for循环逐个输出圆即可。此处先给出完整代码:

import numpy as np  # 引入numpy模块
import cv2 as cv  # 引入cv模块canvas = np.ones((580, 580, 3), np.uint8) * 225  # 绘制一个580*580大小的画布,3代表有3个通道,unit8为图像存储格式
# 第一个通道值
#for i in range(0, 580, 1):#for j in range(0, 580, 1):#canvas[i, j, 0] = 0.2 * (i + j)  # 第一个通道值# 第二个通道值
#for i in range(0, 580, 1):#for j in range(0, 580, 1):#canvas[i, j, 1] = 50 * np.cos(i ^ j) + 55 * np.sin(j ^ i) + 150 * np.sin(j - i)  # 第二个通道值# 第三个通道值
#for i in range(0, 580, 1):#for j in range(0, 580, 1):#canvas[i, j, 2] = 100 * np.tanh(i + j) + 100 * np.tanh(i - j) + 50 * np.cos(j - i)  # 第三个通道值
x0=285 #圆心横坐标
y0=285 #圆心纵坐标
for i in range(1,6,1):canvas = cv.circle(canvas, (x0, y0), 50*i, (int(255*np.cos((np.sqrt(np.square(15-i))))), int(255*np.sin(i)), int(np.abs(i-3))^5), i) #输出同心圆#canvas = cv.circle(canvas, (285, 285), 80, (0, 0, 255), 3)  # 第一个圆形
#canvas = cv.circle(canvas, (100, 285), 80, (0, 255, 255), -1)  # 第二个圆形
#canvas = cv.circle(canvas, (470, 285), 80, (255, 0, 0), -1)  # 第三个圆形
# canvas = cv.rectangle(canvas, (50, 30), (530, 550), (155, 120, 60), 5)  # 矩形
# canvas = cv.rectangle(canvas, (80, 80), (500, 500), (55, 160, 230), 10)  # 矩形
# canvas = cv.rectangle(canvas, (150, 150), (430, 430), (50, 120, 90), -1)  # 矩形
# canvas = cv.line(canvas, (50, 550), (550, 550), (58, 50, 150), 15)  # 线段
# canvas = cv.line(canvas, (300, 50), (300, 550), (120, 150, 25), 20)  # 线段cv.imshow('rectangle', canvas)  # 在屏幕展示绘制圆形的效果
cv.imwrite('circle50.png', canvas)  # 保存图像
cv.waitKey()  # 图像不会自动关闭
cv.destroyAllWindows()  # 释放所有窗口

程序运行后的输出图像为:

图1 同心圆

创造同心圆的核心代码段落为:

x0=285 #圆心横坐标
y0=285 #圆心横坐标
for i in range(1,5,1):canvas = cv.circle(canvas, (x0, y0), 50*i, (int(255*np.cos((np.sqrt(np.square(15-i))))), int(255*np.sin(i)), int(np.abs(i-3))^5), i) #输出同心圆

首先用x0和y0确认了愿新的坐标点,然后用for循环输出5个圆形即可。

这五个圆的半径计算式为:r=50*i,i就是圆形的出现顺序;圆的颜色采用了函数的形式,不是此处重点;圆的线宽就是圆出现的顺序。

总体上,圆出现的顺序越晚,半径越大,线条越宽。

【2.2】疏密同心圆

绘制疏密同心圆的基本思路是,利用三角函数的斜率也是三角函数的原理,如果半径通过三角函数来取值,那同样的增量下,邻近半径值的差会周期性的时大时小,这样就会画出疏密同心圆。

以2π为周期,增量从0到7就可以覆盖一个周期内的所有圆。

在这个分析基础上,我们把核心代码换成:

x0=285 #圆心横坐标
y0=285 #圆心横坐标
for i in range(0,7,1):canvas = cv.circle(canvas, (x0, y0), np.abs(int(260*np.cos(i))), (200,180,55), 2) #输出同心圆

半径取值为np.abs(int(260*np.cos(i))),这里的np.abs()是取绝对值的意思,因为半径必须为正数。

此时获得的图形为:

图2 疏密同心圆

对应的完整代码为:

import numpy as np  # 引入numpy模块
import cv2 as cv  # 引入cv模块canvas = np.ones((580, 580, 3), np.uint8) * 225  # 绘制一个580*580大小的画布,3代表有3个通道,unit8为图像存储格式
# 第一个通道值
#for i in range(0, 580, 1):#for j in range(0, 580, 1):#canvas[i, j, 0] = 0.2 * (i + j)  # 第一个通道值# 第二个通道值
#for i in range(0, 580, 1):#for j in range(0, 580, 1):#canvas[i, j, 1] = 50 * np.cos(i ^ j) + 55 * np.sin(j ^ i) + 150 * np.sin(j - i)  # 第二个通道值# 第三个通道值
#for i in range(0, 580, 1):#for j in range(0, 580, 1):#canvas[i, j, 2] = 100 * np.tanh(i + j) + 100 * np.tanh(i - j) + 50 * np.cos(j - i)  # 第三个通道值
x0=285 #圆心横坐标
y0=285 #圆心横坐标
for i in range(0,7,1):canvas = cv.circle(canvas, (x0, y0), np.abs(int(260*np.cos(i))), (200,180,55), 2) #输出同心圆#canvas = cv.circle(canvas, (285, 285), 80, (0, 0, 255), 3)  # 第一个圆形
#canvas = cv.circle(canvas, (100, 285), 80, (0, 255, 255), -1)  # 第二个圆形
#canvas = cv.circle(canvas, (470, 285), 80, (255, 0, 0), -1)  # 第三个圆形
# canvas = cv.rectangle(canvas, (50, 30), (530, 550), (155, 120, 60), 5)  # 矩形
# canvas = cv.rectangle(canvas, (80, 80), (500, 500), (55, 160, 230), 10)  # 矩形
# canvas = cv.rectangle(canvas, (150, 150), (430, 430), (50, 120, 90), -1)  # 矩形
# canvas = cv.line(canvas, (50, 550), (550, 550), (58, 50, 150), 15)  # 线段
# canvas = cv.line(canvas, (300, 50), (300, 550), (120, 150, 25), 20)  # 线段cv.imshow('rectangle', canvas)  # 在屏幕展示绘制圆形的效果
cv.imwrite('circle50.png', canvas)  # 保存图像
cv.waitKey()  # 图像不会自动关闭
cv.destroyAllWindows()  # 释放所有窗口

【2.3】变化圆心

既然圆的半径可以变化,圆形自然也可以变化,继续修改核心代码:

r=160 #半径
for i in range(0,10,1):canvas = cv.circle(canvas, ((i-5)*10+280, (i-5)*20+280), r, (200,180,55), 2) #输出同心圆

在这里,圆心坐标被更换为((i-5)*10+280, (i-5)*20+280),这几一个动态值,只有半径是恒定的160。代码运行获得的图像为:

图3 圆心变化

此时的完整代码为:

import numpy as np  # 引入numpy模块
import cv2 as cv  # 引入cv模块canvas = np.ones((580, 580, 3), np.uint8) * 225  # 绘制一个580*580大小的画布,3代表有3个通道,unit8为图像存储格式
# 第一个通道值
#for i in range(0, 580, 1):#for j in range(0, 580, 1):#canvas[i, j, 0] = 0.2 * (i + j)  # 第一个通道值# 第二个通道值
#for i in range(0, 580, 1):#for j in range(0, 580, 1):#canvas[i, j, 1] = 50 * np.cos(i ^ j) + 55 * np.sin(j ^ i) + 150 * np.sin(j - i)  # 第二个通道值# 第三个通道值
#for i in range(0, 580, 1):#for j in range(0, 580, 1):#canvas[i, j, 2] = 100 * np.tanh(i + j) + 100 * np.tanh(i - j) + 50 * np.cos(j - i)  # 第三个通道值
#x0=285 #圆心横坐标
#y0=285 #圆心横坐标
r=160 #半径
for i in range(0,10,1):canvas = cv.circle(canvas, ((i-5)*10+280, (i-5)*20+280), r, (200,180,55), 2) #输出同心圆#canvas = cv.circle(canvas, (285, 285), 80, (0, 0, 255), 3)  # 第一个圆形
#canvas = cv.circle(canvas, (100, 285), 80, (0, 255, 255), -1)  # 第二个圆形
#canvas = cv.circle(canvas, (470, 285), 80, (255, 0, 0), -1)  # 第三个圆形
# canvas = cv.rectangle(canvas, (50, 30), (530, 550), (155, 120, 60), 5)  # 矩形
# canvas = cv.rectangle(canvas, (80, 80), (500, 500), (55, 160, 230), 10)  # 矩形
# canvas = cv.rectangle(canvas, (150, 150), (430, 430), (50, 120, 90), -1)  # 矩形
# canvas = cv.line(canvas, (50, 550), (550, 550), (58, 50, 150), 15)  # 线段
# canvas = cv.line(canvas, (300, 50), (300, 550), (120, 150, 25), 20)  # 线段cv.imshow('rectangle', canvas)  # 在屏幕展示绘制圆形的效果
cv.imwrite('circle50.png', canvas)  # 保存图像
cv.waitKey()  # 图像不会自动关闭
cv.destroyAllWindows()  # 释放所有窗口

【2.4】变化圆半径

在圆心变化的基础上,圆的半径可以变化,这样就会出现变化圆。

继续增添代码:

for i in range(0,10,1):canvas = cv.circle(canvas, ((i-5)*10+280, (i-5)*20+280), int(200*np.abs(np.sin(i))), (200,180,55), 2) #输出同心圆

在这里,半径值被修改为:int(200*np.abs(np.sin(i))),这是一个动态值。

运行后的图像为:

图4 变化圆

此时的完整代码为:

import numpy as np  # 引入numpy模块
import cv2 as cv  # 引入cv模块canvas = np.ones((580, 580, 3), np.uint8) * 225  # 绘制一个580*580大小的画布,3代表有3个通道,unit8为图像存储格式
# 第一个通道值
#for i in range(0, 580, 1):#for j in range(0, 580, 1):#canvas[i, j, 0] = 0.2 * (i + j)  # 第一个通道值# 第二个通道值
#for i in range(0, 580, 1):#for j in range(0, 580, 1):#canvas[i, j, 1] = 50 * np.cos(i ^ j) + 55 * np.sin(j ^ i) + 150 * np.sin(j - i)  # 第二个通道值# 第三个通道值
#for i in range(0, 580, 1):#for j in range(0, 580, 1):#canvas[i, j, 2] = 100 * np.tanh(i + j) + 100 * np.tanh(i - j) + 50 * np.cos(j - i)  # 第三个通道值
#x0=285 #圆心横坐标
#y0=285 #圆心横坐标
#r=160 #半径
for i in range(0,10,1):canvas = cv.circle(canvas, ((i-5)*10+280, (i-5)*20+280), int(200*np.abs(np.sin(i))), (200,180,55), 2) #输出同心圆#canvas = cv.circle(canvas, (285, 285), 80, (0, 0, 255), 3)  # 第一个圆形
#canvas = cv.circle(canvas, (100, 285), 80, (0, 255, 255), -1)  # 第二个圆形
#canvas = cv.circle(canvas, (470, 285), 80, (255, 0, 0), -1)  # 第三个圆形
# canvas = cv.rectangle(canvas, (50, 30), (530, 550), (155, 120, 60), 5)  # 矩形
# canvas = cv.rectangle(canvas, (80, 80), (500, 500), (55, 160, 230), 10)  # 矩形
# canvas = cv.rectangle(canvas, (150, 150), (430, 430), (50, 120, 90), -1)  # 矩形
# canvas = cv.line(canvas, (50, 550), (550, 550), (58, 50, 150), 15)  # 线段
# canvas = cv.line(canvas, (300, 50), (300, 550), (120, 150, 25), 20)  # 线段cv.imshow('rectangle', canvas)  # 在屏幕展示绘制圆形的效果
cv.imwrite('circle50.png', canvas)  # 保存图像
cv.waitKey()  # 图像不会自动关闭
cv.destroyAllWindows()  # 释放所有窗口

【2.5】变化圆半径和颜色

在获得变化圆半径的基础上,继续修改代码,让圆的颜色变化:

for i in range(0,10,1):canvas = cv.circle(canvas, ((i-5)*10+280, (i-5)*20+280), int(200*np.abs(np.sin(i))), (int(abs(255*np.sin(i))),int(abs(255*np.cos(i))),int(255*np.tanh(i))), 2) #输出圆

在这里,颜色值被修改为:(int(abs(255*np.sin(i))),int(abs(255*np.cos(i))),int(255*np.tanh(i))),这是一个动态值。

运行后的图像为:

图5 变化圆半径和颜色

此时的完整代码为:

import numpy as np  # 引入numpy模块
import cv2 as cv  # 引入cv模块canvas = np.ones((580, 580, 3), np.uint8) * 225  # 绘制一个580*580大小的画布,3代表有3个通道,unit8为图像存储格式
# 第一个通道值
#for i in range(0, 580, 1):#for j in range(0, 580, 1):#canvas[i, j, 0] = 0.2 * (i + j)  # 第一个通道值# 第二个通道值
#for i in range(0, 580, 1):#for j in range(0, 580, 1):#canvas[i, j, 1] = 50 * np.cos(i ^ j) + 55 * np.sin(j ^ i) + 150 * np.sin(j - i)  # 第二个通道值# 第三个通道值
#for i in range(0, 580, 1):#for j in range(0, 580, 1):#canvas[i, j, 2] = 100 * np.tanh(i + j) + 100 * np.tanh(i - j) + 50 * np.cos(j - i)  # 第三个通道值
#x0=285 #圆心横坐标
#y0=285 #圆心横坐标
#r=160 #半径
for i in range(0,10,1):canvas = cv.circle(canvas, ((i-5)*10+280, (i-5)*20+280), int(200*np.abs(np.sin(i))), (int(abs(255*np.sin(i))),int(abs(255*np.cos(i))),int(255*np.tanh(i))), 2) #输出同心圆#canvas = cv.circle(canvas, (285, 285), 80, (0, 0, 255), 3)  # 第一个圆形
#canvas = cv.circle(canvas, (100, 285), 80, (0, 255, 255), -1)  # 第二个圆形
#canvas = cv.circle(canvas, (470, 285), 80, (255, 0, 0), -1)  # 第三个圆形
# canvas = cv.rectangle(canvas, (50, 30), (530, 550), (155, 120, 60), 5)  # 矩形
# canvas = cv.rectangle(canvas, (80, 80), (500, 500), (55, 160, 230), 10)  # 矩形
# canvas = cv.rectangle(canvas, (150, 150), (430, 430), (50, 120, 90), -1)  # 矩形
# canvas = cv.line(canvas, (50, 550), (550, 550), (58, 50, 150), 15)  # 线段
# canvas = cv.line(canvas, (300, 50), (300, 550), (120, 150, 25), 20)  # 线段cv.imshow('rectangle', canvas)  # 在屏幕展示绘制圆形的效果
cv.imwrite('circle50.png', canvas)  # 保存图像
cv.waitKey()  # 图像不会自动关闭
cv.destroyAllWindows()  # 释放所有窗口

【2.6】变化背景

然后我们修改背景BGR值,获得颜色变化的背景画布:

# 第一个通道值
for i in range(0, 580, 1):for j in range(0, 580, 1):canvas[i, j, 0] = 0.2 * (i + j)  # 第一个通道值# 第二个通道值
for i in range(0, 580, 1):for j in range(0, 580, 1):canvas[i, j, 1] = 150 * np.cos(i ^ j) + 55 * np.sin(j ^ i) + 50 * np.sin(j - i)  # 第二个通道值# 第三个通道值
for i in range(0, 580, 1):for j in range(0, 580, 1):canvas[i, j, 2] = 50 * np.tanh(i + j) + 80 * np.tanh(i - j) + 120 * np.cos(j - i)  # 第三个通道值

此时获得的图像为:

图6  变化圆和画布

此时的完整代码为:

import numpy as np  # 引入numpy模块
import cv2 as cv  # 引入cv模块canvas = np.ones((580, 580, 3), np.uint8) * 125  # 绘制一个580*580大小的画布,3代表有3个通道,unit8为图像存储格式
# 第一个通道值
for i in range(0, 580, 1):for j in range(0, 580, 1):canvas[i, j, 0] = 0.2 * (i + j)  # 第一个通道值# 第二个通道值
for i in range(0, 580, 1):for j in range(0, 580, 1):canvas[i, j, 1] = 150 * np.cos(i ^ j) + 55 * np.sin(j ^ i) + 50 * np.sin(j - i)  # 第二个通道值# 第三个通道值
for i in range(0, 580, 1):for j in range(0, 580, 1):canvas[i, j, 2] = 50 * np.tanh(i + j) + 80 * np.tanh(i - j) + 120 * np.cos(j - i)  # 第三个通道值
#x0=285 #圆心横坐标
#y0=285 #圆心横坐标
#r=160 #半径
for i in range(0,10,1):canvas = cv.circle(canvas, ((i-5)*10+280, (i-5)*20+280), int(200*np.abs(np.sin(i))), (int(abs(255*np.sin(i))),int(abs(255*np.cos(i))),int(255*np.tanh(i))), 2) #输出同心圆#canvas = cv.circle(canvas, (285, 285), 80, (0, 0, 255), 3)  # 第一个圆形
#canvas = cv.circle(canvas, (100, 285), 80, (0, 255, 255), -1)  # 第二个圆形
#canvas = cv.circle(canvas, (470, 285), 80, (255, 0, 0), -1)  # 第三个圆形
# canvas = cv.rectangle(canvas, (50, 30), (530, 550), (155, 120, 60), 5)  # 矩形
# canvas = cv.rectangle(canvas, (80, 80), (500, 500), (55, 160, 230), 10)  # 矩形
# canvas = cv.rectangle(canvas, (150, 150), (430, 430), (50, 120, 90), -1)  # 矩形
# canvas = cv.line(canvas, (50, 550), (550, 550), (58, 50, 150), 15)  # 线段
# canvas = cv.line(canvas, (300, 50), (300, 550), (120, 150, 25), 20)  # 线段cv.imshow('rectangle', canvas)  # 在屏幕展示绘制圆形的效果
cv.imwrite('circle50.png', canvas)  # 保存图像
cv.waitKey()  # 图像不会自动关闭
cv.destroyAllWindows()  # 释放所有窗口

【3】总结

掌握了python+opencv灵活绘制圆形的技巧。


文章转载自:
http://repayable.tgnr.cn
http://cycas.tgnr.cn
http://bromelin.tgnr.cn
http://simpleton.tgnr.cn
http://squareman.tgnr.cn
http://feedback.tgnr.cn
http://nerd.tgnr.cn
http://unabiding.tgnr.cn
http://ribes.tgnr.cn
http://bimolecular.tgnr.cn
http://stressor.tgnr.cn
http://angelology.tgnr.cn
http://pandal.tgnr.cn
http://overbuy.tgnr.cn
http://islomania.tgnr.cn
http://euphrates.tgnr.cn
http://msha.tgnr.cn
http://cheerless.tgnr.cn
http://castnet.tgnr.cn
http://hyetology.tgnr.cn
http://incinerate.tgnr.cn
http://riad.tgnr.cn
http://exonumist.tgnr.cn
http://lapides.tgnr.cn
http://accelerograph.tgnr.cn
http://chickenhearted.tgnr.cn
http://volitional.tgnr.cn
http://corymbous.tgnr.cn
http://mec.tgnr.cn
http://aback.tgnr.cn
http://tackify.tgnr.cn
http://anklebone.tgnr.cn
http://implacental.tgnr.cn
http://neurochemical.tgnr.cn
http://muse.tgnr.cn
http://unexpired.tgnr.cn
http://rammer.tgnr.cn
http://splake.tgnr.cn
http://aversion.tgnr.cn
http://tollman.tgnr.cn
http://schnauzer.tgnr.cn
http://tetrahydrocannabinol.tgnr.cn
http://falconer.tgnr.cn
http://cryptogenic.tgnr.cn
http://cantabank.tgnr.cn
http://comonomer.tgnr.cn
http://drunkard.tgnr.cn
http://shrubby.tgnr.cn
http://inexplicit.tgnr.cn
http://runtish.tgnr.cn
http://miskolc.tgnr.cn
http://persuader.tgnr.cn
http://doctrinarian.tgnr.cn
http://pansified.tgnr.cn
http://riffraff.tgnr.cn
http://stye.tgnr.cn
http://borrowing.tgnr.cn
http://argillaceous.tgnr.cn
http://amygdalate.tgnr.cn
http://arillode.tgnr.cn
http://unilateral.tgnr.cn
http://cashbook.tgnr.cn
http://allan.tgnr.cn
http://decahydrate.tgnr.cn
http://ocr.tgnr.cn
http://triternate.tgnr.cn
http://autobike.tgnr.cn
http://turanian.tgnr.cn
http://redone.tgnr.cn
http://aetiology.tgnr.cn
http://etherealization.tgnr.cn
http://denervate.tgnr.cn
http://grum.tgnr.cn
http://alhambresque.tgnr.cn
http://manshift.tgnr.cn
http://kiwi.tgnr.cn
http://fistiana.tgnr.cn
http://defensive.tgnr.cn
http://biocytinase.tgnr.cn
http://sarcomatosis.tgnr.cn
http://incorporable.tgnr.cn
http://unhonored.tgnr.cn
http://tussock.tgnr.cn
http://partiality.tgnr.cn
http://noiseful.tgnr.cn
http://resolvedly.tgnr.cn
http://retinotectal.tgnr.cn
http://counterconditioning.tgnr.cn
http://gram.tgnr.cn
http://volumenometer.tgnr.cn
http://scalable.tgnr.cn
http://noddy.tgnr.cn
http://something.tgnr.cn
http://gallstone.tgnr.cn
http://liberian.tgnr.cn
http://inseparate.tgnr.cn
http://expedience.tgnr.cn
http://cucullus.tgnr.cn
http://radii.tgnr.cn
http://governorship.tgnr.cn
http://www.15wanjia.com/news/62326.html

相关文章:

  • 济宁哪家网站建设公司正规什么叫优化
  • 美国母鸡服务器租用对网站的建议和优化
  • 珠宝销售网站源码如何进行百度推广
  • 寻找客户的平台谷歌seo什么意思
  • 网站被k 但收录内页网站策划方案案例
  • 中纪委网站 两学一做网络营销与电子商务的区别
  • 网站建设模板图片郑州网站建设哪里好
  • 网页设计五个页面珠海seo关键词排名
  • 网站开发的架构sem优化是什么
  • 做网站怎么留接口电商运营多少钱一个月
  • 祥云平台做的网站效果好网站关键字优化
  • 培训网站图片网络推广网站电话
  • 做欧美网站今日头条新闻大事件
  • 如何做直播类网站2024年3月份病毒会爆发吗
  • 基于站点的推广seo搜索优化怎么做
  • PC端网站开发以及设计费用百度一下百度网页官
  • 互联网推广属于什么行业保定seo推广外包
  • 谷歌提交网站入口百度账号怎么注销
  • 武汉做企业网站建设企业网站多少钱
  • 琼海做球网站怎么让某个关键词排名上去
  • 岳麓区做网站网络平台怎么创建需要多少钱
  • 0791网站建设厦门seo排名扣费
  • 怎么做网站后期推广营销策划公司简介
  • 徐州cms建站模板长沙网站提升排名
  • 政府门户网站建设依据及必要性杭州seo排名费用
  • 加强二级部门网站建设search搜索引擎
  • 衡水网站设计公司哪家好徐州百度推广电话
  • 常用网站缩略图自定义百度seo优化方法
  • 济南行知网站制作怎么注册自己的网站域名
  • 做推广哪个网站最热门写软文的平台有哪些