MATLAB 制作抖音同款含褶皱面料图

2024-01-08 13:48

本文主要是介绍MATLAB 制作抖音同款含褶皱面料图,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

效果如下:!!!
在这里插入图片描述
在这里插入图片描述

步骤
1.导入图片

我们需要导入一张褶皱图片(background.jpg)以及一张前景图片(foreground.jpg),将褶皱图片灰度化,将前景图调整至与褶皱图片相同大小:

bkgPic=imread('background.jpg');
bkgPic=rgb2gray(bkgPic);
forePic=imread('foreground.jpg');
forePic=imresize(forePic,size(bkgPic));

原图在这里:
在这里插入图片描述
在这里插入图片描述

2.图片扩张

因为我们要对前景图片进行拉伸,难免边角处缺一块,因此我们首先将边缘处颜色往外扩展几圈(13圈)

exforePic=uint8(zeros(size(forePic)+[26,26,0]));
exforePic(14:end-13,14:end-13,1)=forePic(:,:,1);
exforePic(14:end-13,14:end-13,2)=forePic(:,:,2);
exforePic(14:end-13,14:end-13,3)=forePic(:,:,3);for i=1:13exforePic(i,14:end-13,:)=forePic(1,:,:);exforePic(end+1-i,14:end-13,:)=forePic(end,:,:);exforePic(14:end-13,i,:)=forePic(:,1,:);exforePic(14:end-13,end+1-i,:)=forePic(:,end,:);
end
for i=1:3exforePic(1:13,1:13,i)=forePic(1,1,i);exforePic(end-13:end,end-13:end,i)=forePic(end,end,i);exforePic(end-13:end,1:13,i)=forePic(end,1,i);exforePic(1:13,end-13:end,i)=forePic(1,end,i);
end

扩展后图片(图片下侧明显一点):

在这里插入图片描述

3.像素映射

原理借鉴ps扭曲置换的原理,亮度较大的像素(大于128)取右下角像素RGB值进行置换,亮度较小的像素(小于128)取左上角像素RGB值进行置换,由于
(255-128)/10=12.7
(0-128)/10=-12.8
各个像素点与替换像素点的距离不超过13,因此上一步共扩展了13圈。
同时因为各个像素分布为整数点位置,而位置差计算一般都不是整数,因此我们要对偏移距离向上向下取整,获得两个像素点RGB值,并对这两点数值进行线性插值即可

newforePic=uint8(zeros(size(forePic)));
for i=1:size(bkgPic,1)for j=1:size(bkgPic,2)goffset=(double(bkgPic(i,j))-128)/10;offsetLim1=floor(goffset)+13;offsetLim2=ceil(goffset)+13;sep1=goffset-floor(goffset);sep2=ceil(goffset)-goffset;c1=double(exforePic(i+offsetLim1,j+offsetLim1,:));c2=double(exforePic(i+offsetLim2,j+offsetLim2,:));if sep1==0c=double(exforePic(i+offsetLim1,j+offsetLim1,:));elsec=c2.*sep1+c1.*sep2;endnewforePic(i,j,:)=c;end
end

像素值映射结果:
在这里插入图片描述

4.正片叠底

将两张图片叠加起来
公式:混合色×基色 / 255=结果色
由于正片叠底后所出图片较暗,这里我们选择除以220而不是255:

newforePic=uint8((double(newforePic).*double(bkgPic))./220);
imwrite(newforePic,'result.jpg')
imshow(newforePic)

在这里插入图片描述

5.完整代码
function clothFold
bkgPic=imread('background.jpg');
bkgPic=rgb2gray(bkgPic);
forePic=imread('foreground.jpg');
forePic=imresize(forePic,size(bkgPic));exforePic=uint8(zeros(size(forePic)+[26,26,0]));
exforePic(14:end-13,14:end-13,1)=forePic(:,:,1);
exforePic(14:end-13,14:end-13,2)=forePic(:,:,2);
exforePic(14:end-13,14:end-13,3)=forePic(:,:,3);for i=1:13exforePic(i,14:end-13,:)=forePic(1,:,:);exforePic(end+1-i,14:end-13,:)=forePic(end,:,:);exforePic(14:end-13,i,:)=forePic(:,1,:);exforePic(14:end-13,end+1-i,:)=forePic(:,end,:);
end
for i=1:3exforePic(1:13,1:13,i)=forePic(1,1,i);exforePic(end-13:end,end-13:end,i)=forePic(end,end,i);exforePic(end-13:end,1:13,i)=forePic(end,1,i);exforePic(1:13,end-13:end,i)=forePic(1,end,i);
endnewforePic=uint8(zeros(size(forePic)));
for i=1:size(bkgPic,1)for j=1:size(bkgPic,2)goffset=(double(bkgPic(i,j))-128)/10;offsetLim1=floor(goffset)+13;offsetLim2=ceil(goffset)+13;sep1=goffset-floor(goffset);sep2=ceil(goffset)-goffset;c1=double(exforePic(i+offsetLim1,j+offsetLim1,:));c2=double(exforePic(i+offsetLim2,j+offsetLim2,:));if sep1==0c=double(exforePic(i+offsetLim1,j+offsetLim1,:));elsec=c2.*sep1+c1.*sep2;endnewforePic(i,j,:)=c;end
end%grayForePic=rgb2gray(newforePic);
%rate=double(bkgPic)./double(grayForePic);newforePic=uint8((double(newforePic).*double(bkgPic))./220);
imwrite(newforePic,'result.jpg')
imshow(newforePic)
end

