當前位置: 首頁>>代碼示例>>PHP>>正文


PHP Gdn_Upload::parse方法代碼示例

本文整理匯總了PHP中Gdn_Upload::parse方法的典型用法代碼示例。如果您正苦於以下問題:PHP Gdn_Upload::parse方法的具體用法?PHP Gdn_Upload::parse怎麽用?PHP Gdn_Upload::parse使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在Gdn_Upload的用法示例。


在下文中一共展示了Gdn_Upload::parse方法的6個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。

示例1: generateUrl

 /**
  * Generate a Gravatar image URL based on the provided email address.
  *
  * @link http://en.gravatar.com/site/implement/images/ Gravatar Image Requests
  * @param string $email Email address for the user, used to generate the avatar ID.
  * @param int $size Target image size.
  * @return string A formatted Gravatar image URL.
  */
 public static function generateUrl($email, $size = 80)
 {
     $avatarID = md5(strtolower($email));
     // Figure out our base URLs.  Gravatar doesn't support SVGs, so we're stuck with using Vanillicon v1.
     if (Gdn::request()->scheme() === 'https') {
         $baseUrl = 'https://secure.gravatar.com/avatar';
         $vanilliconBaseUrl = 'https://vanillicon.com';
     } else {
         $baseUrl = 'http://www.gravatar.com/avatar';
         $vanilliconBaseUrl = 'http://vanillicon.com';
     }
     if (c('Plugins.Gravatar.UseVanillicon', true)) {
         // Version 1 of Vanillicon only supports three sizes.  Figure out which one is best for this image.
         if ($size <= 50) {
             $vanilliconSize = 50;
         } elseif ($size <= 100) {
             $vanilliconSize = 100;
         } else {
             $vanilliconSize = 200;
         }
         $default = "{$vanilliconBaseUrl}/{$avatarID}_{$vanilliconSize}.png";
     } else {
         $configuredDefaultAvatar = c('Plugins.Gravatar.DefaultAvatar', c('Garden.DefaultAvatar'));
         if ($configuredDefaultAvatar) {
             $defaultParsed = Gdn_Upload::parse($configuredDefaultAvatar);
             $default = val('Url', $defaultParsed);
         }
     }
     if (empty($default)) {
         $default = asset($size <= 50 ? 'plugins/Gravatar/default.png' : 'plugins/Gravatar/default_250.png', true);
     }
     $query = ['default' => $default, 'rating' => c('Plugins.Gravatar.Rating', 'g'), 'size' => $size];
     return $baseUrl . "/{$avatarID}/?" . http_build_query($query);
 }
開發者ID:vanilla,項目名稱:vanilla,代碼行數:42,代碼來源:default.php

示例2: getImageSize

 /**
  * If passed path leads to an image, return size
  *
  * @param string $Path Path to file.
  * @return array [0] => Height, [1] => Width.
  */
 public static function getImageSize($Path)
 {
     // Static FireEvent for intercepting non-local files.
     $Sender = new stdClass();
     $Sender->Returns = array();
     $Sender->EventArguments = array();
     $Sender->EventArguments['Path'] =& $Path;
     $Sender->EventArguments['Parsed'] = Gdn_Upload::parse($Path);
     Gdn::pluginManager()->callEventHandlers($Sender, 'Gdn_Upload', 'CopyLocal');
     if (!in_array(strtolower(pathinfo($Path, PATHINFO_EXTENSION)), array('gif', 'jpg', 'jpeg', 'png'))) {
         return array(0, 0);
     }
     $ImageSize = @getimagesize($Path);
     if (is_array($ImageSize)) {
         if (!in_array($ImageSize[2], array(IMAGETYPE_GIF, IMAGETYPE_JPEG, IMAGETYPE_PNG))) {
             return array(0, 0);
         }
         return array($ImageSize[0], $ImageSize[1]);
     }
     return array(0, 0);
 }
開發者ID:vanilla,項目名稱:addons,代碼行數:27,代碼來源:class.mediamodel.php

