solved Image sizes

SteveX
SteveX
@ultrajam
11 years ago
2,584 posts
Are any of the following possible?

1. crop to height (eg all images are 150px high)
2. output to a fixed ratio other than square (eg 16x9 crop)
3. output a fixed sized crop (eg 300px x 200px)

Thanks


--
¯\_(ツ)_/¯ Education, learning resources, TEL, AR/VR/MR, CC licensed content, panoramas, interactive narrative, sectional modules (like jrDocs), lunch at Uni of Bristol. Get in touch if you share my current interests or can suggest better :)

updated by @ultrajam: 05/30/14 08:03:24AM
brian
@brian
11 years ago
10,149 posts
1) Use the "medium" size and just set the height to 150 in the HTML - i.e.

{jrCore_module_function function="jrImage_display" module="jrProfile" type="profile_image" item_id=$row._profile_id size="medium" alt=$row.profile_name title=$row.profile_name height=150}

2) Same as #1 - just define the width as well

3) If you're specifically looking for a crop that crops BOTH height and width, then no. There is a new "fill" crop that will basically letterbox the image so it appears as the right size.

All Jamroom's crop's result in a square image however.

Hope this helps!


--
Brian Johnson
Founder and Lead Developer - Jamroom
https://www.jamroom.net
SteveX
SteveX
@ultrajam
11 years ago
2,584 posts
Setting a height doesn't appear to be working at all (both in the jrImage_display function and on the url)

Quote: All Jamroom's crop's result in a square image however.
Any plans to add other common aspect ratios? Or is there any way to override this with a listener?
I think it could do with something to ensure photos are presented well, otherwise you get a lot of this squished type of look: http://demo.jamroom.net/jrPhotoPro/galleries


--
¯\_(ツ)_/¯ Education, learning resources, TEL, AR/VR/MR, CC licensed content, panoramas, interactive narrative, sectional modules (like jrDocs), lunch at Uni of Bristol. Get in touch if you share my current interests or can suggest better :)
SteveX
SteveX
@ultrajam
11 years ago
2,584 posts
Fill mode looks good, but when I try that on a portrait oriented image I see only a black square (no image visible)
/blog/image/blog_image/18/large/crop=fill/
It's on localhost, sorry.


--
¯\_(ツ)_/¯ Education, learning resources, TEL, AR/VR/MR, CC licensed content, panoramas, interactive narrative, sectional modules (like jrDocs), lunch at Uni of Bristol. Get in touch if you share my current interests or can suggest better :)
brian
@brian
11 years ago
10,149 posts
SteveX:
Setting a height doesn't appear to be working at all (both in the jrImage_display function and on the url)

We use it here on jamroom.net and I'm not seeing an issue. It has to work on the img tag, otherwise your browser would be broken...

SteveX:
Fill mode looks good, but when I try that on a portrait oriented image I see only a black square (no image visible)
/blog/image/blog_image/18/large/crop=fill/

If it's all black, that would be a bug - can you send me the image so I can test it here?

Thanks!
17banksyES_468x606.jpg




--
Brian Johnson
Founder and Lead Developer - Jamroom
https://www.jamroom.net

updated by @brian: 04/21/14 08:21:33AM
brian
@brian
11 years ago
10,149 posts
I'm not seeing any issue with the fill crop here:

https://www.jamroom.net/forum/image/forum_file/10465/xxxlarge/crop=fill

Hope it was OK to just upload it here for testing...

Thanks!


--
Brian Johnson
Founder and Lead Developer - Jamroom
https://www.jamroom.net
SteveX
SteveX
@ultrajam
11 years ago
2,584 posts
Image sent, but I think you already fixed it, I was looking at a dev site with jrImage 1.1.3. It doesn't happen on a site with jrImage 1.1.4.


--
¯\_(ツ)_/¯ Education, learning resources, TEL, AR/VR/MR, CC licensed content, panoramas, interactive narrative, sectional modules (like jrDocs), lunch at Uni of Bristol. Get in touch if you share my current interests or can suggest better :)
SteveX
SteveX
@ultrajam
11 years ago
2,584 posts
I still can't set a height on 1.1.4 though
{jrCore_module_function function="jrImage_display" module=jrBlog type=blog_image item_id=1 size=large class="img-responsivecd" alt="test" height="100" crop="fill"}

If I set width="100" that works, but not when setting a height.


--
¯\_(ツ)_/¯ Education, learning resources, TEL, AR/VR/MR, CC licensed content, panoramas, interactive narrative, sectional modules (like jrDocs), lunch at Uni of Bristol. Get in touch if you share my current interests or can suggest better :)
brian
@brian
11 years ago
10,149 posts
Since a crop always results in square image, only width is used if a crop parameter is supplied. So just do "width" 100 and it will work.

Hope this helps!


--
Brian Johnson
Founder and Lead Developer - Jamroom
https://www.jamroom.net
SteveX
SteveX
@ultrajam
11 years ago
2,584 posts
Ah I see.

But height still doesn't work when not cropping.


--
¯\_(ツ)_/¯ Education, learning resources, TEL, AR/VR/MR, CC licensed content, panoramas, interactive narrative, sectional modules (like jrDocs), lunch at Uni of Bristol. Get in touch if you share my current interests or can suggest better :)
brian
@brian
11 years ago
10,149 posts
SteveX:
Ah I see.

