Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat: crop feature #10

Open
wants to merge 8 commits into
base: main
Choose a base branch
from
Open

feat: crop feature #10

wants to merge 8 commits into from

Conversation

sprabowo
Copy link

Hi @zachleat or @stedman

i just make a PR for adding mime type for jpg. All .jpg format don't return source type "image/jpeg". also add crop feature by adding heights config. i see the sharp api not only can resize with same ratio but also can crop the image https://sharp.pixelplumbing.com/api-resize#resize. with the crop feature, dev can easily crop with their on configuration for some use case e.g og:image, twitter:image

please help to review,
thanks

@stedman
Copy link
Contributor

stedman commented Jun 2, 2020

Hi @sprabowo

Full disclosure: I am merely an enthusiast here and these are my opinions and suggestions. I hope this review helps:

  • Add "jpg" as a mime type: Though many image files use jpg as their file extension, adding jpg as a formats [mime type] option may add more confusion since it is not supported elsewhere:

    It may be helpful to add a link from the README docs to the sharp docs and also make sure all the possible mime types are listed in the options: formats: ["webp", "jpeg"], // "png", "gif", "svg".

  • Add "crop" feature by adding "heights": This feature add also sounds sensible on first pass. However, it seems to add a non-trivial amount of complexity to the code and the implementation. Some follow-up questions that I have (from just looking at the code and tests):

    • What if heights has values but widths doesn't? Does anything get resized?

    • Is there a better way to add a cropping feature? Instead of overloading the widths option, perhaps adding a separate crops property would be clearer. I'm not exactly sure how that would look, but perhaps something such as:

      ..
      crops: ["1600x900", "160x90", "80x45"],
      ..

      ...or...

      ..
      crops: [
        {
          width: 1600, 
          height: 900
        }, {
          width: 160, 
          height: 90
        }, {
          width: 80, 
          height: 45
        }
      ],
      ..

Lastly, it seems your initial commit included a yarn.lock file. You may want to delete that and add yarn.lock to the .gitignore file.

@sprabowo
Copy link
Author

sprabowo commented Jun 3, 2020

Thank for the feedback @stedman,

i've done the following task:

  1. remove mime_type for jpg
  2. add crops option configuration
  3. remove yarn.lock

please check

@sprabowo sprabowo changed the title feat: add mime type for jpg and crop feature feat: crop feature Jun 3, 2020
@zachleat
Copy link
Member

Nice!

Sorry by the time I made it here there are a few more conflicts!

@zachleat
Copy link
Member

I think I’m also confused about where the left/top properties for crop are set?

@zachleat zachleat added the open-question Further information is requested from the original poster. label Aug 28, 2020
@sprabowo
Copy link
Author

sprabowo commented Aug 29, 2020

Hi @zachleat through this docs api resize
since we just use default settings of crop, the position of crop is centre
image

do we need to add 'crop_position' opt for this library?

@dweidner
Copy link
Contributor

do we need to add 'crop_position' opt for this library?

MaybesharpResizeOptions, as there are already properties for other sharp option like sharpOptions or sharpJpegOptions? This would allow users to customize not only the position but also the strategry to use allowing for content aware crops:

await Image(src, {
  crops: ['160x90'],
  formats: ['jpeg'],
  sharpResizeOptions: {
    fit: sharp.fit.cover,
    position: sharp.strategy.attention
  }
});

@sprabowo
Copy link
Author

Hi @zachleat any ideas to this crop feature? should I go ahead close this?

@zachleat
Copy link
Member

Please don’t close—the time frame for this one might be long but it is still valuable 🙌🏻 I consider conflict resolution to be my responsibility here, don’t worry about keeping it up to date

@zachleat
Copy link
Member

zachleat commented Jan 2, 2025

For future visitors, this can be achieved in v6.0.0 with a low level hook for sharp transformations #52

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
open-question Further information is requested from the original poster.
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants