diff options
author | Janko Marohnić <janko.marohnic@gmail.com> | 2018-04-23 12:21:42 +0200 |
---|---|---|
committer | Janko Marohnić <janko.marohnic@gmail.com> | 2018-04-23 12:21:42 +0200 |
commit | 7fc8b6d82cd82440558664e4f2d82d6933d4cba3 (patch) | |
tree | 2f979b1aea4ff2ffd2962e13b764d7537cd4cc84 | |
parent | 0d811fd4826e9a8b3d493a32d1315b681263ad3f (diff) | |
download | rails-7fc8b6d82cd82440558664e4f2d82d6933d4cba3.tar.gz rails-7fc8b6d82cd82440558664e4f2d82d6933d4cba3.tar.bz2 rails-7fc8b6d82cd82440558664e4f2d82d6933d4cba3.zip |
Show ImageProcessing macros in a dedicated example
-rw-r--r-- | activestorage/app/models/active_storage/variant.rb | 25 | ||||
-rw-r--r-- | activestorage/test/models/variant_test.rb | 16 |
2 files changed, 25 insertions, 16 deletions
diff --git a/activestorage/app/models/active_storage/variant.rb b/activestorage/app/models/active_storage/variant.rb index 8ee9e75d6b..b880b8fbff 100644 --- a/activestorage/app/models/active_storage/variant.rb +++ b/activestorage/app/models/active_storage/variant.rb @@ -19,16 +19,15 @@ require "active_storage/downloading" # Rails.application.config.active_storage.variant_processor = :vips # # => :vips # -# Note that to create a variant it's necessary to download the entire blob file from the service and load it -# into memory. The larger the image, the more memory is used. Because of this process, you also want to be -# considerate about when the variant is actually processed. You shouldn't be processing variants inline in a -# template, for example. Delay the processing to an on-demand controller, like the one provided in -# ActiveStorage::RepresentationsController. +# Note that to create a variant it's necessary to download the entire blob file from the service. The larger +# the image, the more memory is used. Because of this process, you also want to be considerate about when the variant +# is actually processed. You shouldn't be processing variants inline in a template, for example. Delay the processing +# to an on-demand controller, like the one provided in ActiveStorage::RepresentationsController. # # To refer to such a delayed on-demand variant, simply link to the variant through the resolved route provided # by Active Storage like so: # -# <%= image_tag Current.user.avatar.variant(resize_to_fit: [100, 100]) %> +# <%= image_tag Current.user.avatar.variant(resize: "100x100") %> # # This will create a URL for that specific blob with that specific variant, which the ActiveStorage::RepresentationsController # can then produce on-demand. @@ -37,22 +36,22 @@ require "active_storage/downloading" # has already been processed and uploaded to the service, and, if so, just return that. Otherwise it will perform # the transformations, upload the variant to the service, and return itself again. Example: # -# avatar.variant(resize_to_fit: [100, 100]).processed.service_url +# avatar.variant(resize: "100x100").processed.service_url # # This will create and process a variant of the avatar blob that's constrained to a height and width of 100. # Then it'll upload said variant to the service according to a derivative key of the blob and the transformations. # -# Variant options are forwarded directly to the ImageProcessing gem. Visit the following links for a list of -# available ImageProcessing commands and processor operations: +# You can combine any number of ImageMagick/libvips operations into a variant. In addition to that, you can also use +# any macros provided by the ImageProcessing gem (such as +resize_to_limit+). +# +# avatar.variant(resize_to_limit: [800, 800], monochrome: true, flip: "-90") +# +# Visit the following links for a list of available ImageProcessing commands and ImageMagick/libvips operations: # # * {ImageProcessing::MiniMagick}[https://github.com/janko-m/image_processing/blob/master/doc/minimagick.md#methods] # * {ImageMagick reference}[https://www.imagemagick.org/script/mogrify.php] # * {ImageProcessing::Vips}[https://github.com/janko-m/image_processing/blob/master/doc/vips.md#methods] # * {ruby-vips reference}[http://www.rubydoc.info/gems/ruby-vips/Vips/Image] -# -# You can combine as many of these options as you like freely: -# -# avatar.variant(resize_to_fit: [100, 100], monochrome: true, flip: "-90") class ActiveStorage::Variant include ActiveStorage::Downloading diff --git a/activestorage/test/models/variant_test.rb b/activestorage/test/models/variant_test.rb index f6b6579d7d..e74bbc9ab4 100644 --- a/activestorage/test/models/variant_test.rb +++ b/activestorage/test/models/variant_test.rb @@ -6,7 +6,7 @@ require "database/setup" class ActiveStorage::VariantTest < ActiveSupport::TestCase test "resized variation of JPEG blob" do blob = create_file_blob(filename: "racecar.jpg") - variant = blob.variant(resize_to_fit: [100, 100]).processed + variant = blob.variant(resize: "100x100").processed assert_match(/racecar\.jpg/, variant.service_url) image = read_image(variant) @@ -16,7 +16,7 @@ class ActiveStorage::VariantTest < ActiveSupport::TestCase test "resized and monochrome variation of JPEG blob" do blob = create_file_blob(filename: "racecar.jpg") - variant = blob.variant(resize_to_fit: [100, 100], monochrome: true).processed + variant = blob.variant(resize: "100x100", monochrome: true).processed assert_match(/racecar\.jpg/, variant.service_url) image = read_image(variant) @@ -25,7 +25,7 @@ class ActiveStorage::VariantTest < ActiveSupport::TestCase assert_match(/Gray/, image.colorspace) end - test "center-weighted crop of JPEG blob" do + test "center-weighted crop of JPEG blob using :combine_options" do begin ActiveStorage.variant_processor = nil blob = create_file_blob(filename: "racecar.jpg") @@ -46,6 +46,16 @@ class ActiveStorage::VariantTest < ActiveSupport::TestCase end end + test "center-weighted crop of JPEG blob using :resize_to_fill" do + blob = create_file_blob(filename: "racecar.jpg") + variant = blob.variant(resize_to_fill: [100, 100]).processed + assert_match(/racecar\.jpg/, variant.service_url) + + image = read_image(variant) + assert_equal 100, image.width + assert_equal 100, image.height + end + test "resized variation of PSD blob" do blob = create_file_blob(filename: "icon.psd", content_type: "image/vnd.adobe.photoshop") variant = blob.variant(resize: "20x20").processed |