0.0
No release in over 3 years
Low commit activity in last 3 years
Picturesque exposes a simple API for resizing images
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
 Dependencies
 Project Readme

Picturesque

Picturesque is an engine for resizing and formatting images on the fly. It makes generating responsive images a snap:

<%= picturesque_image_tag(image, slug: image.slug, alt: image.name, size: '160x160') %>
<img
  alt="Steve Jobs and Bill Gates"
  height=160
  width=160
  src="https://.../picturesque/.../160x160/steve-jobs-and-bill-gates.jpg"
  srcset="https://.../picturesque/.../160x160/steve-jobs-and-bill-gates.jpg 1x,
          https://.../picturesque/.../320x320/steve-jobs-and-bill-gates.jpg 2x,
          https://.../picturesque/.../480x480/steve-jobs-and-bill-gates.jpg 3x"
/>

Requirements

The gem is tested with:

  • Ruby on Rails 4.2.5.1
  • Ruby 2.3.0
  • JRuby 9.0.4.0

Installation

gem install picturesque

Additional

brew install imagemagick

Configuration

# config/initializers/picturesque.rb
Picturesque.setup do |config|
  config.find = -> (params) { Picturesque::Image.new(Image.find(params[:id]).url) }
end

Examples

Migration

rails g model image url:string name:string
class CreateImage < ActiveRecord::Migration
  def self.up
    create_table :images do |t|
      t.string :url, presence: true, index: { unique: true }
      t.string :name, presence: true, index: { unique: true }

      t.timestamps
    end
  end

  def self.down
    drop_table :images
  end
end

Model

class Image < ActiveRecord::Base
  validates :name, presence: true, uniqueness: true
  validates :url, presence: true, uniqueness: true

  def slug
    name.parameterize if name
  end
end

View

<%- @images.each do |image| -%>
<%= picturesque_image_tag(image, slug: image.slug, alt: image.name, size: '160x160') %>
<%- end -%>

Copyright

Copyright (c) 2014 - 2020 Kevin Sylvestre. See LICENSE for details.