主頁 >  其他 > UE 油畫濾鏡

UE 油畫濾鏡

2023-05-30 07:53:31 其他

前言

  • 非真實感渲染的風格不經相同,其中一種便是油畫風格,本文總結了如何實作油畫濾鏡的方法
    宮崎駿動漫場景油畫iPad壁紙 - tt98圖片網

Kuwahara Filter

  • 為什么使用Kuwahara Filter?

    一般對影像進行模糊處理,會使用低通濾波器,但往往模糊后影像會失去它們的硬邊,但Kuwahara Filter可以在平滑影像的同時也能保留其硬邊
    unreal engine paintimage-20230529185929298

  • 如何實作Kuwahara Filter?

    • Kuwahara Filter也是使用卷積,但不同之處是Kuwahara Filter需要四個卷積核
      unreal engine paint

    • 程序:計算每個卷積核的平均值(平滑噪點)方差(衡量一個內核的顏色變化率),一共四個,找出方差最小的卷積核并輸出其平均值

    • 例子
      unreal engine paint

      對于上圖的計算動圖如下
      unreal engine paint

      右邊的顏色變化率太大了,不會選它,這里選擇的是最左邊的卷積核,因為它的顏色最均勻,最后輸出它的平均值

實作油畫濾鏡

  • 根節點需要選擇"Material Domain"為"Post Process"
    image-20230529191334893

  • 總體實作框架
    image-20230529191315543

  • "Global"自定義節點計算平均值和方差

    方差計算公式unreal engine paint

    int32 SceneTextureLookup
    (
        int32 ViewportUV,		// 紋理坐標
        uint32 SceneTextureId,	// 節點sceneTexture中的Scene Texture Id索引值
        bool bFiltered	//是否使用雙線性插值
    )
    

    image-20230529191627854

  • 計算四個卷積核
    image-20230529203543123

  • 效果對比
    image-20230529191955806
    image-20230529191942119

