V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
exmorning
V2EX  ›  分享发现

给 NBA 球星杜兰特的女神寡姐画上 Thug-Life 特效

  •  
  •   exmorning · 2020-08-11 14:57:46 +08:00 · 2591 次点击
    这是一个创建于 1557 天前的主题,其中的信息可能已经有所发展或是发生改变。

    Thug Life 是个什么梗?

    HIPHOP 亚文化的一种,可以把它理解成“屌炸天”的意思

    给大佬们加 Thug Life 特效,装逼效果满分:

    悔创阿里杰克马

    一无所有王健林

    不知妻美刘强东

    Thug Life APP

    在 Google Play 找了一个 Thug Life App 查了下数据,总下载量 500W+,月下载量 30W,相当不错

    Google Play 地址

    https://play.google.com/store/apps/details?id=thug.life.photo.sticker.maker

    实现

    下面有请寡姐,我们给寡姐画上 Thug Life

    demo

    TengineKit

    免费移动端实时人脸 212 关键点 SDK 。是一个易于集成的人脸检测和人脸关键点 SDK 。它可以在各种手机上以非常低的延迟运行。
    https://github.com/OAID/TengineKit

    TengineKit 效果图

    demo1

    配置 Gradle

    Project 中的 build.gradle 添加

        repositories {
            ...
            mavenCentral()
            ...
        }
    
        allprojects {
            repositories {
                ...
                mavenCentral()
                ...
            }
        }
    

    主 Module 中的 build.gradle 添加

        dependencies {
            ...
            implementation 'com.tengine.android:tenginekit:1.0.5'
            ...
        }
    

    配置 manifests

        <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
        <uses-permission android:name="android.permission.INTERNET"/>
    
        <uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE"/>
        <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>
        <uses-permission android:name="android.permission.READ_PHONE_STATE"/>
    

    处理图片

    首先我们先初始化 TengineKit:

    1. 选用 normal 处理模式
    2. 打开人脸检测和人脸关键点功能
    3. 设置图片流格式为 RGBA
    4. 设置输入图片流的宽高,此处为图片的真实宽高
    5. 设置输出图片流的宽高,此处也是图片的真实宽高
        com.tenginekit.Face.init(getBaseContext(),
                AndroidConfig.create()
                        .setNormalMode()
                        .openFunc(AndroidConfig.Func.Detect)
                        .openFunc(AndroidConfig.Func.Landmark)
                        .setInputImageFormat(AndroidConfig.ImageFormat.RGBA)
                        .setInputImageSize(
                                showImage.getDrawable().getIntrinsicWidth(),
                                showImage.getDrawable().getIntrinsicHeight()
                        ).setOutputImageSize(
                                showImage.getDrawable().getIntrinsicWidth(),
                                showImage.getDrawable().getIntrinsicHeight()
                        )
        );
    

    通过关键点得眼睛的中心点,嘴巴的点,下巴的点

        Point getLeftEyeCenter(FaceLandmarkInfo fi){
            FaceLandmarkPoint p1 = fi.landmarks.get(105);
            FaceLandmarkPoint p2 = fi.landmarks.get(113);
            return new Point((int)((p1.X + p2.X) / 2), (int)((p1.Y + p2.Y) / 2));
        }
    
        Point getRightEyeCenter(FaceLandmarkInfo fi){
            FaceLandmarkPoint p1 = fi.landmarks.get(121);
            FaceLandmarkPoint p2 = fi.landmarks.get(129);
            return new Point((int)((p1.X + p2.X) / 2), (int)((p1.Y + p2.Y) / 2));
        }
    
        Point getMouthCenter(FaceLandmarkInfo fi){
            FaceLandmarkPoint p1 = fi.landmarks.get(208);
            return new Point((int)p1.X, (int)p1.Y);
        }
    
        Point getChinPoint(FaceLandmarkInfo fi){
            FaceLandmarkPoint p1 = fi.landmarks.get(53);
            return new Point((int)p1.X, (int)p1.Y);
        }
    

    渲染

        Face.FaceDetect faceDetect = com.tenginekit.Face.detect(girl);
        if(faceDetect.getFaceCount() > 0){
            faceLandmarks = faceDetect.landmark2d();
            if(faceLandmarks != null){
                for(int i = 0; i < faceLandmarks.size(); i++){
                    Point leftEye = getLeftEyeCenter(faceLandmarks.get(i));
                    Point rightEye = getRightEyeCenter(faceLandmarks.get(i));
                    Point centerEye = new Point(
                            (leftEye.x + rightEye.x)/2,
                            (leftEye.y + rightEye.y)/2
                            );
                    canvas.drawBitmap(
                            b_glasses,
                            centerEye.x - b_glasses.getWidth() / 2,
                            centerEye.y - b_glasses.getHeight() / 2,
                            null);
    
                    Point mouthCenter = getMouthCenter(faceLandmarks.get(i));
                    canvas.drawBitmap(
                            b_cigaret,
                            mouthCenter.x - b_cigaret.getWidth(),
                            mouthCenter.y,
                            null);
    
                    Point thin = getChinPoint(faceLandmarks.get(i));
                    canvas.drawBitmap(
                            b_decorate,
                            thin.x - b_decorate.getWidth() / 2,
                            thin.y + b_decorate.getHeight() / 3,
                            null);
                }
            }
        }
    

    效果对比

    demo demo

    参考

    TengineKit - Free, Fast, Easy, Real-Time FaceDetection & FaceLandmark SDK on Mobile.

    源码

    https://github.com/jiangzhongbo/TengineKit_Demo_Thug_Life

    知乎

    https://zhuanlan.zhihu.com/p/180230565

    V2EX 系列

    推荐一个 Github 上面免费用的 Android 人脸关键点 SDK,Demo 图中的小姐姐好漂亮

    抖音美颜效果开源实现,从 AI 到美颜全流程讲解

    尝试 AI 人脸关键点算法实现一下 Android 人脸匿名功能

    抖音快手 APP"大眼特效"开源实现,换了一个甜美系小姐姐做效果演示

    5 条回复    2020-08-12 16:25:02 +08:00
    Microi
        1
    Microi  
       2020-08-11 16:32:47 +08:00
    感谢分享,之前不确切知道这个叫什么风格。
    happuiness
        2
    happuiness  
       2020-08-11 17:29:56 +08:00
    Demo 图中的小姐姐好漂亮
    LZSZ
        3
    LZSZ  
       2020-08-11 21:07:53 +08:00
    美女配上皇冠好看些 大雪茄有点违和
    hxsf
        4
    hxsf  
       2020-08-11 21:16:20 +08:00
    推广节点了解一下?
    darlinghsu
        5
    darlinghsu  
       2020-08-12 16:25:02 +08:00   ❤️ 1
    +1 考虑推广节点吧,你的帖子看了好多次了。
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   5415 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 25ms · UTC 07:02 · PVG 15:02 · LAX 23:02 · JFK 02:02
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.