openFrameworks下的肤色检测源码

举报
ShaderJoy 发表于 2021/12/30 01:03:15 2021/12/30
【摘要】 直接上源码: void testApp::ofSkinDetector(unsigned char* Pointer, ofImage& image, int CAMERA_WIDTH, int CAMERA_HEIGHT){ int len = CAMERA_WIDTH * CAMERA_HEIGHT * 3; unsig...

直接上源码:


  
  1. void testApp::ofSkinDetector(unsigned char* Pointer, ofImage& image, int CAMERA_WIDTH, int CAMERA_HEIGHT)
  2. {
  3. int len = CAMERA_WIDTH * CAMERA_HEIGHT * 3;
  4. unsigned char* SkinP= new unsigned char[len];
  5. for (int Y = 0; Y < CAMERA_HEIGHT; Y++)
  6. {
  7. for (int X = 0; X < CAMERA_WIDTH; X++)
  8. {
  9. unsigned char Red = Pointer[CAMERA_WIDTH * Y * 3 + X * 3];
  10. unsigned char Green = Pointer[CAMERA_WIDTH * Y * 3 + X * 3 + 1];
  11. unsigned char Blue = Pointer[CAMERA_WIDTH * Y * 3 + X * 3 + 2];
  12. unsigned char Max = 0, Min = 0;
  13. if (Red > 95 && Green > 40 && Blue > 20 && Red > Blue && Red > Green && abs(Red - Green) > 15)
  14. {
  15. if (Blue >= Green)
  16. {
  17. Max = Blue;
  18. Min = Green;
  19. }
  20. else
  21. {
  22. Max = Green;
  23. Min = Blue;
  24. }
  25. if (Red > Max)
  26. Max = Red;
  27. else if (Red < Min)
  28. Min = Red;
  29. if (Max - Min > 15)
  30. {
  31. SkinP[CAMERA_WIDTH * Y * 3 + X * 3] = 255;
  32. SkinP[CAMERA_WIDTH * Y * 3 + X * 3 + 1] = 255;
  33. SkinP[CAMERA_WIDTH * Y * 3 + X * 3 + 2] = 255;
  34. }
  35. }
  36. }
  37. }
  38. image.setFromPixels(SkinP, CAMERA_WIDTH, CAMERA_HEIGHT, OF_IMAGE_COLOR);
  39. delete SkinP;
  40. SkinP = NULL;
  41. }

参考博客链接

文章来源: panda1234lee.blog.csdn.net,作者:panda1234lee,版权归原作者所有,如需转载,请联系作者。

原文链接:panda1234lee.blog.csdn.net/article/details/20049517

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。