The approach can be detailed as such, create your sprite map, use a wrapping div with hidden overflow, and then use an img tag with nothing but percentage based widths and margins and you have yourself a responsive SEO friendly sprite map. One important detail that I have experienced is that as the image scales to very small levels, then top and bottom percentages get a little off. One potential workaround if this is a problem is to add some transparent padding at the top and bottom of each block. My example does not, so you will see a little bit of sprite bleeding. Now the html / css:
<div class="responsive-sprite" style="width: 5%;"> <img alt="Yay for alt tags..." src="your-pic.png" /> </div> <style> img { width: 100%; margin-top: -96%; margin-bottom: -391%; } .responsive-sprite { overflow: hidden; } </style>
Which produces the result:
data:image/s3,"s3://crabby-images/d65b8/d65b86811167f0f0f172319f3d19f54648754464" alt="Yay for alt tags"
data:image/s3,"s3://crabby-images/7ebea/7ebea2c9857d734b924d7c591248b1e9e2dc3a2e" alt=""
As always questions and feedback are welcomed and I'll be sure to update with anything else I learn!
UPDATE: After several comments and time/help from a coworker. We were able to figure out a computational way to determine the percentages. It turns out that it is:
(sprite-height / sprite-width) * -100 = Base Percentage
Then for margin-top, it is the (nth - 1 sprite) * Base Percentage.
The for margin-bottom it is (sprite_count - nth_sprite) * Base Percentage.
Hope that works for everyone!