矩阵扩展

为了方便对图像边界的处理,通常要把图像矩阵进行扩展。

原图:


代码:

fig = figure('NumberTitle', 'off', 'name', 'Happy');  
hold on;
  
LineWidth = 2;  
FontSize = 12;  
MarkerSize = 3;  
  
for i = 1 : 9  
    plot([i i], [-1 -9], 'k', 'LineWidth', LineWidth);  
    plot([1 9], [-i -i], 'k', 'LineWidth', LineWidth);  
end  

% 上下
for j = 3 : 8
    text(j-0.5, -1.5, ['U'  num2str(j-1)], 'FontSize', FontSize, 'FontWeight', 'bold', 'HorizontalAlignment', 'center');
    text(j-0.5, -8.5, ['D'  num2str(j-1)], 'FontSize', FontSize, 'FontWeight', 'bold', 'HorizontalAlignment', 'center');
end

% 左右
for i = 3 : 8
    text(1.5, -i+0.5, ['L'  num2str(i-1)], 'FontSize', FontSize, 'FontWeight', 'bold', 'HorizontalAlignment', 'center');
    text(8.5, -i+0.5, ['R'  num2str(i-1)], 'FontSize', FontSize, 'FontWeight', 'bold', 'HorizontalAlignment', 'center');
end

% 四角
text(1.5, -1.5, 'UL', 'FontSize', FontSize, 'FontWeight', 'bold', 'HorizontalAlignment', 'center');
text(8.5, -1.5, 'UR', 'FontSize', FontSize, 'FontWeight', 'bold', 'HorizontalAlignment', 'center');
text(1.5, -8.5, 'DL', 'FontSize', FontSize, 'FontWeight', 'bold', 'HorizontalAlignment', 'center');
text(8.5, -8.5, 'DR', 'FontSize', FontSize, 'FontWeight', 'bold', 'HorizontalAlignment', 'center');
  
axis equal;  
axis off;  
扩展图:

代码:

fig = figure('NumberTitle', 'off', 'name', 'Happy');  
hold on;
  
LineWidth = 2;  
FontSize = 12;  
MarkerSize = 3;  
  
for i = 0 : 10  
    plot([i i], [0 -10], 'k', 'LineWidth', LineWidth);  
    plot([0 10], [-i -i], 'k', 'LineWidth', LineWidth);  
end  

% 上下
for j = 3 : 8
    text(j-0.5, -0.5, ['U'  num2str(j-1)], 'FontSize', FontSize, 'FontWeight', 'bold', 'HorizontalAlignment', 'center');
    text(j-0.5, -1.5, ['U'  num2str(j-1)], 'FontSize', FontSize, 'FontWeight', 'bold', 'HorizontalAlignment', 'center');
    text(j-0.5, -8.5, ['D'  num2str(j-1)], 'FontSize', FontSize, 'FontWeight', 'bold', 'HorizontalAlignment', 'center');
    text(j-0.5, -9.5, ['D'  num2str(j-1)], 'FontSize', FontSize, 'FontWeight', 'bold', 'HorizontalAlignment', 'center');
end

% 左右
for i = 3 : 8
    text(0.5, -i+0.5, ['L'  num2str(i-1)], 'FontSize', FontSize, 'FontWeight', 'bold', 'HorizontalAlignment', 'center');
    text(1.5, -i+0.5, ['L'  num2str(i-1)], 'FontSize', FontSize, 'FontWeight', 'bold', 'HorizontalAlignment', 'center');
    text(8.5, -i+0.5, ['R'  num2str(i-1)], 'FontSize', FontSize, 'FontWeight', 'bold', 'HorizontalAlignment', 'center');
    text(9.5, -i+0.5, ['R'  num2str(i-1)], 'FontSize', FontSize, 'FontWeight', 'bold', 'HorizontalAlignment', 'center');
end

% 四角
for i = 1 : 2
    for j = 1 : 2
        text(j-0.5, -i+0.5, 'UL', 'FontSize', FontSize, 'FontWeight', 'bold', 'HorizontalAlignment', 'center');
        text(j+7.5, -i+0.5, 'UR', 'FontSize', FontSize, 'FontWeight', 'bold', 'HorizontalAlignment', 'center');
        text(j-0.5, -i-7.5, 'DL', 'FontSize', FontSize, 'FontWeight', 'bold', 'HorizontalAlignment', 'center');
        text(j+7.5, -i-7.5, 'DR', 'FontSize', FontSize, 'FontWeight', 'bold', 'HorizontalAlignment', 'center');
    end
end

% 框出原图
plot([1 9], [-1 -1], 'r', 'LineWidth', LineWidth+1);  
plot([9 9], [-1 -9], 'r', 'LineWidth', LineWidth+1);  
plot([9 1], [-9 -9], 'r', 'LineWidth', LineWidth+1);  
plot([1 1], [-9 -1], 'r', 'LineWidth', LineWidth+1);  

% 框出扩展方法
plot([0 10], [-2 -2], 'b', 'LineWidth', LineWidth+1);  
plot([0 10], [-8 -8], 'b', 'LineWidth', LineWidth+1);  
plot([2 2], [0 -10], 'b', 'LineWidth', LineWidth+1);  
plot([8 8], [0 -10], 'b', 'LineWidth', LineWidth+1);  
  
axis equal;  
axis off;  



  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值