流程
流程可以分为两部分,一部分是训练,一部分是测试。
起始界面
界面
如下所示,将使用说明进行了介绍,因为是初次使用,很多不太会,所以界面弄得比较简单,以能使用为第一目标。
实现细节
index.html是欢迎界面,记录一下几个小问题
中文的使用
在head部分加上字符集使用utf-8就好啦!
文字居中与背景设置
在html最前面加了个style,设置body的显示效果。
文字显示设置为居中,使用height,width加上margin-top,margin-left便可以设置body部分在页面中显示的地方啦。
背景则设置了图片url,以及居中显示。
body
{
text-align:left;
height:500px;
width:600px;
top:50%;
margin-top:130px;
margin-left:550px;
background-image:url(./imgs/back.jpg);
background-position:center;
background-repeat:repeat-y;
}
按钮的页面跳转
onClick里面用location记录将要跳转的界面。
训练部分
包括
两部分:
startTrain.php用于输入训练目录,
train.php用于将训练数据传到服务器,并将训练成功标记输出
startTrain.php
这一部分做得蛮挫的,查了下php选择文件夹,没有找到该怎么做,所以就用了个来输入目录。真是弱爆了啊
用了一个表单form来记录输入目录,提交表单之后则跳到train.php中进行真正的训练啦。
train.php 这一部分实现了两个功能:
根据输入目录查找所有训练图片,并记录所有图片路径
将所有训练图片一一检测人脸,并将人脸加入到训练模型中
查找目录
php中查找目录中所有文件倒是挺方便的啊,listDir函数在dir.php中。
这个函数根据$dir目录名,将得到的所有文件名存入$names,所有文件路径名则存入$img_urls中。
注意的一点是,如果是中文文件名,则要加上
$file = iconv("gb2312","UTF-8",$file);这一句才会得到结果的,要不就是空哦
php中字符串的查找可以使用strstr函数,
比如下面的$file_name = strstr($file,'.',true)便是查找$file中‘.’的前面部分,如果是strstr($file,'.',false)则是'.'的后面部分。
动态数组的添加使用array_push就ok啦!
哦,不要忘记了关闭资源啊!有opendir($dir)那么就要有对应的closedir($dir)。
function listDir($dir, &$names, &$img_urls)
{
if(is_dir($dir))
{
if ($dh = opendir($dir))
{
while (($file = readdir($dh)) !== false)
{
if((is_dir($dir."/".$file)) && $file!="." && $file!="..")
{
//echo "文件名:",$file,"
";
listDir($dir."/".$file."/");
}
else
{
$file = iconv("gb2312","UTF-8",$file);
if($file!="." && $file!="..")
{
//var_dump($file);
$file_name = strstr($file, '.', true);
//echo $file_name."
";
array_push($names, $file_name);
array_push($img_urls, $dir."/".$file);
}
}
}
closedir($dh);
}
}
}
在train.php中使用如下代码便得到了训练用的所有图片的url啦。
$img_url = array();
$person_name = array();
$trainDir = $_GET["trainDir"];
listDir($trainDir, $person_name, $img_url);
echo "从目录中我们得到了 ".sizeof($img_url)." 张图片".
;接着我们创建一个训练组oldpeople_qiaoxi。
$response = $facepp->execute('/group/delete', array('group_name' => 'oldpeople_qiaoxi'));
$response = $facepp->execute('/group/create', array('group_name' => 'oldpeople_qiaoxi'));接着做循环,对每张图片检测人脸
$params['img'] = $img;
$params['attribute'] = 'gender,age,race,smiling,glass,pose';
$response = $facepp->execute('/detection/detect',$params);从返回值$response得到face_id之后,创建一个person并将检测到的人脸加入这个类别person中。
$response = $facepp->execute('/person/delete', array('person_name' => $person_name[$i],'group_name' => 'oldpeople_qiaoxi'));
$response = $facepp->execute('/person/create', array('person_name' => $person_name[$i],'group_name' => 'oldpeople_qiaoxi'));
$response = $facepp->execute('/person/add_face', array('person_name' => $person_name[$i], 'face_id' => $face_id, 'group_name' => 'oldpeople_qiaoxi'));将所有图片都处理好之后,便可以训练模型了。
$response = $facepp->execute('/train/identify', array('group_name' => 'oldpeople_qiaoxi'));训练成功的话,结果如下:
测试部分
这个部分包括2个部分:
test.php负责选择测试图片
recognition.php负责将测试图片传到服务器并给出结果
test.php部分
显示如下:
选择文件部分用的是来做的,之后表单提交到recognition.php就好了。
recognition.php部分
首先得到图片的url。
$img_url = $_GET["testImgPath"];之后执行identify得到身份结果。
$response = $facepp->execute('/recognition/identify', array('group_name' => 'oldpeople_qiaoxi', 'img' => $img_url));这里采用了一个数组来进行中文名与英文名的对应,因为face++不支持中文名的图片,所以传给它的图片都是英文命名的,但是显示需要中文名,所以在这里进行映射。
$person_name = array("ami" => "艾米", "dongjian" => "张东健", "xiaowang" => "小王");
$img_url = array();$person_name = array();$trainDir = $_GET["trainDir"];listDir($trainDir, $person_name, $img_url);echo "从目录中我们得到了 ".sizeof($img_url)." 张图片".
;