Making all photos square via css

后端 未结 6 1982
忘掉有多难
忘掉有多难 2021-02-07 06:50

I\'m trying to make a series of photos into square photos. They may be rectangular horizontally (i.e. 600x400) or vertically (400x600), but I want to get them to be 175x175 eit

相关标签:
6条回答
  • 2021-02-07 06:57

    Okay I got this.

    Don't know if it's too late or what, but I've come up with a 100% pure CSS way of creating square thumbnails. It's something that I've been trying to find a solution for for quite a while and have had no luck. With some experimentation, I've got it working. The main two attributes to use are OVERFLOW:HIDDEN and WIDTH/HEIGHT:AUTO.

    Okay here's what to do:

    Let's say you have a batch of images of varying shapes and sizes, some landscape, some portrait, but all, of course, rectangular. The first thing to do is categorize the image links (thumbnails) by either portrait or landscape, using a class selector. Okay, so let's say you want just to create two thumbnails, to make this simpler. you have:

    img1.jpg (portrait) and img2.jpg (landscape)

    For HTML it would look like this:

    <a class="portrait" href="yoursite/yourimages/img1.jpg"><img src="yoursite/yourimages/img1.jpg /></a>
    <a class="landscape" href="yoursite/yourimages/img2.jpg"><img src="yoursite/yourimages/img2.jpg /></a>
    

    So, at this point since there is no css yet, the above code would give you your full-sized image as a thumbnail which would link to the same full-sized image. Right, so here's the css for both portrait and landscape. There are two declarations for each (the link and the link's image):

    .landscape {
            float:left;
            width:175px;     
            height:175px;    
            overflow:hidden;    
        }
    
    .landscape  img{
            width:auto;
            height: 175px;   
        }
    
    .portrait {
            float:left;
            width:175px;
            height:175px;
            overflow:hidden;    
        }
    
    .portrait img {
            width:175px;    <-- notice these
            height: auto;   <-- have switched
        }
    

    The most important things are the width and height and the overflow:hidden. Float left isn't necessary for this to work.

    In the landscape thumbnail declaration (.landscape) the bounding box is set to 175 x 175 and the overflow is set to hidden. That means that any visual information larger than that containing 175px square will be hidden from view.

    For the landscape image declaration (.landscape img), the height is fixed at 175px, which resizes the original height and the width is set to auto, which resizes the original width, but only to the point of relating to the bounding square, which in this case is 175px. So rather than smush the width down into the square, it simply fills the square and then any extra visual information in the width (i.e. the overflow) is hidden with the overflow:hidden.

    It works the same way for portrait, only that the width and height is switched, where height is auto and width is 175px. Basically in each case, whatever dimension exceeds the other is set to auto, because naturally the larger dimension would be the one that would overflow outside of the set thumbnail dimensions (175px x 175x).

    And if you want to add margins between thumbs, for instance a 5px white margin, you can use the border property, otherwise there will be no margin where the information is overflowing.

    Hope this makes sense.

    0 讨论(0)
  • 2021-02-07 06:57

    Determine width and height of image, then active portrait or landscape class of the image. If portrait do {height:175px; width:auto}. If landscape, reverse height and width.

    0 讨论(0)
  • 2021-02-07 07:08

    You can use object-fit, which is widely supported in all major browsers. When set to cover, the browser will crop the image when you set the width and height properties, rather the stretching it.

    <img src="whatever.jpg">
    
    img {
      width: 175px;
      height: 175px;
      object-fit: cover;
    }
    
    0 讨论(0)
  • 2021-02-07 07:12

    You can set the width/height of the parent div then set the child img tag to width:100%; height: auto;

    That will scale the image down to try to fit the parent with aspect ratio in mind.

    You can also set the image as a background-image on the div Then if you can use css3 you can mess with the background-size property. It's attributes are: contain, cover, or a specificed height (50%, 50%) (175px, 175px) You could also try to center the picture with background-position

    <div style="background-image:url(some.png); background-size: cover; background-position: 50%">
    
    0 讨论(0)
  • 2021-02-07 07:15

    This might help.

    CSS:

    .image{
    -moz-border-radius: 30px; /* FF1+ */
    -webkit-border-radius: 30px; /* Saf3-4 */
    border-radius: 30px; /* Opera 10.5, IE 9, Saf5, Chrome */
    }
    

    HTML:

    <div class="image"></div>
    

    This worked for me. Just put the URL to the image inside the div.

    0 讨论(0)
  • 2021-02-07 07:20

    I highly suggestion the NailThumb jquery plugin for anyone that is looking to do this. It allows you to create square thumbnails without distortion. http://www.garralab.com/nailthumb.php

    0 讨论(0)
提交回复
热议问题