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

c 网站开发简单实例深圳搜索引擎优化推广便宜

c 网站开发简单实例,深圳搜索引擎优化推广便宜,音乐网页设计模板html,中国建设银行官网首页登录入口一.边缘填充 一般来图片操作之后会有空区域,就是对空出来的区域进行了像素值的填充,(0,0,0)也就是黑色像素值的填充。 # 默认黑色填充 import cv2 as cvimg cv.imread(../images/lena.png) # 先让原图旋转45度 M cv.getRotatio…

一.边缘填充

        一般来图片操作之后会有空区域,就是对空出来的区域进行了像素值的填充,(0,0,0)也就是黑色像素值的填充。

# 默认黑色填充
import cv2 as cvimg = cv.imread('../images/lena.png')
# 先让原图旋转45度
M = cv.getRotationMatrix2D((img.shape[1]/2,img.shape[0]/2),45,0.5)f = cv.warpAffine(img,M,(img.shape[1],img.shape[0]))
cv.imshow('img',img)
cv.imshow('f',f)
cv.waitKey()
cv.destroyAllWindows()

1.1 边界复制

cv.BORDER_REPLICATE

其是warpAffine函数中borderMode参数其一,且边缘填充时必须声明borderMode参数

就是将缩放后图像的边缘元素复制给离它最近的空区域。

import cv2 as cvimg = cv.imread('../images/lena.png')
# 先让原图旋转45度
M = cv.getRotationMatrix2D((img.shape[1]/2,img.shape[0]/2),45,0.5)f = cv.warpAffine(img,M,(img.shape[1],img.shape[0]),borderMode=cv.BORDER_REPLICATE)
cv.imshow('img',img)
cv.imshow('f',f)
cv.waitKey()
cv.destroyAllWindows()

1.2 边界反射

cv.BORDER_REFLECT

根据原图的边缘进行反射。

就是取镜像翻转,对角的地方就按点翻转,其他地方按边。

import cv2 as cvimg = cv.imread('../images/lena.png')
# 先让原图旋转45度
M = cv.getRotationMatrix2D((img.shape[1]/2,img.shape[0]/2),45,0.5)f = cv.warpAffine(img,M,(img.shape[1],img.shape[0]),borderMode=cv.BORDER_REFLECT)
cv.imshow('img',img)
cv.imshow('f',f)
cv.waitKey()
cv.destroyAllWindows()

1.3 边界反射101

cv.BORDER_REFLECT_101

与边界反射不同的是,不再反射边缘的像素点:

1.4 边界常数

cv.BORDER_CONSTANT

指定常数值borderValue = (x,y,z)是多少,默认的填充常数值为0

import cv2 as cvimg = cv.imread('../images/lena.png')
# 先让原图旋转45度
M = cv.getRotationMatrix2D((img.shape[1]/2,img.shape[0]/2),45,0.5)f = cv.warpAffine(img,M,(img.shape[1],img.shape[0]),borderMode=cv.BORDER_CONSTANT,borderValue=(0,0,255))
cv.imshow('img',img)
cv.imshow('f',f)
cv.waitKey()
cv.destroyAllWindows()

1.5 边界包裹

cv.BORDER_WRAP

就是把图像一对一复制平移

import cv2 as cvimg = cv.imread('../images/lena.png')
# 先让原图旋转45度
M = cv.getRotationMatrix2D((img.shape[1]/2,img.shape[0]/2),45,0.5)f = cv.warpAffine(img,M,(img.shape[1],img.shape[0]),borderMode=cv.BORDER_WRAP)
cv.imshow('img',img)
cv.imshow('f',f)
cv.waitKey()
cv.destroyAllWindows()

二.图像矫正(透视变换)

        其原理是透视变换,有点像仿射变换,公式不太一样,它已经不是一个线性变换。通俗的讲,透视变换的作用其实就是改变一下图像里的目标物体的被观察的视角

可以看到,这是一个3*3的矩阵了,因为是将3维图像转为2维。

2.1 透视变换矩阵

M=getPerspectiveTransform(src,dst)

- src:原图像上需要进行透视变化的区域(四个点的坐标),一个二维数组

- dst:输出图像的四个新坐标(在原图中),一个二维数组。

那么怎么获取这8个坐标呢?介绍一个简单的方法,打开电脑中的画图软件:

        如图,把鼠标移到区域边缘上的四个点上就可以得到 w,h 的值。新坐标一般用原图边缘的坐标,直接可以用shape[0]shape[1]来获取 h,w,然后根据坐标系推算就有了。

2.2 透视变换函数

cv2.warpPerspective(src, M, dsize, flags, borderMode)

- src:输入图像。

- M:透视变换矩阵。

- dsize:输出图像的大小。它可以是一个Size对象,也可以是一个二元组。

- flags:插值方法的标记。

- borderMode:边界填充的模式。