示例3: utilityController_mediaThumbnail_create

 /**
  * Create and display a thumbnail of an uploaded file.
  */
 public function utilityController_mediaThumbnail_create($sender, $media_id)
 {
     // When it makes it into core, it will be available in
     // functions.general.php
     require 'generate_thumbnail.php';
     $model = new Gdn_Model('Media');
     $media = $model->getID($media_id, DATASET_TYPE_ARRAY);
     if (!$media) {
         throw notFoundException('File');
     }
     // Get actual path to the file.
     $local_path = Gdn_Upload::copyLocal($media['Path']);
     if (!file_exists($local_path)) {
         throw notFoundException('File');
     }
     $file_extension = pathinfo($local_path, PATHINFO_EXTENSION);
     // Generate new path for thumbnail
     $thumb_path = $this->getBaseUploadDestinationDir() . '/' . 'thumb';
     // Grab full path with filename, and validate it.
     $thumb_destination_path = $this->getAbsoluteDestinationFilePath($local_path, $file_extension, $thumb_path);
     // Create thumbnail, and grab debug data from whole process.
     $thumb_payload = generate_thumbnail($local_path, $thumb_destination_path, array('height' => c('Plugins.FileUpload.ThumbnailHeight', 128)));
     if ($thumb_payload['success'] === true) {
         // Thumbnail dimensions
         $thumb_height = round($thumb_payload['result_height']);
         $thumb_width = round($thumb_payload['result_width']);
         // Move the thumbnail to its proper location. Calling SaveAs with
         // cloudfiles enabled will trigger the move to cloudfiles, so use
         // same path for each arg in SaveAs. The file will be removed from the local filesystem.
         $parsed = Gdn_Upload::parse($thumb_destination_path);
         $target = $thumb_destination_path;
         // $parsed['Name'];
         $Upload = new Gdn_Upload();
         $filepath_parsed = $Upload->saveAs($thumb_destination_path, $target, array('source' => 'content'));
         // Save thumbnail information to DB.
         $model->save(array('MediaID' => $media_id, 'StorageMethod' => $filepath_parsed['Type'], 'ThumbWidth' => $thumb_width, 'ThumbHeight' => $thumb_height, 'ThumbPath' => $filepath_parsed['SaveName']));
         // Remove cf scratch copy, typically in cftemp, if there was actually a file pulled in from CF.
         if (strpos($local_path, 'cftemp') !== false) {
             if (!unlink($local_path)) {
                 // Maybe add logging for local cf copies not deleted.
             }
         }
         $url = $filepath_parsed['Url'];
     } else {
         // Fix the thumbnail information so this isn't requested again and again.
         $model->save(array('MediaID' => $media_id, 'ImageWidth' => 0, 'ImageHeight' => 0, 'ThumbPath' => ''));
         $url = asset('/plugins/FileUpload/images/file.png');
     }
     redirect($url, 301);
 }
開發者ID:mcnasby,項目名稱:datto-vanilla,代碼行數:53,代碼來源:class.editor.plugin.php

示例4: trashFile

 /**
  * Delete an uploaded file & its media record.
  *
  * @param int $MediaID Unique ID on Media table.
  */
 protected function trashFile($MediaID)
 {
     $Media = $this->mediaModel()->getID($MediaID);
     if ($Media) {
         $this->mediaModel()->delete($Media);
         $Deleted = false;
         // Allow interception
         $this->EventArguments['Parsed'] = Gdn_Upload::parse($Media->Path);
         $this->EventArguments['Handled'] =& $Deleted;
         // Allow skipping steps below
         $this->fireEvent('TrashFile');
         if (!$Deleted) {
             $DirectPath = MediaModel::pathUploads() . DS . $Media->Path;
             if (file_exists($DirectPath)) {
                 $Deleted = @unlink($DirectPath);
             }
         }
         if (!$Deleted) {
             $CalcPath = FileUploadPlugin::findLocalMedia($Media, true, true);
             if (file_exists($CalcPath)) {
                 @unlink($CalcPath);
             }
         }
     }
 }
開發者ID:vanilla,項目名稱:addons,代碼行數:30,代碼來源:class.fileupload.plugin.php

