Giter Club home page Giter Club logo

ngx-image-cropper's People

Contributors

alexfarrugia avatar arpantechparticle avatar c0nstan avatar captaincaius avatar cdelaplanche avatar dependabot[bot] avatar einfachhans avatar freoff avatar halbekanne avatar hyperlife1119 avatar jgroh9 avatar kashyapkaki avatar krivochenko avatar loiddy avatar mawi137 avatar meirg avatar menecats avatar mivanyna avatar pdxwebdev avatar powerkiki avatar prostosergik avatar qlaffont-md avatar robinnau avatar stweedie avatar taehagen avatar tfilo avatar tiagomotasantos avatar vpetrusevici avatar williamlambert-jc avatar xuelink avatar

Stargazers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

Watchers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

ngx-image-cropper's Issues

Cropper dimensions limits

Make available configure min width/height dimensions to crop
E.g. need to crop image with 1.5 aspect ratio and to be not less then 320x240px

Need a help

Can I use the plugin in the server side rendering apps?

Image rotating for portrait images on mobile devices

Hi guys, I found this issue in my Ipad pro, Iphone and also same issue in a android mobile as well.

I used the ngx-image-cropper in our app, but after testing in the mobile uploading a portrait image, i got the following.

48965e22-8571-4f03-a72d-b18f221cb97c

As you can see i just opened the https://stackblitz.com/edit/image-cropper in a mobile phone and add a photo in a portrait mode, notice that half of the image is black, if you move the cropper from the middle to the top the issue with black part is solved. But the image is still rotated left.

In my case I also used that in progress web app, where i used the mobile camera and depending on the orientation you use the mobile phone the image can be upside down.

Tried to find out in the code where the image is being rotated, if you could let me know please?

Thanks

How to keep current cropper? also set options dynamically?

I am using this library for cropper and canvas for rotate.
Once rotate is finished then the base64 code also being changed. at moment, library reset the cropper to the startup point and we lost everything, I would like to keep the current cropper and set it after rotated image loaded.

I have tried to manually set cropper using viewchild but didn't get it working.

also another topic is just want to set cropper ratio dynamically, but ratio change is not reflected to the view. If i tries to crop again then the cropper ratio reflected. any solution for these problems?

Thank you

angular 5.2.9: ngx-image-cropper does not work

Hi! There is a problem. When I try to make npm i ngx-image-cropper
The result is:

-- UNMET PEER DEPENDENCY @angular/[email protected]
+-- UNMET PEER DEPENDENCY @angular/[email protected]
+-- UNMET PEER DEPENDENCY @angular/[email protected]
+-- UNMET PEER DEPENDENCY @angular/[email protected]
+-- UNMET PEER DEPENDENCY @angular/[email protected]
+-- UNMET PEER DEPENDENCY @angular/[email protected]
+-- UNMET PEER DEPENDENCY angular@>=1.4 <1.7

Information about Angular version:

Angular CLI: 1.7.3
Node: 7.10.1
OS: linux x64
Angular: 5.2.9
... animations, common, compiler, compiler-cli, core, forms
... http, language-service, platform-browser
... platform-browser-dynamic, router

@angular/cdk: 5.2.2
@angular/cli: 1.7.3
@angular/material: 5.2.3

Thanks!

Controlling quality of image

Is there a way to control the quality of an image? I know we can't really improve the quality, but can we decrease the quality? Does the cropper offer an option for that?

How to make the cropped image same format as image upload instead of base64 format?

Hi, here is my image file format,
image
and below is my cropped image format
"…"

Internet Explorer 11 throws IndexSizeError if ratio is > 1

Internet Explorer 11 throws IndexSizeError after loading of some images if canvas size is restricted from elements around. This always happens if the ratio in the crop method is calculated to be greater than 1. I already prepared a PR to fix this issue.

Get modified file

It's not a issue exactly. I'm wondering if there is a way to get the modified File once it's cropped.

Thank you, this module is really useful.

Not working in iOS and Firefox

Hi

I can't get the cropper to work with Firefox and iOS-devices, all the resize dots are in the same position and it's not possible to move them. See screenshot below

skarmavbild 2018-01-22 kl 14 56 43

I have configured the cropper like so:
<image-cropper
[imageChangedEvent]="imageChangedEvent"
[maintainAspectRatio]="true"
[aspectRatio]="16 / 9"
[resizeToWidth]="1200"
format="jpeg"
(imageCropped)="imageCropped($event)"
>

How to reset the cropper?

I'm using this component to crop an image before uploading. it works fine.
but after uploading, i want to let the user upload another image.
the previous image is still loaded, and that is undesirable. I want it to be empty,
just like the first time. Any idea how to achieve that? tnx.

Cropping frame does not move smoothly on Google Chrome

