639 lines
32 KiB
PHP
639 lines
32 KiB
PHP
|
|
<?php
|
||
|
|
|
||
|
|
namespace app\NewReedaw\controller\app;
|
||
|
|
|
||
|
|
use think\Db;
|
||
|
|
use think\Cache;
|
||
|
|
|
||
|
|
class Vitalcapacity extends Base{
|
||
|
|
|
||
|
|
protected $vitalcapacity_db_name = [
|
||
|
|
'zhanghao'=>'app_account_number',
|
||
|
|
'juese'=>'app_user_data',
|
||
|
|
'vitalcapacity'=>'app_card_vitalcapacity_data',
|
||
|
|
'biaozhun'=>'pc_vitalcapacity_standard',
|
||
|
|
|
||
|
|
];
|
||
|
|
protected $color = ['无效'=>'#FF5656','不及格'=>'#FF5656','及格'=>'#FFAB00','良好'=>'#5AD06D','优秀'=>'#6492F6','牛逼'=>'#3967D6'];
|
||
|
|
protected $curve_data_format = ['one_val'=>['第一次','容积/ml','#009DFF'],'two_val'=>['第二次','容积/ml','#009DFF'],'three_val'=>['第三次','容积/ml','#009DFF'],'average_val'=>['平均','容积/ml','#009DFF']];
|
||
|
|
protected $pagesize = 15;
|
||
|
|
// 加 bcadd(,,20)
|
||
|
|
// 减 bcsub(,,20)
|
||
|
|
// 乘 bcmul(,,20)
|
||
|
|
// 除 bcdiv(,,20)
|
||
|
|
// 测试token=>'caadd1be045a65f30b92aa805f1de54a'
|
||
|
|
|
||
|
|
################################################################接口################################################################
|
||
|
|
################################################################接口################################################################
|
||
|
|
################################################################接口################################################################
|
||
|
|
|
||
|
|
// 手动记录
|
||
|
|
public function manual_record(){
|
||
|
|
try {
|
||
|
|
|
||
|
|
$data = input('post.');
|
||
|
|
if(!array_key_exists('aud_id', $data) || !array_key_exists('one', $data) || !array_key_exists('two', $data) || !array_key_exists('three', $data) || !array_key_exists('time', $data) || !array_key_exists('token', $data)){
|
||
|
|
return $this->msg(10001);
|
||
|
|
}
|
||
|
|
unset($data['token']);
|
||
|
|
if(!$this->verify_data_is_ok($data['aud_id'],'intnum')){
|
||
|
|
return $this->msg(10005,'aud_id type error');
|
||
|
|
}
|
||
|
|
if(!$this->verify_data_is_ok($data['one'],'intnum')){
|
||
|
|
return $this->msg(10005,'one type error');
|
||
|
|
}
|
||
|
|
if(!$this->verify_data_is_ok($data['two'],'intnum')){
|
||
|
|
return $this->msg(10005,'two type error');
|
||
|
|
}
|
||
|
|
if(!$this->verify_data_is_ok($data['three'],'intnum')){
|
||
|
|
return $this->msg(10005,'three type error');
|
||
|
|
}
|
||
|
|
if(!$this->verify_data_is_ok($data['time'],'datetime')){
|
||
|
|
return $this->msg(10005,'time type error');
|
||
|
|
}
|
||
|
|
if(strlen($data['time']) <= 12){
|
||
|
|
// 时间日期转换,把'Y-m-d'转换成'Y-m-d H:i:s'格式
|
||
|
|
$data['time'] = $this->addCurrentTimeToDateString($data['time']);
|
||
|
|
}
|
||
|
|
return $this->manual_record_action($data,'by_hand_means');
|
||
|
|
} catch (\Exception $e) {
|
||
|
|
// 捕获异常
|
||
|
|
$logContent["flie"] = $e->getFile();
|
||
|
|
$logContent["line"] = $e->getLine();
|
||
|
|
$logContent['all_content'] = "异常信息:\n";
|
||
|
|
$logContent['all_content'] .= "消息: " . $e->getMessage() . "\n";
|
||
|
|
$logContent['all_content'] .= "代码: " . $e->getCode() . "\n";
|
||
|
|
$logContent['all_content'] .= "文件: " . $e->getFile() . "\n";
|
||
|
|
$logContent['all_content'] .= "行号: " . $e->getLine() . "\n";
|
||
|
|
$logContent['all_content'] .= "跟踪信息:\n" . $e->getTraceAsString() . "\n";
|
||
|
|
$this->record_api_log($data, $logContent, null);
|
||
|
|
return $this->msg(99999);
|
||
|
|
}
|
||
|
|
}
|
||
|
|
// 设备记录
|
||
|
|
public function device_record(){
|
||
|
|
try {
|
||
|
|
$data = input('post.');
|
||
|
|
if(!array_key_exists('aud_id', $data) || !array_key_exists('one', $data) || !array_key_exists('two', $data) || !array_key_exists('three', $data) || !array_key_exists('token', $data)){
|
||
|
|
return $this->msg(10001);
|
||
|
|
}
|
||
|
|
unset($data['token']);
|
||
|
|
if(!$this->verify_data_is_ok($data['aud_id'],'intnum')){
|
||
|
|
return $this->msg(10005,'aud_id type error');
|
||
|
|
}
|
||
|
|
if(!$this->verify_data_is_ok($data['one'],'intnum')){
|
||
|
|
return $this->msg(10005,'one type error');
|
||
|
|
}
|
||
|
|
if(!$this->verify_data_is_ok($data['two'],'intnum')){
|
||
|
|
return $this->msg(10005,'two type error');
|
||
|
|
}
|
||
|
|
if(!$this->verify_data_is_ok($data['three'],'intnum')){
|
||
|
|
return $this->msg(10005,'three type error');
|
||
|
|
}
|
||
|
|
$data['time'] = date('Y-m-d H:i:s');
|
||
|
|
return $this->manual_record_action($data,'by_device');
|
||
|
|
} catch (\Exception $e) {
|
||
|
|
// 捕获异常
|
||
|
|
$logContent["flie"] = $e->getFile();
|
||
|
|
$logContent["line"] = $e->getLine();
|
||
|
|
$logContent['all_content'] = "异常信息:\n";
|
||
|
|
$logContent['all_content'] .= "消息: " . $e->getMessage() . "\n";
|
||
|
|
$logContent['all_content'] .= "代码: " . $e->getCode() . "\n";
|
||
|
|
$logContent['all_content'] .= "文件: " . $e->getFile() . "\n";
|
||
|
|
$logContent['all_content'] .= "行号: " . $e->getLine() . "\n";
|
||
|
|
$logContent['all_content'] .= "跟踪信息:\n" . $e->getTraceAsString() . "\n";
|
||
|
|
$this->record_api_log($data, $logContent, null);
|
||
|
|
return $this->msg(99999);
|
||
|
|
}
|
||
|
|
}
|
||
|
|
// 数据报告
|
||
|
|
public function data_report(){
|
||
|
|
try {
|
||
|
|
$data = input('post.');
|
||
|
|
if(!array_key_exists('aud_id', $data) || !array_key_exists('token', $data)){
|
||
|
|
$return_data = $this->msg(10001);
|
||
|
|
}
|
||
|
|
unset($data['token']);
|
||
|
|
if(!$this->verify_data_is_ok($data['aud_id'],'intnum')){
|
||
|
|
return $this->msg(10005,'aud_id type error');
|
||
|
|
}
|
||
|
|
return $this->data_report_action($data);
|
||
|
|
} catch (\Exception $e) {
|
||
|
|
// 捕获异常
|
||
|
|
$logContent["flie"] = $e->getFile();
|
||
|
|
$logContent["line"] = $e->getLine();
|
||
|
|
$logContent['all_content'] = "异常信息:\n";
|
||
|
|
$logContent['all_content'] .= "消息: " . $e->getMessage() . "\n";
|
||
|
|
$logContent['all_content'] .= "代码: " . $e->getCode() . "\n";
|
||
|
|
$logContent['all_content'] .= "文件: " . $e->getFile() . "\n";
|
||
|
|
$logContent['all_content'] .= "行号: " . $e->getLine() . "\n";
|
||
|
|
$logContent['all_content'] .= "跟踪信息:\n" . $e->getTraceAsString() . "\n";
|
||
|
|
$this->record_api_log($data, $logContent, null);
|
||
|
|
return $this->msg(99999);
|
||
|
|
}
|
||
|
|
}
|
||
|
|
// 曲线
|
||
|
|
public function curve_chart(){
|
||
|
|
try {
|
||
|
|
// 你的业务逻辑
|
||
|
|
if(count(input('post.')) > 0){
|
||
|
|
$data = input('post.');
|
||
|
|
}
|
||
|
|
if(!array_key_exists('aud_id', $data) || !array_key_exists('time', $data) || !array_key_exists('token', $data)){
|
||
|
|
$return_data = $this->msg(10001);
|
||
|
|
}
|
||
|
|
unset($data['token']);
|
||
|
|
if(!$this->verify_data_is_ok($data['aud_id'],'intnum')){
|
||
|
|
return $this->msg(10005,'aud_id type error');
|
||
|
|
}
|
||
|
|
if(!$this->verify_data_is_ok($data['time'],'datetime')){
|
||
|
|
return $this->msg(10005,'time type error');
|
||
|
|
}
|
||
|
|
return $this->curve_chart_action($data);
|
||
|
|
} catch (\Exception $e) {
|
||
|
|
// 捕获异常
|
||
|
|
$logContent["flie"] = $e->getFile();
|
||
|
|
$logContent["line"] = $e->getLine();
|
||
|
|
$logContent['all_content'] = "异常信息:\n";
|
||
|
|
$logContent['all_content'] .= "消息: " . $e->getMessage() . "\n";
|
||
|
|
$logContent['all_content'] .= "代码: " . $e->getCode() . "\n";
|
||
|
|
$logContent['all_content'] .= "文件: " . $e->getFile() . "\n";
|
||
|
|
$logContent['all_content'] .= "行号: " . $e->getLine() . "\n";
|
||
|
|
$logContent['all_content'] .= "跟踪信息:\n" . $e->getTraceAsString() . "\n";
|
||
|
|
$this->record_api_log($data, $logContent, null);
|
||
|
|
return $this->msg(99999);
|
||
|
|
}
|
||
|
|
}
|
||
|
|
// 获取历史列表(分页)
|
||
|
|
public function record_list_page(){
|
||
|
|
try {
|
||
|
|
$data = input('post.');
|
||
|
|
if(!array_key_exists('token', $data) || !array_key_exists('aud_id', $data) || !array_key_exists('page', $data)){
|
||
|
|
return $this->msg(10001);
|
||
|
|
}
|
||
|
|
if(!$this->verify_data_is_ok($data['token'],'str')){
|
||
|
|
return $this->msg(10005,'token type error');
|
||
|
|
}
|
||
|
|
if(!$this->verify_data_is_ok($data['aud_id'],'intnum')){
|
||
|
|
return $this->msg(10005,'aud_id type error');
|
||
|
|
}
|
||
|
|
if(!$this->verify_data_is_ok($data['page'],'intnum')){
|
||
|
|
return $this->msg(10005,'page type error');
|
||
|
|
}
|
||
|
|
return $this->record_list_page_or_group_action($data,'page');
|
||
|
|
} catch (\Exception $e) {
|
||
|
|
// 捕获异常
|
||
|
|
$logContent["flie"] = $e->getFile();
|
||
|
|
$logContent["line"] = $e->getLine();
|
||
|
|
$logContent['all_content'] = "异常信息:\n";
|
||
|
|
$logContent['all_content'] .= "消息: " . $e->getMessage() . "\n";
|
||
|
|
$logContent['all_content'] .= "代码: " . $e->getCode() . "\n";
|
||
|
|
$logContent['all_content'] .= "文件: " . $e->getFile() . "\n";
|
||
|
|
$logContent['all_content'] .= "行号: " . $e->getLine() . "\n";
|
||
|
|
$logContent['all_content'] .= "跟踪信息:\n" . $e->getTraceAsString() . "\n";
|
||
|
|
$this->record_api_log($data, $logContent, null);
|
||
|
|
return $this->msg(99999);
|
||
|
|
}
|
||
|
|
}
|
||
|
|
// 获取历史列表(分组)
|
||
|
|
public function record_list_group(){
|
||
|
|
try {
|
||
|
|
$data = input('post.');
|
||
|
|
if(!array_key_exists('token', $data) || !array_key_exists('aud_id', $data) || !array_key_exists('s_time', $data) || !array_key_exists('e_time', $data)){
|
||
|
|
return $this->msg(10001);
|
||
|
|
}
|
||
|
|
if(!$this->verify_data_is_ok($data['token'],'str')){
|
||
|
|
return $this->msg(10005,'token type error');
|
||
|
|
}
|
||
|
|
if(!$this->verify_data_is_ok($data['aud_id'],'intnum')){
|
||
|
|
return $this->msg(10005,'aud_id type error');
|
||
|
|
}
|
||
|
|
if(!$this->verify_data_is_ok($data['s_time'],'datetime')){
|
||
|
|
return $this->msg(10005,'page type error');
|
||
|
|
}
|
||
|
|
if(!$this->verify_data_is_ok($data['e_time'],'datetime')){
|
||
|
|
return $this->msg(10005,'page type error');
|
||
|
|
}
|
||
|
|
return $this->record_list_page_or_group_action($data,'group');
|
||
|
|
} catch (\Exception $e) {
|
||
|
|
// 捕获异常
|
||
|
|
$logContent["flie"] = $e->getFile();
|
||
|
|
$logContent["line"] = $e->getLine();
|
||
|
|
$logContent['all_content'] = "异常信息:\n";
|
||
|
|
$logContent['all_content'] .= "消息: " . $e->getMessage() . "\n";
|
||
|
|
$logContent['all_content'] .= "代码: " . $e->getCode() . "\n";
|
||
|
|
$logContent['all_content'] .= "文件: " . $e->getFile() . "\n";
|
||
|
|
$logContent['all_content'] .= "行号: " . $e->getLine() . "\n";
|
||
|
|
$logContent['all_content'] .= "跟踪信息:\n" . $e->getTraceAsString() . "\n";
|
||
|
|
$this->record_api_log($data, $logContent, null);
|
||
|
|
return $this->msg(99999);
|
||
|
|
}
|
||
|
|
}
|
||
|
|
// 历史记录(详细)
|
||
|
|
public function detailed_record(){
|
||
|
|
try {
|
||
|
|
$data = input('post.');
|
||
|
|
if(!array_key_exists('token', $data) || !array_key_exists('id', $data)){
|
||
|
|
return $this->msg(10001);
|
||
|
|
}
|
||
|
|
if(!$this->verify_data_is_ok($data['token'],'str')){
|
||
|
|
return $this->msg(10005,'token type error');
|
||
|
|
}
|
||
|
|
if(!$this->verify_data_is_ok($data['id'],'intnum')){
|
||
|
|
return $this->msg(10005,'id type error');
|
||
|
|
}
|
||
|
|
return $this->get_all_detaile_data_action($data);
|
||
|
|
} catch (\Exception $e) {
|
||
|
|
// 捕获异常
|
||
|
|
$logContent["flie"] = $e->getFile();
|
||
|
|
$logContent["line"] = $e->getLine();
|
||
|
|
$logContent['all_content'] = "异常信息:\n";
|
||
|
|
$logContent['all_content'] .= "消息: " . $e->getMessage() . "\n";
|
||
|
|
$logContent['all_content'] .= "代码: " . $e->getCode() . "\n";
|
||
|
|
$logContent['all_content'] .= "文件: " . $e->getFile() . "\n";
|
||
|
|
$logContent['all_content'] .= "行号: " . $e->getLine() . "\n";
|
||
|
|
$logContent['all_content'] .= "跟踪信息:\n" . $e->getTraceAsString() . "\n";
|
||
|
|
$this->record_api_log($data, $logContent, null);
|
||
|
|
return $this->msg(99999);
|
||
|
|
}
|
||
|
|
}
|
||
|
|
// 删除历史数据
|
||
|
|
public function del_record(){
|
||
|
|
try {
|
||
|
|
$data = input('post.');
|
||
|
|
if(!array_key_exists('id', $data) || !array_key_exists('token', $data)){
|
||
|
|
return $this->msg(10001);
|
||
|
|
}
|
||
|
|
if(!$this->verify_data_is_ok($data['id'],'intnum')){
|
||
|
|
return $this->msg(10005);
|
||
|
|
}
|
||
|
|
unset($data['token']);
|
||
|
|
$user_data = Db::table($this->vitalcapacity_db_name['vitalcapacity'])->where(['id'=>$data['id']])->update(['is_del'=>1]);
|
||
|
|
if($user_data){
|
||
|
|
return $this->msg([]);
|
||
|
|
}else{
|
||
|
|
return $this->msg(10002);
|
||
|
|
}
|
||
|
|
} catch (\Exception $e) {
|
||
|
|
// 捕获异常
|
||
|
|
$logContent["flie"] = $e->getFile();
|
||
|
|
$logContent["line"] = $e->getLine();
|
||
|
|
$logContent['all_content'] = "异常信息:\n";
|
||
|
|
$logContent['all_content'] .= "消息: " . $e->getMessage() . "\n";
|
||
|
|
$logContent['all_content'] .= "代码: " . $e->getCode() . "\n";
|
||
|
|
$logContent['all_content'] .= "文件: " . $e->getFile() . "\n";
|
||
|
|
$logContent['all_content'] .= "行号: " . $e->getLine() . "\n";
|
||
|
|
$logContent['all_content'] .= "跟踪信息:\n" . $e->getTraceAsString() . "\n";
|
||
|
|
$this->record_api_log($data, $logContent, null);
|
||
|
|
return $this->msg(99999);
|
||
|
|
}
|
||
|
|
}
|
||
|
|
|
||
|
|
################################################################action################################################################
|
||
|
|
################################################################action################################################################
|
||
|
|
public function manual_record_action($data,$type){
|
||
|
|
$temporary_arr['aud_id'] = $data['aud_id'];
|
||
|
|
$temporary_arr['record_time'] = $data['time'];
|
||
|
|
$temporary_arr['one'] = $data['one'];
|
||
|
|
$temporary_arr['two'] = $data['two'];
|
||
|
|
$temporary_arr['three'] = $data['three'];
|
||
|
|
$temporary_arr['average'] = bcdiv(bcadd(bcadd($data['one'],$data['two'],2),$data['three'],2),3,2);
|
||
|
|
$temporary_arr['create_time'] = date('Y-m-d H:i:s');
|
||
|
|
$temporary_arr['one_val'] = $data['one'];
|
||
|
|
$temporary_arr['two_val'] = $data['two'];
|
||
|
|
$temporary_arr['three_val'] = $data['three'];
|
||
|
|
$temporary_arr['average_val'] = $temporary_arr['average'];
|
||
|
|
$temporary_arr['flow_val'] = array_key_exists('flow', $data)?$data['flow']:'0.00';//流速
|
||
|
|
$temporary_arr['record_type'] = $type;//流速
|
||
|
|
// die;
|
||
|
|
// 处理记录时间
|
||
|
|
|
||
|
|
$user_msg = Db::name($this->vitalcapacity_db_name['juese'])->where(['id'=>$data['aud_id']])->field('id,grade,gender,birthday')->find();
|
||
|
|
// die;
|
||
|
|
if($user_msg){
|
||
|
|
// 根据性别&年级&年龄查规则
|
||
|
|
if($user_msg['grade'] == 'nothing'){
|
||
|
|
// 计算年龄判断是属于哪个年级
|
||
|
|
$user_age = $this->calculate_age($user_msg['birthday']);
|
||
|
|
if($user_age <= 7){
|
||
|
|
$user_msg['grade'] = 'grade_s_1';
|
||
|
|
}else if($user_age == 8){
|
||
|
|
$user_msg['grade'] = 'grade_s_2';
|
||
|
|
}else if($user_age == 9){
|
||
|
|
$user_msg['grade'] = 'grade_s_3';
|
||
|
|
}else if($user_age == 10){
|
||
|
|
$user_msg['grade'] = 'grade_s_4';
|
||
|
|
}else if($user_age == 11){
|
||
|
|
$user_msg['grade'] = 'grade_s_5';
|
||
|
|
}else if($user_age == 12){
|
||
|
|
$user_msg['grade'] = 'grade_s_6';
|
||
|
|
}else if($user_age == 13){
|
||
|
|
$user_msg['grade'] = 'grade_m_1';
|
||
|
|
}else if($user_age == 14){
|
||
|
|
$user_msg['grade'] = 'grade_m_2';
|
||
|
|
}else if($user_age == 15){
|
||
|
|
$user_msg['grade'] = 'grade_m_3';
|
||
|
|
}else if($user_age == 16){
|
||
|
|
$user_msg['grade'] = 'grade_h_1';
|
||
|
|
}else if($user_age == 17){
|
||
|
|
$user_msg['grade'] = 'grade_h_2';
|
||
|
|
}else if($user_age == 18){
|
||
|
|
$user_msg['grade'] = 'grade_h_3';
|
||
|
|
}else if($user_age == 19 || $user_age == 20){
|
||
|
|
$user_msg['grade'] = 'grade_u_12';
|
||
|
|
}else if($user_age >= 21){
|
||
|
|
$user_msg['grade'] = 'grade_u_34';
|
||
|
|
}
|
||
|
|
}
|
||
|
|
$sql_str = "sex = ".$user_msg['gender']." and ".$user_msg['grade']." <= ".$temporary_arr['average_val'];
|
||
|
|
$user_achievement = Db::name($this->vitalcapacity_db_name['biaozhun'])->where($sql_str)->order($user_msg['grade'] .' desc')->field('level,score,'.$user_msg['grade'])->limit(1)->cache(86400)->select();
|
||
|
|
if(count($user_achievement)<=0){
|
||
|
|
$user_achievement[0] = ['level'=>'无效','score'=>'0'];
|
||
|
|
}
|
||
|
|
$temporary_arr['score'] = $user_achievement[0]['score'].','.$user_achievement[0]['level'].','.$this->color[$user_achievement[0]['level']];
|
||
|
|
$temporary_arr['score_val'] = $user_achievement[0]['score'];
|
||
|
|
|
||
|
|
}else{
|
||
|
|
return $this->msg(10004,'未找到有效数据');
|
||
|
|
}
|
||
|
|
$standard_data = $this->get_vitalcapacity_data($data['aud_id']);
|
||
|
|
$temporary_arr['standard_data'] = json_encode($standard_data);
|
||
|
|
$result = Db::table($this->vitalcapacity_db_name['vitalcapacity'])->insert($temporary_arr);
|
||
|
|
|
||
|
|
if($result){
|
||
|
|
$time = $result[0]['record_time'];
|
||
|
|
$time = strtotime($time);
|
||
|
|
$time = date('Y年m月d日 H:i:s', $time);
|
||
|
|
return $this->msg([
|
||
|
|
'average'=>$temporary_arr['average'].'ml',
|
||
|
|
'level'=>$user_achievement[0]['level'],
|
||
|
|
'time'=>$time,
|
||
|
|
'flow_val'=>$temporary_arr['flow_val'],
|
||
|
|
'list'=>$standard_data,
|
||
|
|
'offset'=>$this->vitalcapacity_standard_interval($temporary_arr['average'],$standard_data)
|
||
|
|
]);
|
||
|
|
}else{
|
||
|
|
return $this->msg(10002);
|
||
|
|
}
|
||
|
|
}
|
||
|
|
public function data_report_action($data){
|
||
|
|
$result = Db::table($this->vitalcapacity_db_name['vitalcapacity'])->where(['aud_id'=>$data['aud_id']])->order('record_time desc')->field('record_time,score,average,flow_val,standard_data')->limit(1)->select();
|
||
|
|
|
||
|
|
if(count($result) <= 0){
|
||
|
|
// return $this->msg(10004);
|
||
|
|
return $this->msg([
|
||
|
|
'average'=>'',
|
||
|
|
'level'=>'',
|
||
|
|
'time'=>'',
|
||
|
|
'flow_val'=>'',
|
||
|
|
'list'=>'',
|
||
|
|
'offset'=>''
|
||
|
|
]);
|
||
|
|
|
||
|
|
}else{
|
||
|
|
|
||
|
|
$time = $result[0]['record_time'];
|
||
|
|
$time = strtotime($time);
|
||
|
|
$time = date('Y年m月d日 H:i:s', $time);
|
||
|
|
$o_l = explode(',',$result[0]['score']);
|
||
|
|
// $standard_data = $this->get_vitalcapacity_data($data['aud_id']);
|
||
|
|
$standard_data = json_decode($result[0]['standard_data'],true);
|
||
|
|
|
||
|
|
return $this->msg([
|
||
|
|
'average'=>$result[0]['average'].'ml',
|
||
|
|
'level'=>$o_l[1],
|
||
|
|
'time'=>$time,
|
||
|
|
'flow_val'=>$result[0]['flow_val'] == '.00'?'0.00':$result[0]['flow_val'],
|
||
|
|
'list'=>$standard_data,
|
||
|
|
'offset'=>$this->vitalcapacity_standard_interval($result[0]['average'],$standard_data)
|
||
|
|
]);
|
||
|
|
}
|
||
|
|
}
|
||
|
|
public function curve_chart_action($data){
|
||
|
|
$audid = $data['aud_id'];
|
||
|
|
$timeData = explode('-', $data['time']);
|
||
|
|
|
||
|
|
// 根据$timeData的长度构建不同的查询条件
|
||
|
|
$map = ['aud_id' => $audid];
|
||
|
|
switch (count($timeData)) {
|
||
|
|
case 3: // 年月日
|
||
|
|
$map['record_time'] = ['between', [date('Y-m-d 00:00:00', strtotime($timeData[0] . '-' . $timeData[1] . '-' . $timeData[2])), date('Y-m-d 23:59:59', strtotime($timeData[0] . '-' . $timeData[1] . '-' . $timeData[2]))]];
|
||
|
|
break;
|
||
|
|
case 2: // 年月
|
||
|
|
$map['record_time'] = ['between', [date('Y-m-01 00:00:00', strtotime($timeData[0] . '-' . $timeData[1])), date('Y-m-t 23:59:59', strtotime($timeData[0] . '-' . $timeData[1]))]];
|
||
|
|
break;
|
||
|
|
case 1: // 年
|
||
|
|
$map['record_time'] = ['between', [date('Y-01-01 00:00:00', strtotime($timeData[0])), date('Y-12-31 23:59:59', strtotime($timeData[0]))]];
|
||
|
|
break;
|
||
|
|
default:
|
||
|
|
return $this->msg(10005); // 无效的时间数据格式
|
||
|
|
}
|
||
|
|
// 使用查询构造器进行查询
|
||
|
|
$result = Db::name($this->vitalcapacity_db_name['vitalcapacity'])->where($map)->field('id,one_val,two_val,three_val,average_val,score_val,aud_id,record_time,DATEPART(hour, record_time) AS hour,DATEPART(day, record_time) AS day,DATEPART(month, record_time) AS month')->order('record_time')->select();
|
||
|
|
$return_data = [];
|
||
|
|
if(count($timeData) == 3){
|
||
|
|
$key_condition = 'hour';
|
||
|
|
}else if(count($timeData) == 2){
|
||
|
|
$key_condition = 'day';
|
||
|
|
}else if(count($timeData) == 1){
|
||
|
|
$key_condition = 'month';
|
||
|
|
}
|
||
|
|
foreach ($this->curve_data_format as $key => $value) {
|
||
|
|
$temporary_arr['title'] = $value[0].'('.$value[1].')';
|
||
|
|
$temporary_arr['key'] = $key;
|
||
|
|
$temporary_arr['line']['categories'] = [];
|
||
|
|
$temporary_arr['line']['series'][0]['color'] = $value[2];
|
||
|
|
$temporary_arr['line']['series'][0]['name'] = $value[0].'('.$value[1].')';
|
||
|
|
$temporary_arr['line']['series'][0]['data'] = [];
|
||
|
|
foreach ($result as $k => $v) {
|
||
|
|
if($key_condition == 'hour'){
|
||
|
|
if(in_array($result[$k][$key_condition].'时',$temporary_arr['line']['categories'])){
|
||
|
|
|
||
|
|
$num = array_search($result[$k][$key_condition].'时', $temporary_arr['line']['categories']);
|
||
|
|
// $temporary_arr['line']['series'][0]['data'][$num] = bcadd($temporary_arr['line']['series'][0]['data'][$num],$result[$k][$key],2);
|
||
|
|
$temporary_arr['line']['series'][0]['data'][$num] = $temporary_arr['line']['series'][0]['data'][$num] >= $result[$k][$key]?$temporary_arr['line']['series'][0]['data'][$num]:$result[$k][$key];
|
||
|
|
|
||
|
|
}else{
|
||
|
|
array_push($temporary_arr['line']['categories'],$result[$k][$key_condition].'时');
|
||
|
|
array_push($temporary_arr['line']['series'][0]['data'],$result[$k][$key]);
|
||
|
|
}
|
||
|
|
}else if($key_condition == 'day'){
|
||
|
|
if(in_array($result[$k]['month'].'-'.$result[$k][$key_condition],$temporary_arr['line']['categories'])){
|
||
|
|
$num = array_search($result[$k]['month'].'-'.$result[$k][$key_condition], $temporary_arr['line']['categories']);
|
||
|
|
// $temporary_arr['line']['series'][0]['data'][$num] = bcadd($temporary_arr['line']['series'][0]['data'][$num],$result[$k][$key],2);
|
||
|
|
$temporary_arr['line']['series'][0]['data'][$num] = $temporary_arr['line']['series'][0]['data'][$num] >= $result[$k][$key]?$temporary_arr['line']['series'][0]['data'][$num]:$result[$k][$key];
|
||
|
|
}else{
|
||
|
|
array_push($temporary_arr['line']['categories'],$result[$k]['month'].'-'.$result[$k][$key_condition]);
|
||
|
|
array_push($temporary_arr['line']['series'][0]['data'],$result[$k][$key]);
|
||
|
|
}
|
||
|
|
}else{
|
||
|
|
if(in_array($result[$k]['month'].'月',$temporary_arr['line']['categories'])){
|
||
|
|
$num = array_search($result[$k]['month'].'月', $temporary_arr['line']['categories']);
|
||
|
|
// $temporary_arr['line']['series'][0]['data'][$num] = bcadd($temporary_arr['line']['series'][0]['data'][$num],$result[$k][$key],2);
|
||
|
|
$temporary_arr['line']['series'][0]['data'][$num] = $temporary_arr['line']['series'][0]['data'][$num] >= $result[$k][$key]?$temporary_arr['line']['series'][0]['data'][$num]:$result[$k][$key];
|
||
|
|
}else{
|
||
|
|
array_push($temporary_arr['line']['categories'],$result[$k]['month'].'月');
|
||
|
|
array_push($temporary_arr['line']['series'][0]['data'],$result[$k][$key]);
|
||
|
|
}
|
||
|
|
}
|
||
|
|
}
|
||
|
|
array_push($return_data,$temporary_arr);
|
||
|
|
}
|
||
|
|
return $this->msg($return_data);
|
||
|
|
}
|
||
|
|
public function record_list_page_or_group_action($data,$type){
|
||
|
|
$return_result = [];
|
||
|
|
|
||
|
|
if($type == 'group'){
|
||
|
|
$data['s_time'] = $data['s_time'].' 00:00:00';
|
||
|
|
$data['e_time'] = $data['e_time'].' 23:59:59';
|
||
|
|
$result = Db::query("
|
||
|
|
select
|
||
|
|
id,
|
||
|
|
CONVERT(varchar(10), record_time, 120) AS r_t,
|
||
|
|
CONVERT(varchar(19), record_time, 120) AS record_time,
|
||
|
|
one_val as v1,
|
||
|
|
two_val as v2,
|
||
|
|
three_val as v3,
|
||
|
|
average_val as v4,
|
||
|
|
score as v5
|
||
|
|
from ".$this->vitalcapacity_db_name['vitalcapacity']."
|
||
|
|
where aud_id='".$data['aud_id']."'
|
||
|
|
and record_time between '".$data['s_time']."' and '".$data['e_time']."'
|
||
|
|
and is_del = 0
|
||
|
|
order by record_time desc");
|
||
|
|
foreach ($result as $key => $value) {
|
||
|
|
// $time_t = $this->handle_hour_branch_second($value['v2']);
|
||
|
|
array_push($return_result, [
|
||
|
|
'id'=>$value['id'],
|
||
|
|
'v1'=>$value['v1'] == '.00'?'0':$value['v1'],
|
||
|
|
'v2'=>$value['v2'] == '.00'?'0':$value['v2'],
|
||
|
|
'v3'=>$value['v3'] == '.00'?'0':$value['v3'],
|
||
|
|
'v4'=>$value['v4'] == '.00'?'0':$value['v4'],
|
||
|
|
'v5'=>explode(',',$value['v5'])[0],
|
||
|
|
'v1_name'=>'第一次',
|
||
|
|
'v2_name'=>'第二次',
|
||
|
|
'v3_name'=>'第三次',
|
||
|
|
'v4_name'=>'平均',
|
||
|
|
'v5_name'=>'成绩',
|
||
|
|
// 'r_t'=>str_replace('-', '/', $value['r_t'])
|
||
|
|
'r_t'=>$value['r_t']
|
||
|
|
]);
|
||
|
|
}
|
||
|
|
}else{
|
||
|
|
$result = Db::table($this->vitalcapacity_db_name['vitalcapacity'])->where(['aud_id'=>$data['aud_id'],'is_del'=>0])->field("id,record_time,REPLACE(record_time, '-', '-') AS b_time,one_val,two_val,three_val,average_val,score")->order('record_time desc')->page($data['page'],$this->pagesize)->select();
|
||
|
|
$return_result['totalrows'] = Db::table($this->vitalcapacity_db_name['vitalcapacity'])->where(['aud_id'=>$data['aud_id']])->count();
|
||
|
|
$return_result['rows'] = [];
|
||
|
|
$return_result['pageno'] = $data['page'];
|
||
|
|
$return_result['pagesize'] = $this->pagesize;
|
||
|
|
$return_result['totalpage'] = ceil($return_result['totalrows']/$this->pagesize);
|
||
|
|
foreach ($result as $key => $value) {
|
||
|
|
// $time_t = $this->handle_hour_branch_second($value['jump_time']);
|
||
|
|
array_push($return_result['rows'],[
|
||
|
|
'id'=>$value['id'],
|
||
|
|
'v1'=>$value['one_val'] == '.00'?'0':$value['one_val'],
|
||
|
|
'v2'=>$value['two_val'] == '.00'?'0':$value['two_val'],
|
||
|
|
'v3'=>$value['three_val'] == '.00'?'0':$value['three_val'],
|
||
|
|
'v4'=>$value['average_val'] == '.00'?'0':$value['average_val'],
|
||
|
|
'v5'=>explode(',',$value['score'])[0],
|
||
|
|
'v1_name'=>'第一次',
|
||
|
|
'v2_name'=>'第二次',
|
||
|
|
'v3_name'=>'第三次',
|
||
|
|
'v4_name'=>'平均',
|
||
|
|
'v5_name'=>'成绩',
|
||
|
|
'record_time'=>$value['b_time']
|
||
|
|
]);
|
||
|
|
}
|
||
|
|
}
|
||
|
|
return $this->msg($return_result);
|
||
|
|
}
|
||
|
|
public function get_all_detaile_data_action($data){
|
||
|
|
|
||
|
|
$result = $result = Db::table($this->vitalcapacity_db_name['vitalcapacity'])->where(['id'=>$data['id'],'is_del'=>0])->find();
|
||
|
|
$for_data_arr = ['one_val'=>['第一次','ml'],'two_val'=>['第二次','ml'],'three_val'=>['第三次','ml'],'average_val'=>['三次平均','ml'],'score'=>['最后成绩','分']];
|
||
|
|
if($result){
|
||
|
|
$result_data = [];
|
||
|
|
foreach ($for_data_arr as $key => $value) {
|
||
|
|
$temporary_arr['key_name'] = $key;
|
||
|
|
$temporary_arr['name'] = $value[0];
|
||
|
|
$temporary_arr['value'] = explode(',',$result[$key])[0];
|
||
|
|
$temporary_arr['unit'] = $value[1];
|
||
|
|
array_push($result_data,$temporary_arr);
|
||
|
|
}
|
||
|
|
return $this->msg($result_data);
|
||
|
|
}else{
|
||
|
|
return $this->msg(10002);
|
||
|
|
}
|
||
|
|
|
||
|
|
}
|
||
|
|
|
||
|
|
################################################################内部调用################################################################
|
||
|
|
################################################################内部调用################################################################
|
||
|
|
// 肺活量判断区间
|
||
|
|
public function vitalcapacity_standard_interval($val,$data){
|
||
|
|
// 缓存一周
|
||
|
|
$result = '';
|
||
|
|
if(!$data || count($data) <= 0){
|
||
|
|
return $result;
|
||
|
|
}
|
||
|
|
$temporary_qj = $data;
|
||
|
|
$max = 0;
|
||
|
|
$min = 0;
|
||
|
|
$num = 0;
|
||
|
|
foreach ($temporary_qj as $key => $value) {
|
||
|
|
if($val >= $value['min_val'] && $val <= $value['max_val']){
|
||
|
|
$max = $value['max_val'];
|
||
|
|
$min = $value['min_val'];
|
||
|
|
$num = $key;
|
||
|
|
break;
|
||
|
|
}
|
||
|
|
}
|
||
|
|
|
||
|
|
$num = count($temporary_qj)-1-$num;
|
||
|
|
|
||
|
|
if($max == 0){
|
||
|
|
if($val >= $temporary_qj[0]['max_val']){
|
||
|
|
$result = 100;
|
||
|
|
}
|
||
|
|
}else{
|
||
|
|
$temporary_num = bcmul(bcdiv(bcsub($val,$min,20),bcsub($max,$min,20),2),bcdiv(100,count($temporary_qj),2),2);
|
||
|
|
$result = bcadd(bcmul(bcdiv(100,count($temporary_qj),2),$num,2),$temporary_num,2);
|
||
|
|
}
|
||
|
|
return $result;
|
||
|
|
}
|
||
|
|
// 肺活量判断区间(根据得分)
|
||
|
|
public function vitalcapacity_standard_interval2($val,$data){
|
||
|
|
// 缓存一周
|
||
|
|
$result = '';
|
||
|
|
if(count($data) <= 0){
|
||
|
|
return $result;
|
||
|
|
}
|
||
|
|
$temporary_qj = $data;
|
||
|
|
$max = 0;
|
||
|
|
$min = 0;
|
||
|
|
$num = 0;
|
||
|
|
foreach ($temporary_qj as $key => $value) {
|
||
|
|
if($val >= $value['min_val'] && $val <= $value['max_val']){
|
||
|
|
$max = $value['max_val'];
|
||
|
|
$min = $value['min_val'];
|
||
|
|
$num = $key;
|
||
|
|
break;
|
||
|
|
}
|
||
|
|
}
|
||
|
|
// 计算每份占比
|
||
|
|
$share_value = bcdiv($temporary_qj[0]['max_val'],count($temporary_qj),1);
|
||
|
|
// 计算在这一段中占多少
|
||
|
|
$result = bcsub($val,$min,1);
|
||
|
|
$result = bcdiv($result,bcsub($max,$min,1),1);
|
||
|
|
$num = count($temporary_qj)-1-$num;
|
||
|
|
$num = bcmul($num,$share_value,1);
|
||
|
|
$result = bcadd($num,$result,1);
|
||
|
|
// $num = count($temporary_qj)-1-$num;
|
||
|
|
// $temporary_num = bcmul(bcdiv(bcsub($val,$min,20),bcsub($max,$min,20),2),bcdiv(100,count($temporary_qj),2),2);
|
||
|
|
// $result = bcadd(bcmul(bcdiv(100,count($temporary_qj),2),$num,2),$temporary_num,2);
|
||
|
|
|
||
|
|
return $result;
|
||
|
|
}
|
||
|
|
|
||
|
|
|
||
|
|
}
|