CSS::SpriteMaker
in Action!
London.pm Technical Meeting
London, Thursday, 19 September 2013
Savio Dimatteo
Perl Developer
Nestoria Property Search
What is a CSS Image Sprite?
image containing smaller images
+
CSS rules to render each smaller image
Example of Image Sprite
chess.png
Example of associated CSS rule set
.white-king-ico,.chess-ico,.white-knight-ico,.white-queen-ico,.chess-board-ico,.white-pawn-ico,.
black-queen-2d-ico,.white-bishop-ico,.black-king-2d-ico,.white-castle-ico { background-image: url
('chess.png'); background-repeat: no-repeat; }
.white-king-ico { background-position: 0px 0px; width: 256px; height: 256px; }
.chess-ico { background-position: -256px 0px; width: 256px; height: 256px; }
.white-knight-ico { background-position: 0px -256px; width: 256px; height: 256px; }
.white-queen-ico { background-position: -256px -256px; width: 256px; height: 256px; }
.chess-board-ico { background-position: -512px 0px; width: 256px; height: 256px; }
.white-pawn-ico { background-position: -512px -256px; width: 256px; height: 256px; }
.black-queen-2d-ico { background-position: 0px -512px; width: 256px; height: 256px; }
.white-bishop-ico { background-position: -256px -512px; width: 256px; height: 256px; }
.black-king-2d-ico { background-position: -512px -512px; width: 256px; height: 256px; }
.white-castle-ico { background-position: -768px 0px; width: 256px; height: 256px; }
style.css
<html>
<head>
<title>CSS::SpriteMaker Technique</title>
<link rel="stylesheet" type="text/css" href="style.css">
</head>
<body>
<div class="white-knight-ico" />
</body>
</html>
Example of technique
<html>
<head>
<title>CSS::SpriteMaker Technique</title>
<link rel="stylesheet" type="text/css" href="style.css">
</head>
<body>
<img src="spacer.png" class="white-knight-ico" />
</body>
</html>
Example of technique
Making a Sprite
● Online batch generators
● WYSIWYG online tools
● Command-line tools written in
Java/Ruby/Python… and only recently in
Perl!
○ CSS::SpriteBuilder
CSS::SpriteMaker in Action
CSS::SpriteMaker in Action
CSS::SpriteMaker in Action
CSS::SpriteMaker in Action
CSS::SpriteMaker in Action
CSS::SpriteMaker in Action
CSS::SpriteMaker in Action
CSS::SpriteMaker in Action
CSS::SpriteMaker in Action
CSS::SpriteMaker in Action
Remove Padding
Remove Padding
Group icons: same kind same row
Group icons: same kind same row
Group icons: Nestoria map markers
Group icons: two icons per row
Group icons: two icons per row
Advanced Layouts
+
=
?
Advanced Layouts
Advanced Layouts
Advanced Layouts
Advanced Layouts
Advanced Layouts
Advanced Layouts
Advanced Layouts - Packed
Advanced Layouts - FixedDimension
Advanced Layouts - DirectoryBased
CSS Class Generation
● based on file name of input image
○ no characters collide with CSS syntax
● collisions
○ input image file name: “alice.png”
○ input image file name: “alice.gif”
○ result: .alice .alice-1
CSS Class Names Generation
CSS Sprite Viewer
…
…
CSS Sprite Viewer
Perl Modules Used
● File::Find
○ discover input images
● Module::Pluggable
○ for pluggable layouts
● Image::Magick
○ read/write/identify images
Questions?
● twitter.com/darksmo
● www.savio.dimatteo.it/talks
● github.com/darksmo
● github.com/lokku
London.pm Technical Meeting
London, Thursday, 19 September 2013
CSS::SpriteMaker
in Action!
W
e’re
hiring!
www.lokku.com
/jobs

More Related Content

PDF
Pruebas mostrando pdf's
PPTX
Introduction to GraphQL in Scala (ScalaMatsuri 2017)
PDF
Welcome! RGBA
PDF
Icosmith.com
KEY
CSS and CSS3
PPT
The path ahead for property portals
PDF
Bar Camp London 7
PPTX
Geo-Data for Search Marketing SEM & SEO
Pruebas mostrando pdf's
Introduction to GraphQL in Scala (ScalaMatsuri 2017)
Welcome! RGBA
Icosmith.com
CSS and CSS3
The path ahead for property portals
Bar Camp London 7
Geo-Data for Search Marketing SEM & SEO

Similar to CSS::SpriteMaker in action! (20)