But height still doesn't work when not cropping.

Hmm.. height/width should both be working. I'm looking at the code, and it looks correct. Let me setup a test template here and see if I can see what is up.


--
Brian Johnson
Founder and Lead Developer - Jamroom
https://www.jamroom.net
brian
@brian
11 years ago
10,149 posts
I just tested with this here:

{jrCore_module_function function="jrImage_display" module="jrProfile" type="profile_image" item_id="61" size="large" alt="test" height="100"}

and it is working. I would recommend always putting quotes around any parameters that take a string as a value.


--
Brian Johnson
Founder and Lead Developer - Jamroom
https://www.jamroom.net
SteveX
SteveX
@ultrajam
11 years ago
2,584 posts
Definitely not working here even with quotes. Core 5.1.37, jrImage 1.1.4, no classes or styles. Changing the height appears to do nothing at all.

  {jrCore_module_function function="jrImage_display" module="jrBlog" type="blog_image" item_id="1" size="large" alt="test" height="100"}
 
  {jrCore_module_function function="jrImage_display" module="jrProfile" type="profile_image" item_id="1" size="large" alt="test" height="100"}
  
  {jrCore_module_function function="jrImage_display" module="jrProfile" type="profile_image" item_id="1" size="large" alt="test" height="200"}
image-sizes.png
image-sizes.png  •  381KB




--
¯\_(ツ)_/¯ Education, learning resources, TEL, AR/VR/MR, CC licensed content, panoramas, interactive narrative, sectional modules (like jrDocs), lunch at Uni of Bristol. Get in touch if you share my current interests or can suggest better :)

updated by @ultrajam: 04/21/14 09:50:31AM
brian
@brian
11 years ago
10,149 posts
I see both width and height being set in the HTML... so it's coming out of JR properly.


--
Brian Johnson
Founder and Lead Developer - Jamroom
https://www.jamroom.net
SteveX
SteveX
@ultrajam
11 years ago
2,584 posts
Ok, so that's actually 1, 2 and 3 which aren't possible.

What I'm trying to do is set up a skin, preferably not limited to square images so its also suitable for photos, films and video, but where images are not displayed squished. I can't find a way to achieve that at all. Any ideas?


--
¯\_(ツ)_/¯ Education, learning resources, TEL, AR/VR/MR, CC licensed content, panoramas, interactive narrative, sectional modules (like jrDocs), lunch at Uni of Bristol. Get in touch if you share my current interests or can suggest better :)
brian
@brian
11 years ago
10,149 posts
SteveX:
Ok, so that's actually 1, 2 and 3 which aren't possible.

What I'm trying to do is set up a skin, preferably not limited to square images so its also suitable for photos, films and video, but where images are not displayed squished. I can't find a way to achieve that at all. Any ideas?

You should be able to just set the height OR width - not both - and then select a "size" that is just over what you need, then it will maintain the aspect ratio of the image. That should work.


--
Brian Johnson
Founder and Lead Developer - Jamroom
https://www.jamroom.net
brian
@brian
11 years ago
10,149 posts
Actually looking at the code, you need to specifically set the height or width to false depending on what one you do not want - i.e.

width=200 height=false

Let me know if that helps


--
Brian Johnson
Founder and Lead Developer - Jamroom
https://www.jamroom.net
SteveX
SteveX
@ultrajam
11 years ago
2,584 posts
No, the height doesn't appear to be working, even with width=false


--
¯\_(ツ)_/¯ Education, learning resources, TEL, AR/VR/MR, CC licensed content, panoramas, interactive narrative, sectional modules (like jrDocs), lunch at Uni of Bristol. Get in touch if you share my current interests or can suggest better :)
brian
@brian
11 years ago
10,149 posts
Yeah something else is adding the width/height in - let me see if I can figure it out.


--
Brian Johnson
Founder and Lead Developer - Jamroom
https://www.jamroom.net
brian
@brian
11 years ago
10,149 posts
OK this should be fixed now - update to the Image Support module 1.1.6 and let me know if you see any issues.

Thanks!


--
Brian Johnson
Founder and Lead Developer - Jamroom
https://www.jamroom.net
SteveX
SteveX
@ultrajam
11 years ago
2,584 posts
Ok thanks Brian. I'll update later tonight (when the isp works best, 3am).

But I must say, I expect I won't find a way to do what I want with images. If it were possible, you'd have used it on the PhotoPro skin demo - it looks a nice enough skin, but the galleries list and detail pages look terrible with the current demo content. Squished images on a website/demo are a complete turnoff for anyone who knows what an aspect ratio is. Or do Paul's band really look like that? Hmmm, that's a possibility I guess ;)


--
¯\_(ツ)_/¯ Education, learning resources, TEL, AR/VR/MR, CC licensed content, panoramas, interactive narrative, sectional modules (like jrDocs), lunch at Uni of Bristol. Get in touch if you share my current interests or can suggest better :)
brian
@brian
11 years ago
10,149 posts
SteveX:
Ok thanks Brian. I'll update later tonight (when the isp works best, 3am).

But I must say, I expect I won't find a way to do what I want with images. If it were possible, you'd have used it on the PhotoPro skin demo - it looks a nice enough skin, but the galleries list and detail pages look terrible with the current demo content. Squished images on a website/demo are a complete turnoff for anyone who knows what an aspect ratio is. Or do Paul's band really look like that? Hmmm, that's a possibility I guess ;)

