PS 滤镜算法原理——拼贴
%%%% Tile
%%%%% 实现拼贴效果
%%%%% 将原图像进行分块,然后让图像块在
%%%%% 新图像范围内进行随机移动,确定移动后的边界
%%%%% 将移动后的图像块填入新图像内
clc;
clear all;
close all;
Image=imread('4.jpg');
Image1=double(Image);
Image2=Image1;
Image2(:,:,1)=0;
Image2(:,:,2)=0;
Image2(:,:,3)=0;
%%%% 块数 (1-99)
N=8;
%%%% 错开距离的最大百分比(0.01-0.99)
Percent=0.25;
Size_Info=size(Image);
%%% 确定图像的长和宽
Height=Size_Info(1);
Width=Size_Info(2);
%%% 确定图像的分块大小,及错开的最大距离
Min_value=min(Width,Height);
Block_size=floor(Min_value/N);
Rand_Dist=max(Block_size*Percent,2);
%%% 确定图像在长和宽方向的块数
N_row=floor(Height/Block_size);
N_col=floor(Width/Block_size);
Block_height=0;
Block_width=0;
%%% 图像如果在长或宽方向有多余的,统计在内
if(N_row*Block_size<Height)
Block_height=(Height-Block_size*N_row)/2;
N_row=N_row+1;
end
if(N_col*Block_size<Width)
Block_width=(Width-Block_size*N_col)/2;
N_col=N_col+1;
end
First_value=(Block_size+1)/2;
%%% 图像块原始坐标
Row_coordinate_origin(1:N_row)=0;
Col_coordinate_origin(1:N_col)=0;
for i=1:N_row-1;
Row_coordinate_origin(i)=round(First_value+(i-1)*Block_size);
end
Row_coordinate_origin(N_row)=round((Height+(N_row-1)*Block_size)/2);
for i=1:N_col-1
Col_coordinate_origin(i)=round(First_value+(i-1)*Block_size);
end
Col_coordinate_origin(N_col)=round((Width+(N_col-1)*Block_size)/2);
%%% 图像块的错开后的坐标
Row_coordinate(1:N_row,1:N_col)=0;
Col_coordinate(1:N_row,1:N_col)=0;
for i=1:N_row;
for j=1:N_col
Row_coordinate(i,j)=Row_coordinate_origin(i)+floor(Rand_Dist*2*(rand()-0.5));
end
end
for i=1:N_row
for j=1:N_col
Col_coordinate(i,j)=Col_coordinate_origin(j)+floor(Rand_Dist*2*(rand()-0.5));
end
end
%%% 对图像进行拼贴处理
Block_half=(Block_size-1)/2;
for i=1:N_row
for j=1:N_col
%%% 首先确定错开后的坐标没有越界
if(Row_coordinate(i,j)>Height || Col_coordinate(i,j)>Width)
continue;
end
%%% 将图像块分成四部分,从图像的中心向四条边进行搜索
%%% 计算图像块四个方向的边界
%%% 计算图像块上边界
if(Row_coordinate(i,j)-Block_half<1)
Block_h_down=Row_coordinate(i,j)-1;
row_down=1;
row_down_origin=Row_coordinate_origin(i)-Block_h_down;
else
row_down=round(Row_coordinate(i,j)-Block_half);
row_down_origin=round(Row_coordinate_origin(i)-Block_half);
end
%%% 计算图像块的下边界
if(Row_coordinate(i,j)+Block_half>Height)
Block_h_up=Height-Row_coordinate(i,j);
row_up=Height;
row_up_origin=Row_coordinate_origin(i)+Block_h_up;
else
row_up=round(Row_coordinate(i,j)+Block_half);
row_up_origin=round(Row_coordinate_origin(i)+Block_half);
end
%%% 如果最下面的图像块比标准的要小,单独计算
%%% 多出的一部分的下边界
if(i==N_row && Block_height~=0)
if(Row_coordinate(i,j)+Block_height>Height)
Block_h_up=Height-Row_coordinate(i,j);
row_up=Height;
row_up_origin=Row_coordinate_origin(i)+Block_h_up;
else
row_up=floor(Row_coordinate(i,j)+Block_height);
row_up_origin=floor(Row_coordinate_origin(i)+Block_height);
end
end
%%% 计算图像的左边界
if(Col_coordinate(i,j)-Block_half<1)
Block_w_down=Col_coordinate(i,j)-1;
col_down=1;
col_down_origin=Col_coordinate_origin(j)-Block_w_down;
else
col_down=round(Col_coordinate(i,j)-Block_half);
col_down_origin=round(Col_coordinate_origin(j)-Block_half);
end
%%计算图像的右边界
if(Col_coordinate(i,j)+Block_half>Width)
Block_w_up=Width-Col_coordinate(i,j);
col_up=Width;
col_up_origin=Col_coordinate_origin(j)+Block_w_up;
else
col_up=round(Col_coordinate(i,j)+Block_half);
col_up_origin=round(Col_coordinate_origin(j)+Block_half);
end
%%% 如果最右边的图像块比标准的要小,单独计算
%%% 多出的一部分的右边界
if(j==N_col && Block_width~=0)
if(Col_coordinate(i,j)+Block_width>Width)
Block_w_up=Width-Col_coordinate(i,j);
col_up=Width;
col_up_origin=Col_coordinate_origin(j)+Block_w_up;
else
col_up=floor(Col_coordinate(i,j)+Block_width);
col_up_origin=floor(Col_coordinate_origin(j)+Block_width);
end
end
Image2(row_down:row_up,col_down:col_up,:) = ...
Image(row_down_origin:row_up_origin,col_down_origin:col_up_origin,:);
end
end
imshow(Image2/255);
原图:
效果图:
PS 滤镜算法原理——拼贴的更多相关文章
- PS 滤镜算法原理——照亮边缘
这个算法原理很简单,对彩色图像的R,G,B 三个通道,分别求梯度,然后将梯度值作为三个通道的值. clc; clear all;Image=imread('4.jpg');Image=double(I ...
- PS 滤镜算法原理——染色玻璃
%%%% 完成PS 中的染色玻璃滤镜特效 clc; clear all; close all; Image=imread('4.jpg'); Image=double(Image); Gray_Ima ...
- PS 滤镜算法原理——曝光过度
这个算法的原理,就是将图像反相,然后分别比较原图与反相后的图三个通道的大小,将小的值输出. clc; clear all; Image=imread('4.jpg'); Image=double(Im ...
- PS 滤镜算法原理 ——马赛克
% method : 利用邻域的随意一点取代当前邻域全部像素点 %%%% mosaic clc; clear all; addpath('E:\PhotoShop Algortihm\Image Pr ...
- PS 滤镜算法原理——碎片效果
%%% Fragment %%% 对原图做四个方向的平移,然后对平移的结果取平均 %%% 碎片效果 clc; clear all; Image=imread('4.jpg'); Image=doubl ...
- PS 滤镜算法原理——高反差保留 (High Pass)
这个特效简单来说,就是一个高通滤波器, 对图像做高斯滤波,用原图减去高斯滤波后的图,再将差值加上128. clc; clear all; close all; Image=imread('4.jpg' ...
- PS 滤镜算法原理——浮雕效果
clc; clear all; Image=imread('4.jpg');Image=double(Image);p=3; %% 控制浮雕的强度 %% 控制浮雕的方向 H=[0 0 p ...
- PS 滤镜算法— — 表面模糊
图像的表面模糊处理,其作用是在保留图像边缘的情况下,对图像的表面进行模糊处理.在对人物皮肤处理上,比高斯模糊更有效.因为高斯模糊在使人物皮肤光洁的同时,也将一些边缘特征如脸部的眉毛.嘴唇等给模糊了,不 ...
- OpenCV——PS 滤镜算法之极坐标变换到平面坐标
// define head function #ifndef PS_ALGORITHM_H_INCLUDED #define PS_ALGORITHM_H_INCLUDED #include < ...
随机推荐
- Spring配置优化_构造器注入+自动装配
2014-05-16 09:01:08上课内容: 依赖注入的第二种注入方式:构造器注入 创建带参数的构造方法,参数类型为注入类的类型 项目要先添加Spring支持: package com; publ ...
- iOS开发之字数不一的多标签Demo
有朋友让帮他写一个封装的字数不一的多标签视图,所以今天将代码展示一下,供大家学习 代码中封装了两种方法,分别是:1.传递数组,数组中是NSString类型的方法:2.传递数组,数组中是NSDictio ...
- (一一三)使用系统自带框架操作SQLite3数据库
系统自带的框架是基于C语言的,使用比较繁琐. 下面是使用步骤: 首先导入libsqlite3.0.dylib. ①在Document目录下打开数据库,如果没有则创建. NSString *sqlite ...
- ajax post请求request.getParameter("")取值为null
今天在写提交一个json数据到后台,然后后台返回一个json数据类型.但是发现后台通过request.getParamter("")取到的值为null. 于是写一个简单的ajax ...
- Scipy教程 - 优化和拟合库scipy.optimize
http://blog.csdn.net/pipisorry/article/details/51106570 最优化函数库Optimization 优化是找到最小值或等式的数值解的问题.scipy. ...
- JAVA之旅(二十七)——字节流的缓冲区,拷贝mp3,自定义字节流缓冲区,读取键盘录入,转换流InputStreamReader,写入转换流,流操作的规律
JAVA之旅(二十七)--字节流的缓冲区,拷贝mp3,自定义字节流缓冲区,读取键盘录入,转换流InputStreamReader,写入转换流,流操作的规律 我们继续来聊聊I/O 一.字节流的缓冲区 这 ...
- 最简单的基于FFmpeg的内存读写的例子:内存转码器
===================================================== 最简单的基于FFmpeg的内存读写的例子系列文章列表: 最简单的基于FFmpeg的内存读写的 ...
- 华为解锁BL
华为手机要怎么查看手机是否需要解锁呢?相信许多机油都不懂自己入手的手机是否需要解锁.而华为手机自华为C8812之后的高通手机均需要先解锁才能够尽兴刷机或获取Root权限的.那么下面我给大家分享一下华为 ...
- Libgdx 1.5.4发布,跨平台游戏开发框架
(原文链接:http://www.libgdx.cn/topic/70/libgdx-1-5-4%E5%8F%91%E5%B8%83) [1.5.4] 添加对Titled maps 的图像层的支持. ...
- Dynamics crm2013 IFD部署后启用多组织
对CRM的多组织都不会陌生,在常规模式下新建组织后更改下url后面的组织名称即可访问新的组织了,而在部署IFD后就需要注意两点:1.域名的DNS解析:2.relying patry trust的更新 ...