Hello.
Unfortunately I tried to implement your example code and I experience problems in Google Chrome Version 66.0.3359.117 (Official Build) (64-bit). The cropping frame does not move smoothly, it jumps in small steps. I have to mention that at the same time it works smoothly in Microsoft Edge.
Is there any ideas what might be the problem?

IndexSizeError

Hi -
This library works fine when I try to add a portrait size image - but doesn't work when I try to upload landscape style images.

This issue is occurring because it has been placed in a bootstrap model. Should I be making any changes to restrict the image cropper to the bootstrap width.

I am getting IndexSizeError in my console

Code Used:

 <input type="file" (change)="fileChangeEvent($event)" id="comImg" />
<image-cropper [imageChangedEvent]="imageChangedEvent" 
 [maintainAspectRatio]="true" 
[aspectRatio]="1/ 1" 
[resizeToWidth]="150"
 format="png" 
(imageCropped)="imageCropped($event)" 
(imageLoaded)="imageLoaded()" 
(loadImageFailed)="loadImageFailed()">
</image-cropper>

Thank you in advance

Cropper Outline Width doesn't cover image

I suggest you to change this style:

:host .cropper{
  outline-width: 1000px;
}

Become:

:host .cropper{
  outline-width: 100vw;
}

So, the cropper will cover all image width. I have prove it in large image with > 1000px width.
I try to change it in my CSS file, but it can not change.

Output format not changing to .jpg

I have changed the format attribute="jpg" in my html. But the resultant image is always png. Jpg images are also being converted into png. Please tell any solution.

imageLoadedInView unable to be used for setting size, cropper, etc.

Seems like a bug, following code prevents the imageLoaded event from being used to set the size or cropper values due to order of operations, will edit this if I find a solution.

component:

imageLoadedInView(): void {
        if (this.originalImage != null) {
            this.imageLoaded.emit();
            setTimeout(() => {
                this.setMaxSize();
                this.resetCropperPosition();
                this.cd.markForCheck();
            });
        }
}

Following gives me expected functionality, unsure what purpose of setTimeout was here and had to call crop afterwards since it's private, could also just make that public.

    if (this.originalImage != null) {
      this.setMaxSize();
      this.resetCropperPosition();
      this.cd.markForCheck();
      this.imageLoaded.emit();
      this.crop();
    }

Post base64 data to server

Hello, I want to know hot post the cropped image to server?
Im having a Upload Image button and want to post that cropped image to server. Can you post some sample code for post the image data in base64.
Thanks.

Cropper not working on mobile

Currently cropper is not working on mobile because in this case startMove is called after moveImg. I see touchmove and touchend events so I guess the plan was to support that and this is a bug?

To see the issue, you can use chrome mobile simulator

Allowing cropper to have bigger height then the image

Is there a way to allow to cropper to get bigger then the selected image?

For example, I maintain aspect ratio of 1 / 1 which is a square, and if I upload an image with width of 600 and height of 100, the cropper will be a square of width and height 100 but there's no way to make it bigger.
Imagine if we want to fit the 600x100 image into a 200x200 cropper. Is there a way to do it?
Yeah, I know then the image wont be pretty and will have dead space, but that's not important. Just need to have the option.

https://stackblitz.com/edit/image-cropper-jenfnl

Angular 6

Hello I was wondering when your component could be used in Angular 6 ?
Thanks

Cropper size remains zero and non resizeable

hi ,
Sometimes when an image is loaded for cropping, the cropper square remains non-resizeable
leaving cropped image corrupted .
Please help what should be done in such scenario.
Note :
in attached image cropper is non-resizable and below is cropped image which is not generated
cropperissue 1

View not updated when use in Ionic 3

Hello ! First of all, a really big thank you for this plugin. It's very fast and it's what I needed.

But - there's a but - I've seen an issue when building my ionic app : the view is not updated when I move or resize the picture (only the view).

I've already seen that before so I knew how it can be corrected. I forked the repo and add a reference to

ChangeDetectorRef

in the file.

I will make a PR !

ERROR RangeError: Maximum call stack size exceeded

Hi. When I uploaded the image with size more then 3 Mb I saw this error (see below).
What can you advise about this?