Resizing images has always been an issue - there's really no solution to handling photos which may come in all different shapes and sizes. I will check out the photo pro skin - we may have overlooked adding some crops in places.

The "fill" crop was designed to hopefully help the issue, as it maintains the aspect ratio of the image, but guarantees the resulting images will all be the same size.

If you have suggestions, I'm all ears ;)

Thanks!


--
Brian Johnson
Founder and Lead Developer - Jamroom
https://www.jamroom.net
SteveX
SteveX
@ultrajam
11 years ago
2,584 posts
Hmm, I'm still figuring out what jr does with images, and outside jr figuring out what's what with responsive images and device sizes looks difficult at the moment - its still in a state of flux. So I'm just guessing now... maybe a long guess... maybe a ramble...

Square images in Elastic, Nova etc are pretty much perfect for music sites. And since height does work jr has you covered for horizontally filling a grid of mixed images as well as vertically in columns.

But there is no way (that I can see) to achieve regular columns or grids of rectangular images like the galleries list on PhotoPro - that's a really common layout for blogs, portfolio sites, feature articles, etc.

So my guess is that adding a few more aspect ratios would be the best improvement: A landscape photo, a television screen (16:9), a portrait photo (book covers, posters), and a wider banner/supercinemascope rectangle. All of them "best crop to cover" where you can specify width or height, but the main thing would be to make them as simple as "square" images are in jr5 - they're perfect.

If it were more complex for users than a straightforward square, photo, tv, book, banner choice, then maybe best to stick with things as they are. Not many questions about aspect ratios on the forum, and no comments about the image docs not being that helpful, so it looks like jr5 users are pretty content with their perfect squares that thye don't need to think about, makes sense.

But it would be such a crime if Jamroom became widely known for it's Square look. JR5, the squarest of them all, cms of choice to square aficionados throughout the square (round) media packaging music industry.

Square images define the look of all the jr skins, defines the look of jr. PhotoPro does that differently, but I don't think it will be a big seller because of the demo - I know I'm probably over-sensitive to aspect ratios and squishing, but if I were looking for a photo gallery solution and saw that demo (with any visible degree of squishing at all) I'd close the tab and look at the next link within 5 secs = approx as interesting to any media pro as any gallery app named "SqueeyarePhoto". imo

One more viable aspect ration in jr5 would change the possibilities for looks for jr5 skins immediately. Square/rectangle. If it were me I'd fix the PhotoPro gallery list view first, and use crop=fill to fix the gallery detail grid (can you define the background colour for the fill? - that was my very first thought when I saw the new fill mode).

I know I've jsut burbled, but it did make sense to me on rereading, so publish and be damned. click


--
¯\_(ツ)_/¯ Education, learning resources, TEL, AR/VR/MR, CC licensed content, panoramas, interactive narrative, sectional modules (like jrDocs), lunch at Uni of Bristol. Get in touch if you share my current interests or can suggest better :)
michael
@michael
11 years ago
7,800 posts
huh? you don't like/want square images? You could loop your cols over class="row" to vertically align them.

So if you had 4-4-4 layout then just add a new row for each set
image-image-image
image-image-image
image-image-image
image-image-image

The class="row" will keep the tops of the images in alignment and let the images be as tall as you need without running into that float:left image height issue.
SteveX
SteveX
@ultrajam
11 years ago
2,584 posts
Don't get me wrong, I love the square images, they are perfect for music sites but don't entirely fit the bill for a skin like PhotoPro when users are uploading the content.

Have you tried that bootstrap 3 grid without closing each row? - having all grid items in one row allows you to have different numbers of items show in the row at different breakpoints:
class="col-6-xs col-4-sm col-3-md col-2-lg"
Its awesome with square images.


--
¯\_(ツ)_/¯ Education, learning resources, TEL, AR/VR/MR, CC licensed content, panoramas, interactive narrative, sectional modules (like jrDocs), lunch at Uni of Bristol. Get in touch if you share my current interests or can suggest better :)
michael
@michael
11 years ago
7,800 posts
Haven't tried it, is there a demo somewhere?
SteveX
SteveX
@ultrajam
11 years ago
2,584 posts
{jrCore_include template="header.tpl"}
{*http://www.bootply.com/129266*}
<div class="container-fluid">

  <div class="row">
    	<div class="col-xs-12 col-sm-8 col-md-6 col-lg-4"><img src="//placehold.it/650x370" class="img-responsive"></div>
    	<div class="col-xs-6 col-sm-4 col-md-3 col-lg-2">1</div>
        <div class="col-xs-6 col-sm-4 col-md-3 col-lg-2">2</div>
  		<div class="col-xs-6 col-sm-4 col-md-3 col-lg-2">3</div>
        <div class="col-xs-6 col-sm-4 col-md-3 col-lg-2">4</div>
    	<div class="col-xs-6 col-sm-4 col-md-3 col-lg-2">5</div>
        <div class="col-xs-6 col-sm-4 col-md-3 col-lg-2">6</div>
    	<div class="col-xs-6 col-sm-4 col-md-3 col-lg-2">7</div>
        <div class="col-xs-6 col-sm-4 col-md-3 col-lg-2">8</div>
    	<div class="col-xs-6 col-sm-4 col-md-3 col-lg-2">9</div>
        <div class="col-xs-6 col-sm-4 col-md-3 col-lg-2">10</div>
    	<div class="col-xs-6 col-sm-4 col-md-3 col-lg-2">11</div>
  </div>
  
</div>

<style type="text/css">
.col-xs-6 {
	min-height:125px;
    background-color:#55ddff;
}

</style>

{jrCore_include template="footer.tpl"}

If you need clearing at different breakpoints you can add a clearfix and leave it hidden except at a specific breakpoint:
http://getbootstrap.com/examples/grid/
<div class="row">
        <div class="col-xs-6 col-sm-3">
          .col-xs-6 .col-sm-3
          <br>
          Resize your viewport or check it out on your phone for an example.
        </div>
        <div class="col-xs-6 col-sm-3">.col-xs-6 .col-sm-3</div>

        <!-- Add the extra clearfix for only the required viewport -->
        <div class="clearfix visible-xs"></div>

        <div class="col-xs-6 col-sm-3">.col-xs-6 .col-sm-3</div>
        <div class="col-xs-6 col-sm-3">.col-xs-6 .col-sm-3</div>
      </div>



--
¯\_(ツ)_/¯ Education, learning resources, TEL, AR/VR/MR, CC licensed content, panoramas, interactive narrative, sectional modules (like jrDocs), lunch at Uni of Bristol. Get in touch if you share my current interests or can suggest better :)
douglas
@douglas
11 years ago
2,804 posts
Would it make more sense if I said the PhotoPro skin was setup more for photograph size/shaped images and not square ones?

The images uploaded to the PhotoPro demo are not the size or shape I would expect someone to upload to a "photo" site, they are just duplicates of whats on the rest of the demos, ie. MediaPro etc... so they really don't fit well with the PhotoPro demo. I imagined the images uploaded to this type of site to be the size and shape of an actual photograph.

I know this doesn't probably help much, but thought I should explain why the demo images look the way they do.

Hope this helps,
Douglas


--

Douglas Hackney
Jamroom Team - Designer/Developer/Support
FAQ-Docs-Help Videos
SteveX
SteveX
@ultrajam
11 years ago
2,584 posts
Thanks Douglas, that does make sense.

Size and shape are rarely a problem for a site owner uploading content, they will be preparing their images, and photo pros will be batch processing their galleries anyway. If only users would do the same.

Sooo many people don't even seem to notice squishing. For several years after getting their first widescreen tv my parents were quite happy watching a short, fat version of their video tapes. I showed them where the button to change it was, but I guess they were perfectly happy watching shorter, fatter people. My Dad was a keen soccer fan though, and I still don't get how he could be happy watching a game with an OVAL BALL!!!

Maybe I'm just overly sensitive to squishing. Hopefully we'll see thousands of PhotoPro skinned sites managing aspect ratios for themselves without difficulty.


--
¯\_(ツ)_/¯ Education, learning resources, TEL, AR/VR/MR, CC licensed content, panoramas, interactive narrative, sectional modules (like jrDocs), lunch at Uni of Bristol. Get in touch if you share my current interests or can suggest better :)
brian
@brian
11 years ago
10,149 posts
Ideally the Jamroom image support should be able to handle photos in any aspect ratio. It's important to know any time you change the aspect ratio, you are going to get some vertical or horizontal compression of the image (squishing) - there is just no way around that. This is where cropping comes in - the idea being we can (hopefully) crop any uploaded image to fit into the display container aspect ratio, without removing the important part of the image.

I believe right now the image support is setup to handle pretty much anything you can throw at it, and get it to "fit in" wherever needed, but I'm open to additional crop options if that's not the case.

Thanks!


--
Brian Johnson
Founder and Lead Developer - Jamroom
https://www.jamroom.net
SteveX
SteveX
@ultrajam
11 years ago
2,584 posts
Apart from abstract backgrounds maybe, you should never see a distorted image displayed anywhere (not sure if that's the job of the skin or the core) - noticeable distortion always looks bad, whilst a close crop sometimes looks good. But it's just my opinion, people dont seem to mind a bit of squishing.

Its just that this looks more PhotoPro to me:


--
¯\_(ツ)_/¯ Education, learning resources, TEL, AR/VR/MR, CC licensed content, panoramas, interactive narrative, sectional modules (like jrDocs), lunch at Uni of Bristol. Get in touch if you share my current interests or can suggest better :)

updated by @ultrajam: 04/22/14 02:38:28PM
brian
@brian
11 years ago
10,149 posts
SteveX:
Apart from abstract backgrounds maybe, you should never see a distorted image displayed anywhere

I'm all ears - how do you accomplish that when you have specific aspect ratio set by the skin (say 4 images across, each in 4x3 ratio) and you have 4 different images, all uploaded by users, each at a different aspect ratio?

It's easy to say how it should work, but I've been doing this for over 10 years and have yet to find a perfect solution that works 100% of the time for 100% of images.

Thanks!


--
Brian Johnson
Founder and Lead Developer - Jamroom
https://www.jamroom.net
SteveX
SteveX
@ultrajam
11 years ago
2,584 posts
Nothing will work perfectly for 100% of all images until image saliency (facial recognition, horizon, etc) is taken into account which is years away, but surely different aspect ratios (16:9, 4:3) work in the same way that crop to square (1:1) works?

I could be wrong, definitely being foolish in trying to explain it , but looking at imagecopyresampled, wouldn't it work like this?:

imagecopyresampled($image['handle'], $image['source'], $hnd_x_offset, $hnd_y_offset, $src_x_offset, $src_y_offset, $new_width, $new_height, $src_width, $src_height)


Instead of $new_width : $new_height and $src_width : $src_height both being 1 : 1, they can both be 4 : 3, or 16 : 9
As long as $new_width : $new_height and $src_width : $src_height are the same aspect ratios there will be no distortion, regardless of the aspect ratio of the uploaded image - $src_width and $src_height are not the width and height of the src image, they are the width and height that you are copying out of the src image.

You still need to work out the offsets - $src_x_offset = 0 unless the height hits the boundary, $src_y_offset = 0 unless the width hits the boundary.


Say we have a 1600 x 1200 image and we want a 16:9 crop (160x90) from the center.


$src_width = $actual_source_image_width;
$src_height = ($actual_source_image_width / 16) * 9;
$src_y_offset = ($actual_source_image_height - $src_height) / 2;
$new_width = 160;
$new_height = 90;
$image['handle'] is 160 x 90
$image['source'] is 1600 x 1200

imagecopyresampled($image['handle'], $image['source'], 0, 0, 0, 150, 160, 90, 1600, 900)

A 1200 x 1600 source:
imagecopyresampled($image['handle'], $image['source'], 0, 0, 0, 462, 160, 90, 1200, 675)

A 1200 x 1200 source:
imagecopyresampled($image['handle'], $image['source'], 0, 0, 0, 262, 160, 90, 1200, 675)

A 100 x 100 source:
imagecopyresampled($image['handle'], $image['source'], 0, 0, 0, 22, 160, 90, 100, 56)


I know I'm oversimplifying it, but wouldn't that give a set of 160x90 thumbnail images with no distortion?

A 9:16 portrait from a 100x100 could be similar:
imagecopyresampled($image['handle'], $image['source'], 0, 0, 22, 0, 90, 160, 56, 100)


--
¯\_(ツ)_/¯ Education, learning resources, TEL, AR/VR/MR, CC licensed content, panoramas, interactive narrative, sectional modules (like jrDocs), lunch at Uni of Bristol. Get in touch if you share my current interests or can suggest better :)
SteveX
SteveX
@ultrajam
11 years ago
2,584 posts
http://stackoverflow.com/questions/999250/php-gd-cropping-and-resizing-images

This page has a self contained example which does more of the maths. Change the aspect ratio and size on the last line.

imagetest.php:
<?php
function Image($image, $crop = null, $size = null) {
    $image = ImageCreateFromString(file_get_contents($image));

    if (is_resource($image) === true) {
        $x = 0;
        $y = 0;
        $width = imagesx($image);
        $height = imagesy($image);

        /*
        CROP (Aspect Ratio) Section
        */

        if (is_null($crop) === true) {
            $crop = array($width, $height);
        } else {
            $crop = array_filter(explode(':', $crop));

            if (empty($crop) === true) {
                    $crop = array($width, $height);
            } else {
                if ((empty($crop[0]) === true) || (is_numeric($crop[0]) === false)) {
                        $crop[0] = $crop[1];
                } else if ((empty($crop[1]) === true) || (is_numeric($crop[1]) === false)) {
                        $crop[1] = $crop[0];
                }
            }

            $ratio = array(0 => $width / $height, 1 => $crop[0] / $crop[1]);

            if ($ratio[0] > $ratio[1]) {
                $width = $height * $ratio[1];
                $x = (imagesx($image) - $width) / 2;
            }

            else if ($ratio[0] < $ratio[1]) {
                $height = $width / $ratio[1];
                $y = (imagesy($image) - $height) / 2;
            }

        }

        /*
        Resize Section
        */

        if (is_null($size) === true) {
            $size = array($width, $height);
        }

        else {
            $size = array_filter(explode('x', $size));

            if (empty($size) === true) {
                    $size = array(imagesx($image), imagesy($image));
            } else {
                if ((empty($size[0]) === true) || (is_numeric($size[0]) === false)) {
                        $size[0] = round($size[1] * $width / $height);
                } else if ((empty($size[1]) === true) || (is_numeric($size[1]) === false)) {
                        $size[1] = round($size[0] * $height / $width);
                }
            }
        }

       $result = ImageCreateTrueColor($size[0], $size[1]);

        if (is_resource($result) === true) {
            ImageSaveAlpha($result, true);
            ImageAlphaBlending($result, true);
            ImageFill($result, 0, 0, ImageColorAllocate($result, 255, 255, 255));
            ImageCopyResampled($result, $image, 0, 0, $x, $y, $size[0], $size[1], $width, $height);

            ImageInterlace($result, true);
            ImageJPEG($result, null, 90);
        }
    }

    return false;
}

header('Content-Type: image/jpeg');
Image('http://upload.wikimedia.org/wikipedia/commons/4/47/PNG_transparency_demonstration_1.png', '16:9', '320x');

?>



--
¯\_(ツ)_/¯ Education, learning resources, TEL, AR/VR/MR, CC licensed content, panoramas, interactive narrative, sectional modules (like jrDocs), lunch at Uni of Bristol. Get in touch if you share my current interests or can suggest better :)
SteveX
SteveX
@ultrajam
11 years ago
2,584 posts
brian:It's easy to say how it should work, but I've been doing this for over 10 years and have yet to find a perfect solution that works 100% of the time for 100% of images.

I know man, I'm talking it rather than coding it, and I know I'm out classed: Everything I know about php is via you and your excellent code (and now the Jamroom Team), so it's kind of weird even attempting to explain what I mean (especially as we've been in a similar thread before jr5, and most people seem totally unconcerned by squishing or squareness), but you did say you were all ears, and I do love to shoot the breeze.

So my apologies for the wordiness in this thread. I'm going to attribute that to perfect weather here at the moment.

Important to note, I'm perfectly happy working with square images, and they do work flawlessly.


--
¯\_(ツ)_/¯ Education, learning resources, TEL, AR/VR/MR, CC licensed content, panoramas, interactive narrative, sectional modules (like jrDocs), lunch at Uni of Bristol. Get in touch if you share my current interests or can suggest better :)

updated by @ultrajam: 04/23/14 01:35:18PM
brian
@brian
11 years ago
10,149 posts
Thanks for the feedback Steve - so this is basically just cropping to something that is not a square, which is doable ;)

What do you feel would be the best way to name these ? would something like:

4x3
16x9

be good? These should not be hard to add in.

Hope this helps!


--
Brian Johnson
Founder and Lead Developer - Jamroom
https://www.jamroom.net
SteveX
SteveX
@ultrajam
11 years ago
2,584 posts
I'm not sure, whatever woulld be most useful to the target market I guess.

cd/square, book, portrait, banner, tv, facebook, twitter and google?


--
¯\_(ツ)_/¯ Education, learning resources, TEL, AR/VR/MR, CC licensed content, panoramas, interactive narrative, sectional modules (like jrDocs), lunch at Uni of Bristol. Get in touch if you share my current interests or can suggest better :)

updated by @ultrajam: 04/23/14 03:52:31PM
SteveX
SteveX
@ultrajam
11 years ago
2,584 posts
brian:so this is basically just cropping to something that is not a square

When you put it like that it sounds so simple - a linear thread, spiralling on a square.


--
¯\_(ツ)_/¯ Education, learning resources, TEL, AR/VR/MR, CC licensed content, panoramas, interactive narrative, sectional modules (like jrDocs), lunch at Uni of Bristol. Get in touch if you share my current interests or can suggest better :)
brian
@brian
11 years ago
10,149 posts
OK latest Image Support module now has support for this - i.e.

crop=16:9
crop=4:3
crop=25:12
crop=5:10
crop=w:h

Check it out and let me know if you see any issues.

Hope this helps!


--
Brian Johnson
Founder and Lead Developer - Jamroom
https://www.jamroom.net
SteveX
SteveX
@ultrajam
11 years ago
2,584 posts
That doesn't seem right at all, all cropped images are distorted regardless of the ratio.
For a 800x601 image (using "large" for 256x256 output):
/blog/image/blog_image/1/large/crop=33:33
|src_height=601 src_width=792 src_y_offset=0 src_x_offset=4|

src_width should be 601 with a src_x_offset of 99

Similar for both landscape and portrait crops 2:1 and 1:2

Also, after emptying the image cache I don't always see a new image being created (the fdebug in the crop section of jrImage/include.php doesn't get triggered). I'm not sure how that image cache is supposed to be working.


--
¯\_(ツ)_/¯ Education, learning resources, TEL, AR/VR/MR, CC licensed content, panoramas, interactive narrative, sectional modules (like jrDocs), lunch at Uni of Bristol. Get in touch if you share my current interests or can suggest better :)
SteveX
SteveX
@ultrajam
11 years ago
2,584 posts
This seems to work for all images I've tried:

                // Check for an aspect ratio crop
                if (strpos($_post['crop'], ':')) {


//                     // Our aspect ratio crop will come in like 4x3 or 16x9, etc.
//                     list($w, $h) = explode(':', $_post['crop']);
//                     $w = (int) $w;
//                     $h = (int) $h;
//                     // What is our existing ratio?
//                     if ($w > $h) {
//                         $chunk           = round($src_height / $w);
//                         $src_y_offset    = round(($src_height - ($h * $chunk)) / 2);
//                         $new_width       = $_post['width'];
//                         $new_height      = round(($_post['width'] / $w) * $h);
//                         $_post['height'] = $new_height;
//                         $src_height     -= round($src_y_offset * 2);
//                     }
//                     else {
//                         $chunk           = round($src_width / $h);
//                         $src_x_offset    = round(($src_width - ($w * $chunk)) / 2);
//                         $new_height      = $_post['width'];
//                         $new_width       = round(($_post['width'] / $h) * $w);
//                         $_post['width']  = $new_width;
//                         $_post['height'] = $new_height;
//                         $src_width      -= round($src_x_offset * 2);
//                     }

                
                    // Our aspect ratio crop will come in like 4:3 or 16:9, etc.
					$crop = array_filter(explode(':', $_post['crop']));

					$ratio = array(0 => $src_width / $src_height, 1 => $crop[0] / $crop[1]);

					$w = $crop[0];
					$h = $crop[1];
			
					// What is our existing ratio?
					if ($w > $h) {
					
						if ($ratio[0] > $ratio[1]) {
							$width = $src_height * ($w / $h);
							$src_x_offset = ($src_width - $width) / 2;
							$src_width = $width;
						
						}

						else if ($ratio[0] < $ratio[1]) {
							$height = $src_width / ($w / $h);
							$src_y_offset = ($src_height - $height) / 2;
							$src_height = $height;
						}

						$new_width       = $_post['width'];
						$new_height      = round(($_post['width'] / $w) * $h);
						$_post['height'] = $new_height;
						
					}
                    else {

						if ($ratio[0] > $ratio[1]) {
							$width = $src_height * ($w / $h);
							$src_x_offset = ($src_width - $width) / 2;
							$src_width = $width;
						}

						else if ($ratio[0] < $ratio[1]) {
							$height = $src_width / ($w / $h);
							$src_y_offset = ($src_height - $height) / 2;
							$src_height = $height;
						}
						
						$new_height      = $_post['width'];
						$new_width       = round(($_post['width'] / $h) * $w);
						$_post['width']  = $new_width;
						$_post['height'] = $new_height;
							
                    }

                }
                else {
                    // Default auto height/width



--
¯\_(ツ)_/¯ Education, learning resources, TEL, AR/VR/MR, CC licensed content, panoramas, interactive narrative, sectional modules (like jrDocs), lunch at Uni of Bristol. Get in touch if you share my current interests or can suggest better :)
SteveX
SteveX
@ultrajam
11 years ago
2,584 posts
I've been testing that on url images like
/blog/image/blog_image/4/xxlarge/crop=9:18

