| Summary: | The canvas is not scrolled to the cropped area after the crop | ||
|---|---|---|---|
| Product: | [Applications] krita | Reporter: | Dmitry Kazakov <dimula73> | 
| Component: | General | Assignee: | Dmitry Kazakov <dimula73> | 
| Status: | RESOLVED DUPLICATE | ||
| Severity: | critical | CC: | halla | 
| Priority: | NOR | ||
| Version First Reported In: | git master (please specify the git hash!) | ||
| Target Milestone: | --- | ||
| Platform: | Unlisted Binaries | ||
| OS: | Linux | ||
| Latest Commit: | Version Fixed In: | ||
| Sentry Crash Report: | |||
| Attachments: | screenshot of the bug | ||
| 
        
          Description
        
        
          Dmitry Kazakov
        
        
        
        
          2011-05-15 18:27:47 UTC
        
       Git commit efa9863ff712100367193f17d4acb0569abae279 by Sven Langkamp. Committed on 12/08/2011 at 03:52. Pushed by langkamp into branch 'master'. fit to page after crop BUG:273357 M +4 -0 krita/plugins/tools/tool_crop/kis_tool_crop.cc http://commits.kde.org/calligra/efa9863ff712100367193f17d4acb0569abae279 Git commit 5523b353ffb8a7515374903f608b847faf0f91d2 by Srikanth Tiyyagura, on behalf of Sven Langkamp. Committed on 12/08/2011 at 03:52. Pushed by tiyyagura into branch 'krita_resource-management-tagging-tiyyagura'. fit to page after crop BUG:273357 M +4 -0 krita/plugins/tools/tool_crop/kis_tool_crop.cc http://commits.kde.org/calligra/5523b353ffb8a7515374903f608b847faf0f91d2 Git commit 0f23eb9e726cfae6253af327340520b19f0b4c7d by Inge Wallin, on behalf of Sven Langkamp. Committed on 12/08/2011 at 03:52. Pushed by ingwa into branch 'nondestructive-unavail-leinir'. fit to page after crop BUG:273357 M +4 -0 krita/plugins/tools/tool_crop/kis_tool_crop.cc http://commits.kde.org/calligra/0f23eb9e726cfae6253af327340520b19f0b4c7d The fix doesn't work. See attachment. Problems: 1) The crop tool doesn't work with QPainter canvas (explanation below) 2) The fix doesn't fix Resize Image action 3) The fix doesn't fix Scale Image action 4) The fix doesn't work with undo/redo Explanation: You shouldn't call to setSize directly from anywhere other than from a couple of zoom classes. The setting of the zoom should happen automatically by zoom classes, basing on the signals emitted by the image. Calling setZoom manually causes a kind of race conditions between your call and the other recipients of image signals. That is exactly what happens in your fix. KisPrescaledProjection is connected to a signal "size changed" from the image. It updates the cache, changes its size and redraws the canvas on the signal delivery. With calling setZoom manually, the order of the execution goes wrong somewhere. How it is supposed to work: 1) Image emits "size changed" or "resolution changed" signal. 2) View gets this signal 3) Notifies canvas (prescaled projection) about the size change 4) Updates the zoom values 5) Prescaled projection gets the signal that the zoom changed and redraws the canvas The order may be a bit different, but the main idea is that everything should happen on the delivery of the signal, no direct calls. Created attachment 63033 [details]
screenshot of the bugThis really needs to be fixed before we release 2.4. It might be the most irritating and embarrassing bug in Krita Fixed by Thorsten Zachmann in b85f2e520fb172bc7d1c7f07f8f9aa44ee03dda9 Cropping is now completely broken visually: on cropping, the top-left area of the image is shown, though the actual crop is done correctly. Closing this one as duplicate of 250146 *** This bug has been marked as a duplicate of bug 250146 *** |