ImageCropperComponent.html:3 ERROR RangeError: Maximum call stack size exceeded
at RegExp.[Symbol.match] ()
at String.match (native)
at sanitizeUrl (webpack-internal:///../../../platform-browser/@angular/platform-browser.es5.js:3438:44)
at DomSanitizerImpl.sanitize (webpack-internal:///../../../platform-browser/@angular/platform-browser.es5.js:4008:24)
at setElementProperty (webpack-internal:///../../../core/@angular/core.es5.js:9600:78)
at checkAndUpdateElementValue (webpack-internal:///../../../core/@angular/core.es5.js:9520:13)
at checkAndUpdateElementInline (webpack-internal:///../../../core/@angular/core.es5.js:9454:24)
at checkAndUpdateNodeInline (webpack-internal:///../../../core/@angular/core.es5.js:12537:20)
at checkAndUpdateNode (webpack-internal:///../../../core/@angular/core.es5.js:12484:16)
at debugCheckAndUpdateNode (webpack-internal:///../../../core/@angular/core.es5.js:13341:59)

Unable to zoom in the source image

I try to zoom the source image. I have wrapped it, so by clicking the zoom in icon, the image should be zoom in too.

I can not find the best way to zoom in the image. Could you help me?

How to change style in class source image?

I am trying to zoom in and zoom out the source image. And I've found the best way to do that. I have to change the style property of class source-image. Like this:

[_nghost-c7] > div[_ngcontent-c7] .source-image[_ngcontent-c7] {
    max-width: 100%;
    max-height: 100%;
}

In inspect element, I try to change the max-width and max-height and the image going zoom in. So, do you have any idea to access that class directly from TS file?

请帮助我

请问下,如何设置初始化默认图片?

Resize cropper canvas

I set the height to <image-cropper>. And when I upload the image with portrait orientation locating of cropper area is not in the appropriate place.

P. S.: cropper is initing in the dialog (modal) window

screenshot from 2018-03-01 18-34-21

Multipart form data

My server side is expecting multipart form data but I have with me base64 string. How can I make this base64 to multipart form-data.

error fetch same image

error fetch same image not to edit and also open file search window when click on cancel button error appears "ERROR TypeError: Failed to execute 'readAsDataURL' on 'FileReader': parameter 1 is not of type 'Blob' " . I still can not solve

Unable to publish angular 4 app, it works fine in local just not working with webpack publish

$$_gendir\node_modules\ngx-image-cropper\ngx-image-cropper.ngfactory.ts Unexpected token (13:40)
You may need an appropriate loader to handle this file type.
| import * as i2 from '@angular/common';
| import * as i3 from '@angular/platform-browser';
| export const ImageCropperModuleNgFactory:i0.NgModuleFactory<i1.ImageCropperModule> = i0.╔╡cmf(i1.ImageCropperModule,
| ([] as any[]),(_l:any) => {
| return i0.╔╡mod([i0.╔╡mpd(512,i0.ComponentFactoryResolver,i0.╔╡CodegenComponentFactoryResolver,
@ ./$$_gendir/ClientApp/app/components/client/updateclient.component.ngfactory.ts 12:0-106
@ ./$$_gendir/ClientApp/app/app.module.server.ngfactory.ts
@ ./ClientApp/boot.server.ts

any ideas please?
Thank you
Girish

Image cropper always square

The image cropper is always square. I can't able to crop a image with free size. Any solution to achieve the free positions like rectangle?

Cannot apply *ngIf on <image-cropper> tag

I want to show cropper only if the uploaded file meet specified conditions (like dimensions). So I would like to switch visibility by standard *ngIf. Problem is, that once I set shouldBeVisible to true the image is not visible on the page at all. (btw I set this property in promise.then)

# a.component.ts
<image-cropper
  *ngIf="shouldBeVisible"
  [imageChangedEvent]="imageChangedEvent"
  (imageCropped)="imageCropped($event)"
  (imageLoaded)="imageLoaded()"
  (loadImageFailed)="loadImageFailed()">
</image-cropper>

Sanitizing unsafe style

I'm upgrade from version 0.1.24 to 0.1.30 then is showing angular warning:

print

WARNING: sanitizing unsafe style value 0px; (see http://g.co/ng/security#xss).

on platform-browser.js

as the angular itself recommends: see http://g.co/ng/security#xss

Unable to set the canvas size

Hi, is there a way to set canvas size? At the moment whenever I set the size of the container itself, the image will still overflow and as a result cover up my other stuff in display.

If I do this way

<div class="col-lg-3 text-center" style="height:33vh">
        <div *ngIf="file">
          <div class="row">
            <image-cropper class="col-lg-12"
            [imageChangedEvent]="imageChangedEvent"
            [maintainAspectRatio]="true"
            [aspectRatio]="1"
            [resizeToWidth]="128"
            format="jpeg"
            (imageCropped)="imageCropped($event)"
            ></image-cropper>
          </div>
          <div><p>Preview</p></div>
        </div>
      </div>

The image will poke through the container

If I do this way

<div class="col-lg-3 text-center">
        <div *ngIf="file">
          <div class="row">
            <image-cropper class="col-lg-12" style="height:33vh"
            [imageChangedEvent]="imageChangedEvent"
            [maintainAspectRatio]="true"
            [aspectRatio]="1"
            [resizeToWidth]="128"
            format="jpeg"
            (imageCropped)="imageCropped($event)"
            ></image-cropper>
          </div>
          <div><p>Preview</p></div>
        </div>
      </div>

The image will get cut instead

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.