So far it holds up for blog images of all sizes and aspect ratios and original upload aspect ratio.

The cache problem I was seeing seems to be firefox.
After emptying the jr image cache, ff cache will show a previous version for the same url. You can get around that by changing the image id, size or aspect ratio in the url each time so its always a new url; crop=122:133 crop=122:136 crop=1342:1396 etc


--
¯\_(ツ)_/¯ Education, learning resources, TEL, AR/VR/MR, CC licensed content, panoramas, interactive narrative, sectional modules (like jrDocs), lunch at Uni of Bristol. Get in touch if you share my current interests or can suggest better :)
brian
@brian
11 years ago
10,149 posts
I'm not seeing any image distortion at all with my original code - can you give me an example URL (is the blog one above good)?

Thanks!


--
Brian Johnson
Founder and Lead Developer - Jamroom
https://www.jamroom.net
SteveX
SteveX
@ultrajam
11 years ago
2,584 posts
This is distorted for me on the Nova demo:
http://demo.jamroom.net/jrNova/blog/image/blog_image/4/large/crop=16:9

The original isn't distorted:
http://demo.jamroom.net/jrNova/blog/image/blog_image/4/large


--
¯\_(ツ)_/¯ Education, learning resources, TEL, AR/VR/MR, CC licensed content, panoramas, interactive narrative, sectional modules (like jrDocs), lunch at Uni of Bristol. Get in touch if you share my current interests or can suggest better :)
brian
@brian
11 years ago
10,149 posts
I will check out the demos - this works for me:

https://www.jamroom.net/profile/image/profile_image/2/large/crop=5:16/_v=1393701341

and

https://www.jamroom.net/profile/image/profile_image/2/large/crop=16:5/_v=1393701341

Do those look distorted to you?


--
Brian Johnson
Founder and Lead Developer - Jamroom
https://www.jamroom.net
SteveX
SteveX
@ultrajam
11 years ago
2,584 posts
No, they both look fine.


--
¯\_(ツ)_/¯ Education, learning resources, TEL, AR/VR/MR, CC licensed content, panoramas, interactive narrative, sectional modules (like jrDocs), lunch at Uni of Bristol. Get in touch if you share my current interests or can suggest better :)
brian
@brian
11 years ago
10,149 posts
SteveX:
No, they both look fine.

Yeah the code is fine - there's something tweaky going on on the demo, most likely cause all the demo sites share the same data/cache sub system, so I will check that out.

Thanks!


--
Brian Johnson
Founder and Lead Developer - Jamroom
https://www.jamroom.net
brian
@brian
11 years ago
10,149 posts
Actually it looks like there is an issue on non-square images - i.e.

https://www.jamroom.net/user/image/user_image/6/xxxlarge/crop=16:9/_v=1378751265

so I will check that out.

Thanks!


--
Brian Johnson
Founder and Lead Developer - Jamroom
https://www.jamroom.net

updated by @brian: 04/27/14 03:03:31PM
SteveX
SteveX
@ultrajam
11 years ago
2,584 posts
I get the same on my local site though.

The above code fixes it for me.


--
¯\_(ツ)_/¯ Education, learning resources, TEL, AR/VR/MR, CC licensed content, panoramas, interactive narrative, sectional modules (like jrDocs), lunch at Uni of Bristol. Get in touch if you share my current interests or can suggest better :)
brian
@brian
11 years ago
10,149 posts
SteveX:
I get the same on my local site though.

The above code fixes it for me.

Yeah see my response above ^.

I'm checking it out.


--
Brian Johnson
Founder and Lead Developer - Jamroom
https://www.jamroom.net
brian
@brian
11 years ago
10,149 posts
OK play around with this:

https://www.jamroom.net/user/image/user_image/6/xxxlarge/crop=4:16/_v=1378751268

