广告位联系
返回顶部
分享到

详解人脸认证源码faceIdentify源码

C语言 来源:互联网搜集 作者:秩名 发布时间:2019-08-28 21:30:10 人浏览
摘要

人脸认证:代码如下 using AForge.Video.DirectShow;using face;using Newtonsoft.Json;using Newtonsoft.Json.Linq;using System;using System.Collections.Generic;using System.ComponentModel;using System.Data;using System.Data.SqlClient;using Syst

人脸认证:代码如下

using AForge.Video.DirectShow;
using face;
using Newtonsoft.Json;
using Newtonsoft.Json.Linq;
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Data.SqlClient;
using System.Drawing;
using System.Drawing.Imaging;
using System.IO;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;
 
namespace Camtest
{
 public partial class faceIdentify : Form
 {
  public faceIdentify()
  {
   InitializeComponent();
   //启动默认在屏幕中间
   this.StartPosition = System.Windows.Forms.FormStartPosition.CenterScreen;
  }
  //Api_Key
  public static string Api_Key = "OVYw5Ok0y9U8n6CfVPYt0wfZ";
  //Secret_Key
  public static string Secret_Key = "aCN3lupCarq3rC9G8Rylqz1d36Towp8G";
  FilterInfoCollection videoDevices;
  VideoCaptureDevice videoSource;
  public int selectedDeviceIndex = 0;
  public int selectedPICIndex = 0;
 
  //窗体加载
  private void faceIdentify_Load(object sender, EventArgs e)
  {
   //显示为正在检测
   this.label1.Text = this.label2.Text = this.label6.Text = this.label9.Text = "正在识别";
 
   // 刷新可用相机的列表
   videoDevices = new FilterInfoCollection(FilterCategory.VideoInputDevice);
   comboBoxCameras.Items.Clear();
 
   for (int i = 0; i < videoDevices.Count; i++)
   {
    comboBoxCameras.Items.Add(videoDevices[i].Name.ToString());
   }
 
 
   if (comboBoxCameras.Items.Count > 0)
    comboBoxCameras.SelectedIndex = 0;
   picsize.SelectedIndex = 0;
 
   //打开摄像头
   openCamera();
  }
 
  //打开摄像头
  public void openCamera()
  {
   selectedPICIndex = picsize.SelectedIndex;
 
   selectedDeviceIndex = comboBoxCameras.SelectedIndex;
   //连接摄像头。
   videoSource = new VideoCaptureDevice(videoDevices[selectedDeviceIndex].MonikerString);
   videoSource.VideoResolution = videoSource.VideoCapabilities[selectedDeviceIndex];
   // 枚举所有摄像头支持的像素,设置拍照为1920*1080
   foreach (VideoCapabilities capab in videoSource.VideoCapabilities)
   {
    if (selectedPICIndex == 0)
    {
     if (capab.FrameSize.Width == 1920 && capab.FrameSize.Height == 1080)
     {
      videoSource.VideoResolution = capab;
      break;
     }
     if (capab.FrameSize.Width == 1280 && capab.FrameSize.Height == 720)
     {
      videoSource.VideoResolution = capab;
      break;
     }
    }
    else
    {
     if (capab.FrameSize.Width == 1280 && capab.FrameSize.Height == 720)
     {
      videoSource.VideoResolution = capab;
      break;
     }
    }
   }
   videoSourcePlayer1.VideoSource = videoSource;
 
   // set NewFrame event handler
   videoSourcePlayer1.Start();
  }
 
  /// <summary>
  /// 签到的按钮
  /// 先保存图片,然后进行比较,获取的id,查询
  /// </summary>
  /// <param name="sender"></param>
  /// <param name="e"></param>
  private void qiandao_Click(object sender, EventArgs e)
  {
   Users users = FaceIdentifys(SavePicture());
   this.label1.Text = users.age.ToString();
   this.label2.Text = users.name;
   this.label6.Text = users.phone;
   this.label9.Text = users.address;
   if (users.picture != null)
   {
    this.pictureBox1.Image = Image.FromFile(users.picture, false);
   }
 
  }
 
