header("Content-Type", $mimetype); // 直接显示二维码 // header('Content-Type: ' . $qrcode_service->getContentType()); // $response->content($qrcode_service->writeString()); $qrcodePath = ROOT_PATH . 'public/uploads/qrcode/'; if (!is_dir($qrcodePath)) { @mkdir($qrcodePath); } if (is_really_writable($qrcodePath)) { $filename = md5(implode('', $params)) . '.png'; $filePath = $qrcodePath . $filename; $qrcode_service->writeFile($filePath); } return '/uploads/qrcode/' . $filename; } //生成视频分享海报 public function shareposter() { $inviteimage = $this->inviteimage($this->auth->introcode); $data = [ [ "left"=> "140px", "top"=> "120px", "type"=> "img", "width"=> "50px", "height"=> "50px", "src"=> localpath_to_netpath($this->auth->avatar)//"https://metavision.oss-cn-hongkong.aliyuncs.com/uploads/20220615/f00cb545deb4c4e7296f444239d83e84.jpg" ], [ "left"=> "95px", "top"=> "190px", "type"=> "nickname", "width"=> "166px", "height"=> "38px", "size"=> "11px", "color"=> "#FFFFFF", "content" => '这里真心不错,推荐你来', ], [ "left"=> "105px", "top"=> "400px", "type"=> "nickname", "width"=> "166px", "height"=> "38px", "size"=> "11px", "color"=> "#333333", "content" => '邀请码:'.$this->auth->introcode, ], [ "left"=> "100px", "top"=> "265px", "type"=> "img", "width"=> "130px", "height"=> "130px", "src"=> httpurllocal($inviteimage)//"https://metavision.oss-cn-hongkong.aliyuncs.com/uploads/20220615/f00cb545deb4c4e7296f444239d83e84.jpg" ], ]; $data = json_encode($data, 320); $poster = [ 'id' => 1, 'title' => '测试', 'waittext' => '您的专属海报正在拼命生成中,请等待片刻...', 'bg_image' => '/assets/img/posteruserbg.png', 'data' => $data, 'status' => 'normal', 'weigh' => 0, 'createtime' => 1653993709, 'updatetime' => 1653994259, ]; $image = new \addons\poster\library\Image(); $imgurl = $image->createPosterImage($poster, $this->auth->getUser()); if (!$imgurl) { $this->error('生成海报出错'); } $imgurl = $_SERVER["REQUEST_SCHEME"]."://".$_SERVER["HTTP_HOST"] . '/' . $imgurl; //echo ''; $this->success('', $imgurl); } //我的收益 public function myprofit(){ //今日 $start = strtotime(date('Y-m-d')); $end = $start + 86399; //收益type $profit_type = [21,22,23,52,54,56]; //今日收益 $map = [ 'log_type' => ['IN',$profit_type], 'user_id' => $this->auth->id, 'createtime' => ['between',[$start,$end]], ]; $today_profit = Db::name('user_money_log')->where($map)->sum('change_value'); //今日视频时长 $map = [ 'user_id|to_user_id' => $this->auth->id, 'createtime' => ['between',[$start,$end]], ]; $today_video_min = Db::name('user_match_video_log')->where($map)->count(); //今日语音时长 $map = [ 'user_id|to_user_id' => $this->auth->id, 'createtime' => ['between',[$start,$end]], ]; $today_audio_min = Db::name('user_match_audio_log')->where($map)->count(); //本周收益 $week_start = strtotime(date('Y-m-d')) - ((date('w')==0?7:date('w'))-1)*86400; $week_end = $week_start + 604799; $map = [ 'log_type' => ['IN',$profit_type], 'user_id' => $this->auth->id, 'createtime' => ['between',[$week_start,$week_end]], ]; $week_profit = Db::name('user_money_log')->where($map)->sum('change_value'); //我的累计收益 $map = [ 'log_type' => ['IN',$profit_type], 'user_id' => $this->auth->id, ]; $all_profit = Db::name('user_money_log')->where($map)->sum('change_value'); //我的邀请 $my_intro_number = Db::name('user')->where('intro_uid',$this->auth->id)->count('id'); $result = [ 'avatar' => $this->auth->avatar, 'nickname' => $this->auth->nickname, 'username' => $this->auth->username, 'today_profit' => $today_profit, 'today_video_min' => $today_video_min, 'today_audio_min' => $today_audio_min, 'week_profit' => $week_profit, 'all_profit' => $all_profit, 'my_intro_number' => $my_intro_number, ]; $this->success('success',$result); } //我邀请的,成员今日收益 public function myintro(){ $map = [ 'intro_uid' => $this->auth->id, ]; $list = Db::name('user')->field('id,nickname,username,avatar')->where($map)->page($this->page,$this->listrow)->select(); $rs = []; foreach($list as $key => $user){ $rs[] = $this->profit($user); } //dump($rs); $this->success('success',$rs); } //收益数据 private function profit($userinfo){ $uid = $userinfo['id']; //今日 $start = strtotime(date('Y-m-d')); $end = $start + 86399; //收益type $profit_type = [21,22,23,52,54,56]; //今日收益 $map = [ 'log_type' => ['IN',$profit_type], 'user_id' => $uid, 'createtime' => ['between',[$start,$end]], ]; $today_profit = Db::name('user_money_log')->where($map)->sum('change_value'); //今日视频时长 $map = [ 'user_id|to_user_id' => $uid, 'createtime' => ['between',[$start,$end]], ]; $today_video_min = Db::name('user_match_video_log')->where($map)->count('id'); //今日语音时长 $map = [ 'user_id|to_user_id' => $uid, 'createtime' => ['between',[$start,$end]], ]; $today_audio_min = Db::name('user_match_audio_log')->where($map)->count('id'); //本周收益 $week_start = strtotime(date('Y-m-d')) - ((date('w')==0?7:date('w'))-1)*86400; $week_end = $week_start + 604799; $map = [ 'log_type' => ['IN',$profit_type], 'user_id' => $uid, 'createtime' => ['between',[$week_start,$week_end]], ]; $week_profit = Db::name('user_money_log')->where($map)->sum('change_value'); $result = [ 'today_profit' => $today_profit, 'today_video_min' => $today_video_min, 'today_audio_min' => $today_audio_min, 'week_profit' => $week_profit, ]; $result = array_merge($result,$userinfo); return $result; } }