示例5: saveImageAs

 /**
  * Saves the specified image at $Target in the specified format with the
  * specified dimensions (or the existing dimensions if height/width are not provided.
  *
  * @param string The path to the source image. Typically this is the tmp file name returned by $this->ValidateUpload();
  * @param string The full path to where the image should be saved, including image name.
  * @param int An integer value indicating the maximum allowed height of the image (in pixels).
  * @param int An integer value indicating the maximum allowed width of the image (in pixels).
  * @param array Options additional options for saving the image.
  *  - <b>Crop</b>: Image proportions will always remain constrained. The Crop parameter is a boolean value indicating if the image should be cropped when one dimension (height or width) goes beyond the constrained proportions.
  *  - <b>OutputType</b>: The format in which the output image should be saved. Options are: jpg, png, and gif. Default is jpg.
  *  - <b>ImageQuality</b>: An integer value representing the qualityof the saved image. Ranging from 0 (worst quality, smaller file) to 100 (best quality, biggest file).
  *  - <b>SourceX, SourceY</b>: If you want to create a thumbnail that is a crop of the image these are the coordinates of the thumbnail.
  *  - <b>SourceHeight. SourceWidth</b>: If you want to create a thumbnail that is a crop of the image these are it's dimensions.
  */
 public static function saveImageAs($Source, $Target, $Height = '', $Width = '', $Options = array())
 {
     $Crop = false;
     $OutputType = '';
     $ImageQuality = c('Garden.UploadImage.Quality', 100);
     // Make function work like it used to.
     $Args = func_get_args();
     $SaveGif = false;
     if (count($Args) > 5) {
         $Crop = val(4, $Args, $Crop);
         $OutputType = val(5, $Args, $OutputType);
         $ImageQuality = val(6, $Args, $ImageQuality);
     } elseif (is_bool($Options)) {
         $Crop = $Options;
     } else {
         $Crop = val('Crop', $Options, $Crop);
         $OutputType = val('OutputType', $Options, $OutputType);
         $ImageQuality = val('ImageQuality', $Options, $ImageQuality);
         $SaveGif = val('SaveGif', $Options);
     }
     // Set some boundaries for $ImageQuality
     if ($ImageQuality < 10) {
         $ImageQuality = 10;
     }
     if ($ImageQuality > 100 || !is_numeric($ImageQuality)) {
         $ImageQuality = 100;
     }
     // Make sure type, height & width are properly defined.
     if (!function_exists('gd_info')) {
         throw new Exception(T('The uploaded file could not be processed because GD is not installed.'));
     }
     $GdInfo = gd_info();
     $Size = getimagesize($Source);
     list($WidthSource, $HeightSource, $Type) = $Size;
     $WidthSource = val('SourceWidth', $Options, $WidthSource);
     $HeightSource = val('SourceHeight', $Options, $HeightSource);
     if ($Height == '' || !is_numeric($Height)) {
         $Height = $HeightSource;
     }
     if ($Width == '' || !is_numeric($Width)) {
         $Width = $WidthSource;
     }
     if (!$OutputType) {
         $OutputTypes = array(1 => 'gif', 2 => 'jpeg', 3 => 'png', 17 => 'ico');
         $OutputType = val($Type, $OutputTypes, 'jpg');
     } elseif ($Type == 17 && $OutputType != 'ico') {
         // Icons cannot be converted
         throw new Exception(T('Upload cannot convert icons.'));
     }
     // Figure out the target path.
     $TargetParsed = Gdn_Upload::parse($Target);
     $TargetPath = PATH_UPLOADS . '/' . ltrim($TargetParsed['Name'], '/');
     if (!file_exists(dirname($TargetPath))) {
         mkdir(dirname($TargetPath), 0777, true);
     }
     // Don't resize if the source dimensions are smaller than the target dimensions or an icon
     $XCoord = val('SourceX', $Options, 0);
     $YCoord = val('SourceY', $Options, 0);
     if (($HeightSource > $Height || $WidthSource > $Width) && $Type != 17) {
         $AspectRatio = (double) $WidthSource / $HeightSource;
         if ($Crop === false) {
             if (round($Width / $AspectRatio) > $Height) {
                 $Width = round($Height * $AspectRatio);
             } else {
                 $Height = round($Width / $AspectRatio);
             }
         } else {
             $HeightDiff = $HeightSource - $Height;
             $WidthDiff = $WidthSource - $Width;
             if ($WidthDiff > $HeightDiff) {
                 // Crop the original width down
                 $NewWidthSource = round($Width * $HeightSource / $Height);
                 // And set the original x position to the cropped start point.
                 if (!isset($Options['SourceX'])) {
                     $XCoord = round(($WidthSource - $NewWidthSource) / 2);
                 }
                 $WidthSource = $NewWidthSource;
             } else {
                 // Crop the original height down
                 $NewHeightSource = round($Height * $WidthSource / $Width);
                 // And set the original y position to the cropped start point.
                 if (!isset($Options['SourceY'])) {
                     $YCoord = 0;
                     // crop to top because most portraits show the face at the top.
                 }
//.........這裏部分代碼省略.........
開發者ID:sitexa,項目名稱:vanilla,代碼行數:101,代碼來源:class.uploadimage.php

示例6: isUploadUri

 /**
  * Determine if a URI matches the format of a valid type/domain upload.
  *
  * @param string $uri The URI to test. This would be the value saved in the database (ex. GDN_User.Photo).
  * @return bool Returns **true** if {@link uri} looks like an uploaded file or **false** otherwise.
  */
 public static function isUploadUri($uri)
 {
     $parsed = Gdn_Upload::parse($uri);
     return !empty($parsed['Url']) && val('Type', $parsed) !== 'external';
 }
開發者ID:vanilla,項目名稱:vanilla,代碼行數:11,代碼來源:class.upload.php


注:本文中的Gdn_Upload::parse方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。