電子產(chǎn)業(yè)一站式賦能平臺

PCB聯(lián)盟網(wǎng)

搜索
查看: 87|回復(fù): 0
收起左側(cè)

MATLAB|制作圣誕節(jié)專屬頭像

[復(fù)制鏈接]

193

主題

193

帖子

1532

積分

三級會員

Rank: 3Rank: 3

積分
1532
跳轉(zhuǎn)到指定樓層
樓主
發(fā)表于 2023-12-22 21:49:00 | 只看該作者 |只看大圖 回帖獎勵 |倒序瀏覽 |閱讀模式
點擊上方藍(lán)字和“好玩的MATLAB”一起快樂玩耍吧!

好玩的matlab
帶你解鎖不一樣的matlab新玩法

今天介紹一下怎么利用Matlab制作圣誕節(jié)專屬頭像,喜歡此推文的小伙伴們記得點贊+關(guān)注+分享!【尊重作者勞動成果,轉(zhuǎn)載請注明推文鏈接和公眾號名】
效果圖




程序介紹
主界面
  • function addHatmFig = figure('units', 'pixels', 'position', [400 300 400 600], ...    'Numbertitle', 'off', 'menubar', 'none', 'resize', 'on', ...    'name', '公眾號:好玩的Matlab');axes('parent', mFig, 'position', [0 0 1 1], ...    'XLim', [0 400], ...    'YLim', [-200 400], ...    'NextPlot', 'add', ...    'YDir', 'reverse', ...    'XTick', [], ...    'YTick', [],...    'layer', 'bottom', ...    'Visible', 'on');[avatar, ~, ~] = imread('tx1.jpg');[decorImg, ~, alphaImg] = imread('./img/2.png');ImgResult=image([0 400], [0 400], avatar);添加帽子
  • hatPos = [200, 40];[n, m, ~] = size(decorImg);enlarge=0.08;DrawHatHdl = image([hatPos(1) - m* enlarge hatPos(1) + m* enlarge], ...    [hatPos(2) - n* enlarge hatPos(2) + n* enlarge], decorImg, 'AlphaData', alphaImg);DrawHatHdl.HitTest = 'on';鼠標(biāo)監(jiān)聽代碼
  • set(gcf,'WindowButtonDownFcn', @clickBoat);    function clickBoat(~, ~)        clickType = get(gcf, 'SelectionType');        XY = get(gca, 'CurrentPoint');        if strcmp(clickType, 'normal')            Y = XY(1, 2);            X = XY(1, 1);            set(DrawHatHdl, 'XData', [X - m* enlarge X + m* enlarge], 'YData', [Y - n* enlarge Y + n* enlarge]);        elseif strcmp(clickType, 'alt')            Y = XY(1, 2);            X = XY(1, 1);            enlarge=enlarge*1.1;            set(DrawHatHdl,  'XData', [X - m*enlarge X + m*enlarge], 'YData', [Y - n*enlarge Y + n*enlarge]);        end    endend
    操作方法:
  • 鼠標(biāo)右擊放大帽子
  • 鼠標(biāo)左擊移動帽子位置全部代碼
  • function addHatmFig = figure('units', 'pixels', 'position', [400 300 400 600], ...    'Numbertitle', 'off', 'menubar', 'none', 'resize', 'on', ...    'name', '公眾號:好玩的Matlab');axes('parent', mFig, 'position', [0 0 1 1], ...    'XLim', [0 400], ...    'YLim', [-200 400], ...    'NextPlot', 'add', ...    'YDir', 'reverse', ...    'XTick', [], ...    'YTick', [],...    'layer', 'bottom', ...    'Visible', 'on');[avatar, ~, ~] = imread('tx1.jpg');[decorImg, ~, alphaImg] = imread('./img/2.png');ImgResult=image([0 400], [0 400], avatar);hatPos = [200, 40];[n, m, ~] = size(decorImg);enlarge=0.08;DrawHatHdl = image([hatPos(1) - m* enlarge hatPos(1) + m* enlarge], ...    [hatPos(2) - n* enlarge hatPos(2) + n* enlarge], decorImg, 'AlphaData', alphaImg);DrawHatHdl.HitTest = 'on';
    set(gcf,'WindowButtonDownFcn', @clickBoat);    function clickBoat(~, ~)        clickType = get(gcf, 'SelectionType');        XY = get(gca, 'CurrentPoint');        if strcmp(clickType, 'normal')            Y = XY(1, 2);            X = XY(1, 1);            set(DrawHatHdl, 'XData', [X - m* enlarge X + m* enlarge], 'YData', [Y - n* enlarge Y + n* enlarge]);        elseif strcmp(clickType, 'alt')            Y = XY(1, 2);            X = XY(1, 1);            enlarge=enlarge*1.1;            set(DrawHatHdl,  'XData', [X - m*enlarge X + m*enlarge], 'YData', [Y - n*enlarge Y + n*enlarge]);        end    endend


    小編根據(jù)原理又做了APP操作界面


    - -THE END- -

    源碼下載:gitee下載:https://gitee.com/LoveMatlab/addHat


    QQ 群下載:


    參考資料:
    【1】https://slandarer.blog.csdn.net/article/details/118368777【2】https://mp.weixin.qq.com/s/mRIImZK-bLJWrZwVtkrhfw
  • 回復(fù)

    使用道具 舉報

    發(fā)表回復(fù)

    您需要登錄后才可以回帖 登錄 | 立即注冊

    本版積分規(guī)則


    聯(lián)系客服 關(guān)注微信 下載APP 返回頂部 返回列表