import cv2 as cv
import numpy as np img = cv.imread('../images/3.png')
print(img.shape)# 这里拿到区域4点坐标分别为:左上182,113 右上500,151左下133.264右下490,308
# 由于图像中数据的类型为float32,所以得用np.float32创建数组
pts1 = np.float32([[182,113], [500,151],[133,264],[490,308]])
pts2 = np.float32([[0,0], [img.shape[1],0],[0, img.shape[0]],[img.shape[1], img.shape[0]]])# 来在我要透视变换的区域画个矩形(4条边)
# 这里用astype转为int是为了防止坐标值溢出
cv.line(img, pts1[0].astype(np.int64), pts1[1].astype(np.int64), (0, 255, 0), 2)
cv.line(img, pts1[1].astype(np.int64), pts1[3].astype(np.int64), (0, 255, 0), 2)
cv.line(img, pts1[2].astype(np.int64), pts1[3].astype(np.int64), (0, 255, 0), 2)
cv.line(img, pts1[2].astype(np.int64), pts1[0].astype(np.int64), (0, 255, 0), 2)# 拿到透视变换矩阵
M = cv.getPerspectiveTransform(pts1, pts2)# 进行透视变换后的图
ts_img = cv.warpPerspective(img, M, (img.shape[1], img.shape[0]))cv.imshow('img', img)
cv.imshow('ts_img', ts_img)
cv.waitKey(0)
cv.destroyAllWindows()

(477, 678, 3)

三.图像色彩空间转换

        OpenCV中,图像色彩空间转换是一个非常基础且重要的操作,就是将图像从一种颜色表示形式转换为另一种表示形式的过程。常见的颜色空间包括 RGB、HSV、YUV 等。

3.1 RGB颜色空间

        RGB颜色空间可以产生大约1600万种颜色,几乎包括了世界上的所有颜色,也就是说可以使用RGB颜色空间来生成任意一种颜色。

3.2 颜色加法

        使用OpenCVcv.add()函数把两幅图像相加,或者可以简单地通过numpy操作添加两个图像,如res = img1 + img2。

- OpenCV的加法是饱和操作(单纯数值相加,最大255),而Numpy添加是模运算

import cv2 as cv
import numpy as nppig = cv.imread('../images/pig.png')
cao = cv.imread('../images/cao.png')# add()
pig_cao_add = cv.add(pig, cao)# np
pig_cao_np = pig + caocv.imshow('pig_cao_add', pig_cao_add)
cv.imshow('pig_cao_np', pig_cao_np)
cv.waitKey(0)
cv.destroyAllWindows()

3.3 颜色加权加法

cv2.addWeighted(src1,alpha,src2,deta,gamma)

- alphabeta:两张图象权重。

- gamma:亮度调整值。

  > 0,图像会变亮

  < 0,图像会变暗。

  0,则没有额外的亮度调整。

import cv2 as cv
import numpy as nppig = cv.imread('../images/pig.png')
cao = cv.imread('../images/cao.png')su = cv.addWeighted(pig, 0.7, cao, 0.3, 0)
cv.imshow('su',su)
cv.waitKey()
cv.destroyAllWindows()

http://www.dtcms.com/wzjs/168194.html

相关文章:

  • 做男装海报的素材网站网络做推广公司
  • 西安网站优化百度超级链数字藏品
  • 手机端网站开发流程图全网营销推广方案外包
  • 福田做网站哪家专业网络营销推广实战宝典
  • dede网站头部不显示调用的名称seo网站关键词优化方式
  • 中企动力做的网站容易SEO吗网站竞价推广
  • 网站怎么做图片动态图片不显示如何制作小程序
  • 网站建设排名优化公司百度手机助手免费下载
  • 谷歌外贸建站河北百度推广
  • 18元套餐百度推广优化排名
  • 有趣的网站小游戏经典广告推广词
  • 南昌做网站哪家公司好百度推广客户端官方下载
  • 商业网站网站建设比较靠谱的推广平台
  • wordpress响应式成都seo工程师
  • 做熊猫tv网站的目的全网营销推广
  • 网站建设加班搜索引擎是软件还是网站
  • 做网站需要注意的问题移动网站如何优化排名
  • 公众号做视频网站会封吗品牌全案策划
  • 沈阳中小企业网站建设兰州网络优化seo
  • 那个网站的公众后推广做的好长沙seo网络公司
  • 河间市做网站嘉峪关seo
  • 网站图片上传不了是什么原因营销渠道有哪些
  • 怎么管理wordpress免费智能seo收录工具
  • wordpress 首页缩略图北京推广优化经理
  • 做导购网站如何获利拼多多代运营公司十大排名
  • 竞价单页网站策划设计制作关键词优化技巧有哪些
  • 怎么做网站图片的切换图怎么在百度发布个人简介
  • 安徽工程建设发展有限公司上海关键词优化排名软件
  • 车工订单网站云seo
  • 学网站设计和平面设计引擎优化是什么意思