and let me know if it works. You can change the _v on the end to get a non-cached version.

Thanks!


--
Brian Johnson
Founder and Lead Developer - Jamroom
https://www.jamroom.net
SteveX
SteveX
@ultrajam
11 years ago
2,584 posts
Mostly ok, but it becomes letterboxed/filled at 16:11
https://www.jamroom.net/user/image/user_image/6/xxxlarge/crop=16:11


--
¯\_(ツ)_/¯ Education, learning resources, TEL, AR/VR/MR, CC licensed content, panoramas, interactive narrative, sectional modules (like jrDocs), lunch at Uni of Bristol. Get in touch if you share my current interests or can suggest better :)
brian
@brian
11 years ago
10,149 posts
The alternate is to start cropping the width - is that preferred?


--
Brian Johnson
Founder and Lead Developer - Jamroom
https://www.jamroom.net
SteveX
SteveX
@ultrajam
11 years ago
2,584 posts
Yes, the width needs to be cropped to maintain the aspect ratio and maintain the max image dimension (switches from width to height or vice versa but is still an small/xlarge/xxlarge image).

Try out my code above (it replaces the if (strpos($_post['crop'], ':')) section at around line 952, and it does do the job perfectly as far as I can see.


--
¯\_(ツ)_/¯ Education, learning resources, TEL, AR/VR/MR, CC licensed content, panoramas, interactive narrative, sectional modules (like jrDocs), lunch at Uni of Bristol. Get in touch if you share my current interests or can suggest better :)
brian
@brian
11 years ago
10,149 posts
SteveX:
Yes, the width needs to be cropped to maintain the aspect ratio and maintain the max image dimension (switches from width to height or vice versa but is still an small/xlarge/xxlarge image).

Try out my code above (it replaces the if (strpos($_post['crop'] , ':')) section at around line 952, and it does do the job perfectly as far as I can see.

I still get distortion with the code you posted - it was the first thing I tried.

I will check it out some more.

Thanks!


--
Brian Johnson
Founder and Lead Developer - Jamroom
https://www.jamroom.net
SteveX
SteveX
@ultrajam
11 years ago
2,584 posts
I've tested it extensively and haven't seen distortion at all since completing it. It took quite a while to get right.

Make sure you are not seeing cached images when looking at an image processed on the url, and that if you are looking at images in templates that they are freshly uploaded - once the image has been created it will already be distorted.

When looking at an image directly on the url change the aspect ratio for every page reload to make sure the image is recreated each time.

I still found I had to do that even with emptying the image cache every time.


--
¯\_(ツ)_/¯ Education, learning resources, TEL, AR/VR/MR, CC licensed content, panoramas, interactive narrative, sectional modules (like jrDocs), lunch at Uni of Bristol. Get in touch if you share my current interests or can suggest better :)

updated by @ultrajam: 04/28/14 06:57:09AM
brian
@brian
11 years ago
10,149 posts
Yep - it looks good. I must have copied it wrong the first time or left some extra code in. Just tested it again and it looks great through all ratios, so thanks for that.

I'll get this packaged up and pushed out.

Thanks!


--
Brian Johnson
Founder and Lead Developer - Jamroom
https://www.jamroom.net
brian
@brian
11 years ago
10,149 posts
OK the latest image support module is out with this update - let me know if you see any issues.

Thanks!


--
Brian Johnson
Founder and Lead Developer - Jamroom
https://www.jamroom.net
SteveX
SteveX
@ultrajam
11 years ago
2,584 posts
deleted this comment, I'm not reading straight today


--
¯\_(ツ)_/¯ Education, learning resources, TEL, AR/VR/MR, CC licensed content, panoramas, interactive narrative, sectional modules (like jrDocs), lunch at Uni of Bristol. Get in touch if you share my current interests or can suggest better :)

updated by @ultrajam: 04/28/14 08:05:41AM
brian
@brian
11 years ago
10,149 posts
That is happening - the part you are looking at is just an outer wrapper that will skip the crop if either $w or $h is set to 0 - i.e. someone does 16:0.


--
Brian Johnson
Founder and Lead Developer - Jamroom
https://www.jamroom.net
SteveX
SteveX
@ultrajam
11 years ago
2,584 posts
Sorry Brian, I had the thread still open when I noticed my mistake, so I just edited it.

All looks good to me.


--
¯\_(ツ)_/¯ Education, learning resources, TEL, AR/VR/MR, CC licensed content, panoramas, interactive narrative, sectional modules (like jrDocs), lunch at Uni of Bristol. Get in touch if you share my current interests or can suggest better :)
brian
@brian
11 years ago
10,149 posts
SteveX:
Sorry Brian, I had the thread still open when I noticed my mistake, so I just edited it.

All looks good to me.

No problem - I appreciate your help and input on this to get it working right!


--
Brian Johnson
Founder and Lead Developer - Jamroom
https://www.jamroom.net
SteveX
SteveX
@ultrajam
11 years ago
2,584 posts
My pleasure, I'm glad to be able to! :)


--
¯\_(ツ)_/¯ Education, learning resources, TEL, AR/VR/MR, CC licensed content, panoramas, interactive narrative, sectional modules (like jrDocs), lunch at Uni of Bristol. Get in touch if you share my current interests or can suggest better :)

Tags