注:
若是17年及之前版本,需将代码最后的

newforePic=uint8((double(newforePic).*double(bkgPic))./220);

改为(三个通道分别处理):

newforePic(:,:,1)=uint8((double(newforePic(:,:,1)).*double(bkgPic))./220);
newforePic(:,:,2)=uint8((double(newforePic(:,:,2)).*double(bkgPic))./220);
newforePic(:,:,3)=uint8((double(newforePic(:,:,3)).*double(bkgPic))./220);

这篇关于MATLAB 制作抖音同款含褶皱面料图的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/583654

相关文章

用Unity2D制作一个人物,实现移动、跳起、人物静止和动起来时的动画:中(人物移动、跳起、静止动作)

上回我们学到创建一个地形和一个人物,今天我们实现一下人物实现移动和跳起,依次点击,我们准备创建一个C#文件 创建好我们点击进去,就会跳转到我们的Vision Studio,然后输入这些代码 using UnityEngine;public class Move : MonoBehaviour // 定义一个名为Move的类,继承自MonoBehaviour{private Rigidbo

matlab读取NC文件(含group)

matlab读取NC文件(含group): NC文件数据结构: 代码: % 打开 NetCDF 文件filename = 'your_file.nc'; % 替换为你的文件名% 使用 netcdf.open 函数打开文件ncid = netcdf.open(filename, 'NC_NOWRITE');% 查看文件中的组% 假设我们想读取名为 "group1" 的组groupName

利用matlab bar函数绘制较为复杂的柱状图,并在图中进行适当标注

示例代码和结果如下:小疑问:如何自动选择合适的坐标位置对柱状图的数值大小进行标注?😂 clear; close all;x = 1:3;aa=[28.6321521955954 26.2453660695847 21.69102348512086.93747104431360 6.25442246899816 3.342835958564245.51365061796319 4.87

C# double[] 和Matlab数组MWArray[]转换

C# double[] 转换成MWArray[], 直接赋值就行             MWNumericArray[] ma = new MWNumericArray[4];             double[] dT = new double[] { 0 };             double[] dT1 = new double[] { 0,2 };

libsvm在matlab中的使用方法

原文地址:libsvm在matlab中的使用方法 作者: lwenqu_8lbsk 前段时间,gyp326曾在论坛里问libsvm如何在matlab中使用,我还奇怪,认为libsvm是C的程序,应该不能。没想到今天又有人问道,难道matlab真的能运行libsvm。我到官方网站看了下,原来,真的提供了matlab的使用接口。 接口下载在: http://www.csie.ntu.edu.

OpenStack离线Train版安装系列—0制作yum源

本系列文章包含从OpenStack离线源制作到完成OpenStack安装的全部过程。 在本系列教程中使用的OpenStack的安装版本为第20个版本Train(简称T版本),2020年5月13日,OpenStack社区发布了第21个版本Ussuri(简称U版本)。 OpenStack部署系列文章 OpenStack Victoria版 安装部署系列教程 OpenStack Ussuri版

OpenStack镜像制作系列5—Linux镜像

本系列文章主要对如何制作OpenStack镜像的过程进行描述记录 CSDN:OpenStack镜像制作教程指导(全) OpenStack镜像制作系列1—环境准备 OpenStack镜像制作系列2—Windows7镜像 OpenStack镜像制作系列3—Windows10镜像 OpenStack镜像制作系列4—Windows Server2019镜像 OpenStack镜像制作

OpenStack镜像制作系列4—Windows Server2019镜像

本系列文章主要对如何制作OpenStack镜像的过程进行描述记录  CSDN:OpenStack镜像制作教程指导(全) OpenStack镜像制作系列1—环境准备 OpenStack镜像制作系列2—Windows7镜像 OpenStack镜像制作系列3—Windows10镜像 OpenStack镜像制作系列4—Windows Server2019镜像 OpenStack镜像制作系

OpenStack镜像制作系列2—Windows7镜像

本系列文章主要对如何制作OpenStack镜像的过程进行描述记录 CSDN:OpenStack镜像制作教程指导(全) OpenStack镜像制作系列1—环境准备 OpenStack镜像制作系列2—Windows7镜像 OpenStack镜像制作系列3—Windows10镜像 OpenStack镜像制作系列4—Windows Server2019镜像 OpenStack镜像制作系列

OpenStack镜像制作系列1—环境准备

本系列文章主要对如何制作OpenStack镜像的过程进行描述记录 CSDN:OpenStack镜像制作教程指导(全) OpenStack镜像制作系列1—环境准备 OpenStack镜像制作系列2—Windows7镜像 OpenStack镜像制作系列3—Windows10镜像 OpenStack镜像制作系列4—Windows Server2019镜像 OpenStack镜像制作