  //关闭窗口
  private void faceIdentify_FormClosing(object sender, FormClosingEventArgs e)
  {
   DialogResult r = MessageBox.Show("确定要退出程序?", "操作提示", MessageBoxButtons.OKCancel, MessageBoxIcon.Question);
   if (r != DialogResult.OK)
   {
 
    e.Cancel = true;
   }
   videoSourcePlayer1.Stop();//停止摄像头
   videoSourcePlayer1.Dispose();
  }
 
  /// <summary>
  /// 人脸识别
  /// </summary>
  /// <param name="filename"></param>
  public static Users FaceIdentifys(string filename)
  {
   long id = 0;
   string ids = "";
   double scores_num = 0;
   Users user = new Users();
   var client = new Baidu.Aip.Face.Face(Api_Key, Secret_Key);
   var image1 = File.ReadAllBytes(filename);
   var result = client.User.Identify(image1, new[] { "gr_test" }, 1, 1);
   //先判断脸是不是在上面,在继续看有匹配的没,否则提示放上脸
   //得到根节点
   JObject jo_result = (JObject)JsonConvert.DeserializeObject(result.ToString());
   if ((string)jo_result["error_msg"] != null)
   {
    MessageBox.Show("对不起,请把脸放上!", "提示", MessageBoxButtons.OK, MessageBoxIcon.Stop);
   }
   else
   {
    //检测到脸
    //得到result节点
    JArray jo_age = (JArray)JsonConvert.DeserializeObject(jo_result["result"].ToString());
    foreach (var val in jo_age)
    {
     id = long.Parse(((JObject)val)["uid"].ToString()); //获取uid
     string scores = ((JObject)val)["scores"].ToString();//获取scores
     int num1 = scores.IndexOf("\n") + 2;
     int num2 = scores.LastIndexOf("]")-8;
     ids = scores.Substring(num1, num2);
     scores_num =double.Parse(ids);
    }
    if (scores_num > 80)
    {
     user = QueryUsersById(id);
     if (user.id != 0)
     {
      MessageBox.Show("签到成功,已检测到您的信息", "操作提示", MessageBoxButtons.OK, MessageBoxIcon.Information);
     }
     else
     {
      MessageBox.Show("对不起,系统根据您的脸未检测到信息", "操作提示", MessageBoxButtons.OK, MessageBoxIcon.Stop);
     }
    }
    else {
     MessageBox.Show("对不起,系统根据您的脸未检测到信息", "操作提示", MessageBoxButtons.OK, MessageBoxIcon.Stop);
    }
 
   }
   return user;
 
  }
 
  /// <summary>
  /// 保存图片
  /// </summary>
  public string SavePicture()
  {
   if (videoSource == null)
   {
    return null;
   }
 
   Bitmap bitmap = videoSourcePlayer1.GetCurrentVideoFrame();
   //图片名称,年月日时分秒毫秒.jpg
   string fileName = DateTime.Now.ToString("yyyyMMddHHmmssff") + ".jpg";
 
   //获取项目的根目录
   string path = AppDomain.CurrentDomain.BaseDirectory;
   string picture = path + "\\picture\\" + fileName;
   //将图片保存在服务器里面
   bitmap.Save(picture, ImageFormat.Jpeg);
   bitmap.Dispose();
   return picture;
  }
 
  /// <summary>
  /// 根据编号查询用户信息
  /// </summary>
  /// <param name="id"></param>
  /// <returns></returns>
  public static Users QueryUsersById(long id)
  {
 
   Users user = new Users();
   string sql = "select * from users where id = @id";
   using (SqlDataReader reader = SqlHelper.ExcuteReader(sql, CommandType.Text, new SqlParameter("@id", id)))
   {
    if (reader.Read())
    {
     user.id = long.Parse(reader[0].ToString());
     user.name = reader[1].ToString();
     user.age = Convert.ToInt32(reader[2]);
     user.phone = reader[3].ToString();
     user.password = reader[4].ToString();
     user.address = reader[5].ToString();
     user.picture = reader[6].ToString();
    }
   }
   return user;
  }
 
