aIImageCropProcess.php 6.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283
  1. <?php
  2. require dirname(__FILE__, 2) . '/vendor/autoload.php';
  3. $secretId = "SECRETID"; //替换为用户的 secretId,请登录访问管理控制台进行查看和管理,https://console.cloud.tencent.com/cam/capi
  4. $secretKey = "SECRETKEY"; //替换为用户的 secretKey,请登录访问管理控制台进行查看和管理,https://console.cloud.tencent.com/cam/capi
  5. $region = "ap-beijing"; //替换为用户的 region,已创建桶归属的region可以在控制台查看,https://console.cloud.tencent.com/cos5/bucket
  6. $cosClient = new Qcloud\Cos\Client(
  7. array(
  8. 'region' => $region,
  9. 'scheme' => 'https', //协议头部,默认为http
  10. 'credentials'=> array(
  11. 'secretId' => $secretId,
  12. 'secretKey' => $secretKey)));
  13. try {
  14. // -------------------- 1. 下载时处理-原图存储在COS -------------------- //
  15. $object = 'xxx.jpg';
  16. $ciProcessParams = new Qcloud\Cos\ImageParamTemplate\CIProcessTransformation('AIImageCrop');
  17. $ciProcessParams->addParam('width', 100); // 需要裁剪区域的宽度,与height共同组成所需裁剪的图片宽高比例;输入数字请大于0、小于图片宽度的像素值
  18. $ciProcessParams->addParam('height', 100); // 需要裁剪区域的高度,与width共同组成所需裁剪的图片宽高比例;输入数字请大于0、小于图片高度的像素值;width : height建议取值在[1, 2.5]之间,超过这个范围可能会影响效果
  19. $ciProcessParams->addParam('fixed', 0); // 是否严格按照 width 和 height 的值进行输出。
  20. $ciProcessParams->addParam('ignore-error', 1); // 当此参数为1时,针对文件过大等导致处理失败的场景,会直接返回原图而不报错。
  21. $query = $ciProcessParams->queryString();
  22. $downloadUrl = $cosClient->getObjectUrl('examplebucket-1250000000', $object); // 获取下载链接
  23. echo "{$downloadUrl}&{$query}"; // 携带签名的图片地址以“&”连接
  24. // -------------------- 1. 下载时处理-原图存储在COS -------------------- //
  25. // -------------------- 2. 下载时处理-原图来自其他链接 -------------------- //
  26. $ciProcessParams = new Qcloud\Cos\ImageParamTemplate\CIProcessTransformation('AIImageCrop');
  27. $ciProcessParams->addParam('detect-url', 'https://xxx.com/xxx.jpg');
  28. $ciProcessParams->addParam('width', 100); // 需要裁剪区域的宽度,与height共同组成所需裁剪的图片宽高比例;输入数字请大于0、小于图片宽度的像素值
  29. $ciProcessParams->addParam('height', 100); // 需要裁剪区域的高度,与width共同组成所需裁剪的图片宽高比例;输入数字请大于0、小于图片高度的像素值;width : height建议取值在[1, 2.5]之间,超过这个范围可能会影响效果
  30. $ciProcessParams->addParam('fixed', 0); // 是否严格按照 width 和 height 的值进行输出。
  31. $ciProcessParams->addParam('ignore-error', 1); // 当此参数为1时,针对文件过大等导致处理失败的场景,会直接返回原图而不报错。
  32. $query = $ciProcessParams->queryString();
  33. $downloadUrl = $cosClient->getObjectUrl('examplebucket-1250000000', ''); // 获取下载链接
  34. echo "{$downloadUrl}&{$query}";
  35. // -------------------- 2. 下载时处理-原图来自其他链接 -------------------- //
  36. // ---------------------------- 3. 上传时处理 ---------------------------- //
  37. $ciProcessParams = new Qcloud\Cos\ImageParamTemplate\CIProcessTransformation('AIImageCrop');
  38. $ciProcessParams->addParam('width', 100); // 需要裁剪区域的宽度,与height共同组成所需裁剪的图片宽高比例;输入数字请大于0、小于图片宽度的像素值
  39. $ciProcessParams->addParam('height', 100); // 需要裁剪区域的高度,与width共同组成所需裁剪的图片宽高比例;输入数字请大于0、小于图片高度的像素值;width : height建议取值在[1, 2.5]之间,超过这个范围可能会影响效果
  40. $ciProcessParams->addParam('fixed', 0); // 是否严格按照 width 和 height 的值进行输出。
  41. $ciProcessParams->addParam('ignore-error', 1); // 当此参数为1时,针对文件过大等导致处理失败的场景,会直接返回原图而不报错。
  42. $picOperations = new Qcloud\Cos\ImageParamTemplate\PicOperationsTransformation();
  43. $picOperations->setIsPicInfo(1); // is_pic_info
  44. $picOperations->addRule($ciProcessParams, "output.png"); // rules
  45. $result = $cosClient->putObject(array(
  46. 'Bucket' => 'examplebucket-125000000', //存储桶名称,由BucketName-Appid 组成,可以在COS控制台查看 https://console.cloud.tencent.com/cos5/bucket
  47. 'Key' => 'object.jpg',
  48. 'Body' => fopen('/tmp/local.jpg', 'rb'), // 本地文件
  49. 'PicOperations' => $picOperations->queryString(),
  50. ));
  51. // 请求成功
  52. print_r($result);
  53. // ---------------------------- 3. 上传时处理 ---------------------------- //
  54. // --------------------- 4. 云上数据处理 ------------------------------ //
  55. $ciProcessParams = new Qcloud\Cos\ImageParamTemplate\CIProcessTransformation('AIImageCrop');
  56. $ciProcessParams->addParam('width', 100); // 需要裁剪区域的宽度,与height共同组成所需裁剪的图片宽高比例;输入数字请大于0、小于图片宽度的像素值
  57. $ciProcessParams->addParam('height', 100); // 需要裁剪区域的高度,与width共同组成所需裁剪的图片宽高比例;输入数字请大于0、小于图片高度的像素值;width : height建议取值在[1, 2.5]之间,超过这个范围可能会影响效果
  58. $ciProcessParams->addParam('fixed', 0); // 是否严格按照 width 和 height 的值进行输出。
  59. $ciProcessParams->addParam('ignore-error', 1); // 当此参数为1时,针对文件过大等导致处理失败的场景,会直接返回原图而不报错。
  60. $picOperations = new Qcloud\Cos\ImageParamTemplate\PicOperationsTransformation();
  61. $picOperations->setIsPicInfo(1); // is_pic_info
  62. $picOperations->addRule($ciProcessParams, 'output.jpg'); // rules
  63. $result = $cosClient->ImageProcess(array(
  64. 'Bucket' => 'examplebucket-1250000000', //存储桶名称,由BucketName-Appid 组成,可以在COS控制台查看 https://console.cloud.tencent.com/cos5/bucket
  65. 'Key' => 'test.jpg',
  66. 'PicOperations' => $picOperations->queryString(),
  67. ));
  68. // 请求成功
  69. print_r($result);
  70. // --------------------- 4. 云上数据处理 ------------------------------ //
  71. } catch (\Exception $e) {
  72. // 请求失败
  73. echo($e);
  74. }