%%%% 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 滤镜算法原理——拼贴的更多相关文章

  1. PS 滤镜算法原理——照亮边缘

    这个算法原理很简单,对彩色图像的R,G,B 三个通道,分别求梯度,然后将梯度值作为三个通道的值. clc; clear all;Image=imread('4.jpg');Image=double(I ...

  2. PS 滤镜算法原理——染色玻璃

    %%%% 完成PS 中的染色玻璃滤镜特效 clc; clear all; close all; Image=imread('4.jpg'); Image=double(Image); Gray_Ima ...

  3. PS 滤镜算法原理——曝光过度

    这个算法的原理,就是将图像反相,然后分别比较原图与反相后的图三个通道的大小,将小的值输出. clc; clear all; Image=imread('4.jpg'); Image=double(Im ...

  4. PS 滤镜算法原理 ——马赛克

    % method : 利用邻域的随意一点取代当前邻域全部像素点 %%%% mosaic clc; clear all; addpath('E:\PhotoShop Algortihm\Image Pr ...

  5. PS 滤镜算法原理——碎片效果

    %%% Fragment %%% 对原图做四个方向的平移,然后对平移的结果取平均 %%% 碎片效果 clc; clear all; Image=imread('4.jpg'); Image=doubl ...

  6. PS 滤镜算法原理——高反差保留 (High Pass)

    这个特效简单来说,就是一个高通滤波器, 对图像做高斯滤波,用原图减去高斯滤波后的图,再将差值加上128. clc; clear all; close all; Image=imread('4.jpg' ...

  7. PS 滤镜算法原理——浮雕效果

    clc; clear all; Image=imread('4.jpg');Image=double(Image);p=3;  %% 控制浮雕的强度 %% 控制浮雕的方向 H=[0 0 p      ...

  8. PS 滤镜算法— — 表面模糊

    图像的表面模糊处理,其作用是在保留图像边缘的情况下,对图像的表面进行模糊处理.在对人物皮肤处理上,比高斯模糊更有效.因为高斯模糊在使人物皮肤光洁的同时,也将一些边缘特征如脸部的眉毛.嘴唇等给模糊了,不 ...

  9. OpenCV——PS 滤镜算法之极坐标变换到平面坐标

    // define head function #ifndef PS_ALGORITHM_H_INCLUDED #define PS_ALGORITHM_H_INCLUDED #include < ...

随机推荐

  1. Android Multimedia框架总结(六)C++中MediaPlayer的C/S架构

    转载请把头部出处链接和尾部二维码一起转载,本文出自: http://blog.csdn.net/hejjunlin/article/details/52435789 前面几节中,都是通过java层调用 ...

  2. Apache Beam—透视Google统一流式计算的野心

    Google是最早实践大数据的公司,目前大数据繁荣的生态很大一部分都要归功于Google最早的几篇论文,这几篇论文早就了以Hadoop为开端的整个开源大数据生态,但是很可惜的是Google内部的这些系 ...

  3. Gazebo機器人仿真學習探索筆記(五)環境模型

    環境模型構建可以通過向其中添加模型實現,待之後補充,比較有趣的是建築物模型, 可以編輯多層樓層和房間,加入樓梯,窗戶和牆壁等,具體可以參考附錄,等有空再補充. 起伏地形環境構建可以參考之前內容:在Ga ...

  4. 如何向android studio中导入第三方类库

    下面分两种情况介绍一下如何导入第三方类库. 1.对于jar的类库,直接复制进libs目录,然后把jar复制进去,然后File->Project Structure,然后选中主module的名称, ...

  5. [ExtJS5学习笔记]第七节 Extjs5的组件components及其模板事件方法学习

    本文地址:http://blog.csdn.net/sushengmiyan/article/details/38487519 本文作者:sushengmiyan ------------------ ...

  6. 剑指Offer——算法复杂度中的O(logN)底数是多少

    剑指Offer--算法复杂度中的O(logN)底数是多少 前言 无论是计算机算法概论.还是数据结构书中,关于算法的时间复杂度很多都用包含O(logN)这样的描述,但是却没有明确说logN的底数究竟是多 ...

  7. python 远程调度进程服务与客户端

    python 远程调度进程服务与客户端 核心思想: 在本地或远程机器上创建一个进程,提供调度服务.使用了 APScheduler. 安装:APScheduler $ wget https://pypi ...

  8. Cocos2D iOS之旅:如何写一个敲地鼠游戏(二):Cocos2D中的高清支持

    大熊猫猪·侯佩原创或翻译作品.欢迎转载,转载请注明出处. 如果觉得写的不好请告诉我,如果觉得不错请多多支持点赞.谢谢! hopy ;) 免责申明:本博客提供的所有翻译文章原稿均来自互联网,仅供学习交流 ...

  9. visual studio 2015使用python tools远程调试maya 2016

    步骤: 1. 去https://apps.exchange.autodesk.com/MAYA/en/Home/Index搜索Developer Kit并下载,maya 2016可以直接点击这里下载. ...

  10. (国内)完美下载android源代码(文章已经丢失)

    刚刚文章莫名其妙的丢了,我重写了一篇,http://blog.csdn.net/song19891121/article/details/50099857 我们在很多时候需要下载android源代码进 ...