  //取消的按钮
  private void close_Click(object sender, EventArgs e)
  {
   //停止摄像头
   videoSourcePlayer1.Stop();
   this.Close();
   welcome we = new welcome();
   we.Show();
  }
 
 
 }
}


版权声明 : 本文内容来源于互联网或用户自行发布贡献,该文观点仅代表原作者本人。本站仅提供信息存储空间服务和不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权, 违法违规的内容, 请发送邮件至2530232025#qq.cn(#换@)举报,一经查实,本站将立刻删除。

您可能感兴趣的文章 :

原文链接 : https://blog.csdn.net/qq_34137397/article/details/78685549
    Tag :
相关文章
  • C++中类的六大默认成员函数的介绍

    C++中类的六大默认成员函数的介绍
    一、类的默认成员函数 二、构造函数Date(形参列表) 构造函数主要完成初始化对象,相当于C语言阶段写的Init函数。 默认构造函数:无参的构
  • C/C++实现遍历文件夹最全方法总结介绍

    C/C++实现遍历文件夹最全方法总结介绍
    一、filesystem(推荐) 在c++17中,引入了文件系统,使用起来非常方便 在VS中,可以直接在项目属性中调整: 只要是C++17即以上都可 然后头文件
  • C语言实现手写Map(数组+链表+红黑树)的代码

    C语言实现手写Map(数组+链表+红黑树)的代码
    要求 需要准备数组集合(List) 数据结构 需要准备单向链表(Linked) 数据结构 需要准备红黑树(Rbtree)数据结构 需要准备红黑树和链表适配策略
  • MySQL系列教程之使用C语言来连接数据库

    MySQL系列教程之使用C语言来连接数据库
    写在前面 知道了 Java中使用 JDBC编程 来连接数据库了,但是使用 C语言 来连接数据库却总是连接不上去~ 立即安排一波使用 C语言连接 MySQL数
  • 基于C语言实现简单学生成绩管理系统

    基于C语言实现简单学生成绩管理系统
    一、系统主要功能 1、密码登录 2、输入数据 3、查询成绩 4、修改成绩 5、输出所有学生成绩 6、退出系统 二、代码实现 1 2 3 4 5 6 7 8 9 10 11
  • C语言实现共享单车管理系统

    C语言实现共享单车管理系统
    1.功能模块图; 2.各个模块详细的功能描述。 1.登陆:登陆分为用户登陆,管理员登陆以及维修员登录,登陆后不同的用户所执行的操作
  • C++继承与菱形继承的介绍

    C++继承与菱形继承的介绍
    继承的概念和定义 继承机制是面向对象程序设计的一种实现代码复用的重要手段,它允许程序员在保持原有类特性的基础上进行拓展,增加
  • C/C++指针介绍与使用介绍

    C/C++指针介绍与使用介绍
    什么是指针 C/C++语言拥有在程序运行时获得变量的地址和操作地址的能力,这种用来操作地址的特殊类型变量被称作指针。 翻译翻译什么
  • C++进程的创建和进程ID标识介绍
    进程的ID 进程的ID,可称为PID。它是进程的唯一标识,类似于我们的身份证号是唯一标识,因为名字可能会和其他人相同,生日可能会与其他
  • C++分析如何用虚析构与纯虚析构处理内存泄漏

    C++分析如何用虚析构与纯虚析构处理内存泄漏
    一、问题引入 使用多态时,如果有一些子类的成员开辟在堆区,那么在父类执行完毕释放后,没有办法去释放子类的内存,这样会导致内存
  • 本站所有内容来源于互联网或用户自行发布,本站仅提供信息存储空间服务,不拥有版权,不承担法律责任。如有侵犯您的权益,请您联系站长处理!
  • Copyright © 2017-2022 F11.CN All Rights Reserved. F11站长开发者网 版权所有 | 苏ICP备2022031554号-1 | 51LA统计