PDF
Css sprite_maker-1
PDF
Dead Pixel: A Practical Guide to Attacking Server-Side Image Processors (BSid...
PDF
Adobe MAX 2008: HTML/CSS + Fireworks
PDF
3 ways-to-create-sprites-in-rails
PDF
HTML5 after the hype - JFokus2015
PDF
CSS :has() Unlimited Power
PPTX
Images meet Web
PDF
Intro to CSS3
KEY
Sass, Compass and the new tools - Open Web Camp IV
PDF
Minimalism in Web Development
PDF
Refresh Tallahassee: The RE/MAX Front End Story
PDF
Eye Candy Without Images: Fun With CSS3
PDF
CSS3: Ripe and Ready
PDF
Simply Responsive CSS3
PDF
建立前端開發團隊 - 2011 中華電信訓練所版
PDF
CSS3: Ripe and Ready to Respond
PDF
Илья Пухальский (EPAM Systems)
PDF
Type-safe front-end development with Scala
PPTX
About Best friends - HTML, CSS and JS
PDF
Drawing a Circle Three Ways: Generating Graphics for the Web
Css sprite_maker-1
Dead Pixel: A Practical Guide to Attacking Server-Side Image Processors (BSid...
Adobe MAX 2008: HTML/CSS + Fireworks
3 ways-to-create-sprites-in-rails
HTML5 after the hype - JFokus2015
CSS :has() Unlimited Power
Images meet Web
Intro to CSS3
Sass, Compass and the new tools - Open Web Camp IV
Minimalism in Web Development
Refresh Tallahassee: The RE/MAX Front End Story
Eye Candy Without Images: Fun With CSS3
CSS3: Ripe and Ready
Simply Responsive CSS3
建立前端開發團隊 - 2011 中華電信訓練所版
CSS3: Ripe and Ready to Respond
Илья Пухальский (EPAM Systems)
Type-safe front-end development with Scala
About Best friends - HTML, CSS and JS
Drawing a Circle Three Ways: Generating Graphics for the Web
Ad

More from lokku (20)

PDF
Geocoding Overview
PDF
OpenCage Data and sustainable business models for open data
PDF
Presenting the OpenCage Geocoder at #londonapi 17 Sept 2014
PDF
A living hell - lessons learned in eight years of parsing real estate data
PPTX
Geo-search-location-based-results-for-site-search
PDF
Geocoding India - talk delivered on 31 Jan 2014 at the Bangalore goeBLR event
PDF
Nestoria new design
PDF
Reducing the technical hurdle - why we started OpenCage Data
PPTX
Nestoria case study - The effective use of geo-data for search marketing
PDF
The Nestoria GeoChallenge
PDF
Making using OSM data simpler - OpenCage Data
PDF
What’s next in mapping for portals? ppw2012
PDF
How Nestoria switched to OpenStreetMap maps
PPT
Remote Geocoding
PDF
Lessons learned in doing lots with few people
PDF
Mapstraction
PDF
How People Search For Locations
PDF
Arbyte - A modular, flexible, scalable job queing and execution system
PPT
Planning for Debugging
PDF
YAPC::Europe 2008 - Mike Astle - Profiling
Geocoding Overview
OpenCage Data and sustainable business models for open data
Presenting the OpenCage Geocoder at #londonapi 17 Sept 2014
A living hell - lessons learned in eight years of parsing real estate data
Geo-search-location-based-results-for-site-search
Geocoding India - talk delivered on 31 Jan 2014 at the Bangalore goeBLR event
Nestoria new design
Reducing the technical hurdle - why we started OpenCage Data
Nestoria case study - The effective use of geo-data for search marketing
The Nestoria GeoChallenge
Making using OSM data simpler - OpenCage Data
What’s next in mapping for portals? ppw2012
How Nestoria switched to OpenStreetMap maps
Remote Geocoding
Lessons learned in doing lots with few people
Mapstraction
How People Search For Locations
Arbyte - A modular, flexible, scalable job queing and execution system
Planning for Debugging
YAPC::Europe 2008 - Mike Astle - Profiling
Ad

Recently uploaded (20)

PDF
Accessing-Finance-in-Jordan-MENA 2024 2025.pdf
PDF
CloudStack 4.21: First Look Webinar slides
PDF
How IoT Sensor Integration in 2025 is Transforming Industries Worldwide
DOCX
Basics of Cloud Computing - Cloud Ecosystem
PDF
Hybrid horned lizard optimization algorithm-aquila optimizer for DC motor
PDF
UiPath Agentic Automation session 1: RPA to Agents
PPTX
AI IN MARKETING- PRESENTED BY ANWAR KABIR 1st June 2025.pptx
PDF
A contest of sentiment analysis: k-nearest neighbor versus neural network
PDF
A proposed approach for plagiarism detection in Myanmar Unicode text
PDF
A review of recent deep learning applications in wood surface defect identifi...
PPTX
Microsoft Excel 365/2024 Beginner's training
PPT
Geologic Time for studying geology for geologist
PDF
Architecture types and enterprise applications.pdf
PPTX
The various Industrial Revolutions .pptx
PPTX
TEXTILE technology diploma scope and career opportunities
PPTX
Final SEM Unit 1 for mit wpu at pune .pptx
PDF
How ambidextrous entrepreneurial leaders react to the artificial intelligence...
PDF
Consumable AI The What, Why & How for Small Teams.pdf
PDF
sustainability-14-14877-v2.pddhzftheheeeee
PPTX
Module 1 Introduction to Web Programming .pptx
Accessing-Finance-in-Jordan-MENA 2024 2025.pdf
CloudStack 4.21: First Look Webinar slides
How IoT Sensor Integration in 2025 is Transforming Industries Worldwide
Basics of Cloud Computing - Cloud Ecosystem
Hybrid horned lizard optimization algorithm-aquila optimizer for DC motor
UiPath Agentic Automation session 1: RPA to Agents
AI IN MARKETING- PRESENTED BY ANWAR KABIR 1st June 2025.pptx
A contest of sentiment analysis: k-nearest neighbor versus neural network
A proposed approach for plagiarism detection in Myanmar Unicode text
A review of recent deep learning applications in wood surface defect identifi...
Microsoft Excel 365/2024 Beginner's training
Geologic Time for studying geology for geologist
Architecture types and enterprise applications.pdf
The various Industrial Revolutions .pptx
TEXTILE technology diploma scope and career opportunities
Final SEM Unit 1 for mit wpu at pune .pptx
How ambidextrous entrepreneurial leaders react to the artificial intelligence...
Consumable AI The What, Why & How for Small Teams.pdf
sustainability-14-14877-v2.pddhzftheheeeee
Module 1 Introduction to Web Programming .pptx

CSS::SpriteMaker in action!