實作方向性油畫濾鏡

  • 為什么需要方向性油畫濾鏡
    從上圖可以看出該濾鏡某些地方有點奇怪,某些地方過于方正,而方向性油畫濾鏡可以解決這個問題

  • 如何實作

    • 方向性油畫濾鏡和之前的差別在于它的卷積核和像素的區域朝向相同
      unreal engine paint

    • 計算區域朝向的方法是Sobel

      Sobel需要兩個卷積核,Gx提供水平方向的梯度資訊,Gy提供垂直方向的梯度資訊,使用這兩個卷積核分別對像素做一次卷積,再使用atan()求角度,隨后以該角度對卷積核進行旋轉
      unreal engine paint

    • 例子
      unreal engine paint

      對上圖進行Sobel,得到的結果如下
      unreal engine paint
      使用atan()求角度
      unreal engine paint

  • 具體實作

    • 求角度
      image-20230529200212596

    • 修改GetKernelMeanAndVariance()

      float4 GetKernelMeanAndVariance(float2 uv, float4 range, float2x2 rotationMatrix)
      {
          //...
          float2 offset = mul(float2(x, y) * textelSize, rotationMatrix);
      
      
    • 計算旋轉矩陣
      image-20230529200407948

    • 效果對比
      image-20230529191942119
      image-20230529200450006

源代碼

  • global

    float4 GetKernelMeanAndVariance(float2 uv, float4 range, float2x2 rotationMatrix)
    {
        float2 textelSize = View.ViewSizeAndInvSize.zw; //紋素大小
        const int ppInput0 = 14;    //對應SceneTexture的節點索引值
        float3 mean = 0;    //平均值
        float3 variance = 0;    //方差
        int sampleNums = 0;     //采樣次數
        
        for(int x = range.x; x <= range.y; ++x)
        {
            for(int y = range.z; y <= range.w; ++y)
            {
                float2 offset = mul(float2(x, y) * textelSize, rotationMatrix);
                float3 pixelColor = SceneTextureLookup(uv + offset, ppInput0, false).rgb;
    
                mean += pixelColor;
                variance = pixelColor * pixelColor;
                sampleNums++;
            }
        }
        mean /= sampleNums;
        variance = variance / sampleNums - mean * mean;
    
        float totalVariance = variance.r + variance.g + variance.b;
        return float4(mean.r, mean.g, mean.b, totalVariance);
    }
    
    // 求角度
    float4 GetAngle(float2 uv)
    {
        float2 textelSize = View.ViewSizeAndInvSize.zw; //紋素大小
        const int ppInput0 = 14;    //對應SceneTexture的節點索引值
    
        float gradientX = 0.f;  // 水平方向的梯度值
        float gradientY = 0.f;  // 豎直方向的梯度值
        float sobelX[9] = {-1, -2, -1, 0, 0, 0, 1, 2, 1};   // 水平方向的卷積核
        float sobelY[9] = {-1, 0, 1, -2, 0, 2, -1, 0, 1};   // 垂直方向的卷積核
        int i = 0;  //訪問sobel的索引
    
        for(int x = -1; x <= 1; ++x)
        {
            for(int y = -1; y <= 1; ++y)
            {
                float2 offset = float2(x, y) * textelSize;
                float3 pixelColor = SceneTextureLookup(uv + offset, ppInput0, false).rgb;
                float pixelValue = https://www.cnblogs.com/chenglixue/archive/2023/05/29/dot(pixelColor, float3(0.3,0.59,0.11));  // 轉化為灰度值,用于將影像看作一個整體計算梯度,比計算單個顏色值的梯度快
    
                // 計算梯度值
                gradientX += pixelValue * sobelX[i];
                gradientY += pixelValue * sobelY[i];
                i++;
            }
        }
    
        return atan(gradientY / gradientX);
    
    
  • Kuwahara

    const int ppInput0 = 14;
    float2 uv = GetDefaultSceneTextureUV(Parameters, ppInput0); //目標像素點
    float4 range;   //卷積核范圍.xy表示x的范圍,zw表示y的范圍
    float4 meanAndVariance[4];  //算得的平均值和方差
    
    float angle = GetAngle(uv);
    float2x2 rotationMatrix = float2x2(cos(angle), -sin(angle), sin(angle), cos(angle));
    
    // 計算四個卷積核
    range = float4(-RadiusX, 0, -RadiusY, 0);
    meanAndVariance[0] = GetKernelMeanAndVariance(uv, range, rotationMatrix);
    
    range = float4(-RadiusX, 0, 0, RadiusY);
    meanAndVariance[1] = GetKernelMeanAndVariance(uv, range, rotationMatrix);
    
    range = float4(0, RadiusX, 0, RadiusY);
    meanAndVariance[2] = GetKernelMeanAndVariance(uv, range, rotationMatrix);
    
    range = float4(0, RadiusX, -RadiusY, 0);
    meanAndVariance[3] = GetKernelMeanAndVariance(uv, range, rotationMatrix);
    
    // 求方差最小值的顏色
    float3 finalColor = meanAndVariance[0].rgb;
    float minVariance = meanAndVariance[0].a;
    
    for(int i = 1; i < 4; ++i)
    {
        if(minVariance > meanAndVariance[i].a)
        {
            minVariance = meanAndVariance[i].a;
            finalColor = meanAndVariance[i].rgb;
        }
    }
    
    return finalColor;
    
    

reference

UE4卡通渲染基礎教程 Part4:Paint Filter - 知乎 (zhihu.com)

Unreal Engine 4 Paint Filter Tutorial | Kodeco

轉載請註明出處,本文鏈接:https://www.uj5u.com/qita/553769.html

標籤:其他

上一篇:云原生周刊:使用 ChatGPT 提高安全性

下一篇:返回列表

標籤雲
其他(159961) Python(38185) JavaScript(25462) Java(18151) C(15233) 區塊鏈(8268) C#(7972) AI(7469) 爪哇(7425) MySQL(7215) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5873) 数组(5741) R(5409) Linux(5344) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4578) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2434) ASP.NET(2403) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) .NET技术(1977) 功能(1967) Web開發(1951) HtmlCss(1949) C++(1926) python-3.x(1918) 弹簧靴(1913) xml(1889) PostgreSQL(1878) .NETCore(1862) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • 網閘典型架構簡述

    網閘架構一般分為兩種:三主機的三系統架構網閘和雙主機的2+1架構網閘。 三主機架構分別為內端機、外端機和仲裁機。三機無論從軟體和硬體上均各自獨立。首先從硬體上來看,三機都用各自獨立的主板、記憶體及存盤設備。從軟體上來看,三機有各自獨立的作業系統。這樣能達到完全的三機獨立。對于“2+1”系統,“2”分為 ......

    uj5u.com 2020-09-10 02:00:44 more
  • 如何從xshell上傳檔案到centos linux虛擬機里

    如何從xshell上傳檔案到centos linux虛擬機里及:虛擬機CentOs下執行 yum -y install lrzsz命令,出現錯誤:鏡像無法找到軟體包 前言 一、安裝lrzsz步驟 二、上傳檔案 三、遇到的問題及解決方案 總結 前言 提示:其實很簡單,往虛擬機上安裝一個上傳檔案的工具 ......

    uj5u.com 2020-09-10 02:00:47 more
  • 一、SQLMAP入門

    一、SQLMAP入門 1、判斷是否存在注入 sqlmap.py -u 網址/id=1 id=1不可缺少。當注入點后面的引數大于兩個時。需要加雙引號, sqlmap.py -u "網址/id=1&uid=1" 2、判斷文本中的請求是否存在注入 從文本中加載http請求,SQLMAP可以從一個文本檔案中 ......

    uj5u.com 2020-09-10 02:00:50 more
  • Metasploit 簡單使用教程

    metasploit 簡單使用教程 浩先生, 2020-08-28 16:18:25 分類專欄: kail 網路安全 linux 文章標簽: linux資訊安全 編輯 著作權 metasploit 使用教程 前言 一、Metasploit是什么? 二、準備作業 三、具體步驟 前言 Msfconsole ......

    uj5u.com 2020-09-10 02:00:53 more
  • 游戲逆向之驅動層與用戶層通訊

    驅動層代碼: #pragma once #include <ntifs.h> #define add_code CTL_CODE(FILE_DEVICE_UNKNOWN,0x800,METHOD_BUFFERED,FILE_ANY_ACCESS) /* 更多游戲逆向視頻www.yxfzedu.com ......

    uj5u.com 2020-09-10 02:00:56 more
  • 北斗電力時鐘(北斗授時服務器)讓網路資料更精準

    北斗電力時鐘(北斗授時服務器)讓網路資料更精準 北斗電力時鐘(北斗授時服務器)讓網路資料更精準 京準電子科技官微——ahjzsz 近幾年,資訊技術的得了快速發展,互聯網在逐漸普及,其在人們生活和生產中都得到了廣泛應用,并且取得了不錯的應用效果。計算機網路資訊在電力系統中的應用,一方面使電力系統的運行 ......

    uj5u.com 2020-09-10 02:01:03 more
  • 【CTF】CTFHub 技能樹 彩蛋 writeup

    ?碎碎念 CTFHub:https://www.ctfhub.com/ 筆者入門CTF時時剛開始刷的是bugku的舊平臺,后來才有了CTFHub。 感覺不論是網頁UI設計,還是題目質量,賽事跟蹤,工具軟體都做得很不錯。 而且因為獨到的金幣制度的確讓人有一種想去刷題賺金幣的感覺。 個人還是非常喜歡這個 ......

    uj5u.com 2020-09-10 02:04:05 more
  • 02windows基礎操作

    我學到了一下幾點 Windows系統目錄結構與滲透的作用 常見Windows的服務詳解 Windows埠詳解 常用的Windows注冊表詳解 hacker DOS命令詳解(net user / type /md /rd/ dir /cd /net use copy、批處理 等) 利用dos命令制作 ......

    uj5u.com 2020-09-10 02:04:18 more
  • 03.Linux基礎操作

    我學到了以下幾點 01Linux系統介紹02系統安裝,密碼啊破解03Linux常用命令04LAMP 01LINUX windows: win03 8 12 16 19 配置不繁瑣 Linux:redhat,centos(紅帽社區版),Ubuntu server,suse unix:金融機構,證券,銀 ......

    uj5u.com 2020-09-10 02:04:30 more
  • 05HTML

    01HTML介紹 02頭部標簽講解03基礎標簽講解04表單標簽講解 HTML前段語言 js1.了解代碼2.根據代碼 懂得挖掘漏洞 (POST注入/XSS漏洞上傳)3.黑帽seo 白帽seo 客戶網站被黑帽植入劫持代碼如何處理4.熟悉html表單 <html><head><title>TDK標題,描述 ......

    uj5u.com 2020-09-10 02:04:36 more
最新发布
  • UE 油畫濾鏡

    # 前言 - 非真實感渲染的風格不經相同,其中一種便是油畫風格,本文總結了如何實作油畫濾鏡的方法 ![宮崎駿動漫場景油畫iPad壁紙 - tt98圖片網](https://img2023.cnblogs.com/blog/2487253/202305/2487253-2023052920372475 ......

    uj5u.com 2023-05-30 07:53:31 more
  • 云原生周刊:使用 ChatGPT 提高安全性

    雖然 ChatGPT 最近因網路犯罪分子使用該技術加強攻擊而成為負面新聞,但它也可以成為網路防御的強大資產,幫助公司最大限度地提高安全態勢,同時彌合其員工的技能差距。 云安全聯盟 (CSA) 最近發布了一份白皮書,詳細研究了 ChatGPT 的攻防潛力。CSA 技術研究總監Sean Heide是該論 ......

    uj5u.com 2023-05-30 07:53:11 more
  • 2.1. 類與物件

    在 Java 中,類和物件是面向物件編程的基本構建塊。類是一種模板,用于定義物件的屬性和行為。物件是類的實體,具有類定義的屬性和行為。 #### 2.1.1. 類的定義 要定義一個類,可以使用以下語法: ```java class ClassName { // 成員變數(屬性) // 成員方法(行為 ......

    uj5u.com 2023-05-30 07:53:04 more
  • GPT虛擬直播Demo系列(二)|無人直播間實作虛擬人回復粉絲

    虛擬人和數字人是人工智能技術在現實生活中的具體應用,它們可以為人們的生活和作業帶來便利和創新。在直播間場景里,虛擬人和數字人可用于直播主播、智能客服、營銷推廣等。接入GPT的虛擬人像是加了超強buff,具備更強大的自然語言處理能力和智能對話能力,可以實作更加智能化、自然化的人機互動。
    - 直播主播:... ......

    uj5u.com 2023-05-30 07:52:58 more
  • 揭秘“AI換臉”詐騙背后,黑灰產使用的手段

    ![image](https://img2023.cnblogs.com/blog/1520018/202305/1520018-20230529164725586-844276157.gif) 近日,警方通報了一起使用智能AI技術進行電信詐騙的案件。被騙者是福州市某科技公司法人代表郭先生,他通過微 ......

    uj5u.com 2023-05-30 07:52:46 more
  • AI實戰營環境配置-快速安裝

    # AI實戰營環境配置-快速安裝 [toc] ## 📕前言 介紹如何快速配置實戰營實戰專案的所依賴環境,分本地配置和服務器配置。 ## 🔧本地配置環境 ### mmpretrain - github:https://github.com/open-mmlab/mmpretrain - 快速安裝: ......

    uj5u.com 2023-05-30 07:52:33 more
  • 面對AI時代潮流,測驗人應該如何應對?

    首先一定要知道AI相關知識,測驗人員需要了解AI的基本概念、機器學習演算法和資料科學等方面的知識,這有助于更好地理解和測驗AI系統。同時測驗人員需要了解和掌握AI測驗工具,包括自動化測驗工具、模型評估工具和資料生成工具等。 ......

    uj5u.com 2023-05-30 07:52:21 more
  • 功能測驗面試沒人要了!軟體自動化測驗如何入門?

    對于我來說,我做的是web端的測驗,做測驗也有好幾個年頭了,每次都是使用手工測驗的話,一直是做重復性的作業,既枯燥又繁瑣,所以我在兩年前自己使用java語言寫了一系列的自動化測驗腳本,利用的框架是java+testng+reportng+selenium,這個框架在專案中基本可用了。
    在這里我談談我... ......

    uj5u.com 2023-05-30 07:52:01 more
  • Mybatis Generator 配置詳解

    因原版觀感不佳,搬運至此。 作者:Jimin 鏈接:https://www.imooc.com/article/21444 來源:慕課網 <?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE generatorConfiguration PUBLIC "- ......

    uj5u.com 2023-05-30 07:51:48 more
  • Mybatis Generator 配置詳解

    因原版觀感不佳,搬運至此。 作者:Jimin 鏈接:https://www.imooc.com/article/21444 來源:慕課網 <?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE generatorConfiguration PUBLIC "- ......

    uj5u.com 2023-05-30 07:51:31 more