Jump to content

GSoc/2023/StatusReports/SrirupaDatta: Difference between revisions

From KDE Community Wiki
Srirupa (talk | contribs)
Srirupa (talk | contribs)
 
(61 intermediate revisions by the same user not shown)
Line 1: Line 1:
== Improving the Bundle Creator in Krita ==
= <b> Improving the Bundle Creator in Krita </b> =
 
== Summary ==


The primary format to share resources in Krita is a Resource Bundle, which is a compressed file containing all the resources together. It also contains some other information like metadata and a manifest so Krita can check there’s no errors in the file.  
The primary format to share resources in Krita is a Resource Bundle, which is a compressed file containing all the resources together. It also contains some other information like metadata and a manifest so Krita can check there’s no errors in the file.  
Line 5: Line 7:
Krita’s Bundle Creator allows one to create their own bundle from the resources of their choice. The project aims to improve the user interface of the current Bundle Creator, and allow the ability to edit bundles (which is currently not supported in Krita).
Krita’s Bundle Creator allows one to create their own bundle from the resources of their choice. The project aims to improve the user interface of the current Bundle Creator, and allow the ability to edit bundles (which is currently not supported in Krita).


[[File:Final2.png|left]]
=== Project Proposal ===
[https://docs.google.com/document/d/1-cMokNanLAcpXIrExLzmx3kzZ4M2yFgXv7_Rigfpixo/edit?usp=sharing Improving the Bundle Creator in Krita]


== Blog Posts ==
== Blog Posts ==
The list of all the blog posts for GSoC'23 has been listed here.
* [https://srirupa19.github.io/gsoc/2023/05/14/first_post.html First Blog Post for GSoC'23]
* [https://srirupa19.github.io/gsoc/2023/05/25/second_post.html Second Blog Post for GSoC'23]
* [https://srirupa19.github.io/gsoc/2023/06/15/third_post.html The Fully Functional Bundle Creator]
* [https://srirupa19.github.io/gsoc/2023/07/07/fourth_post.html Long Post Alert!!]
* [https://srirupa19.github.io/gsoc/2023/08/17/fifth_post.html Unleashing the new Bundle Editor]
== Merge Request ==
The merge request for this project can be viewed [https://invent.kde.org/graphics/krita/-/merge_requests/1802 here].
== Timeline ==
===== Week 1 =====
I have created the Bundle Creator wizard with a side widget that displays the names of the four main sections (wizard pages) that will be present in the Bundle Creator. The pages can be navigated using the Next and Back buttons. The <b>DlgCreateBundle</b> class inherits from <b>QWizard</b>, which is responsible for creating the wizard. For each of the wizard pages, four classes have been created, each subclassing <b>QWizardPage</b>. Each of these classes handles the specific code related to the corresponding section. The 4 sections are:
* Choose Resources
* Choose Tags
* Enter Bundle Details
* Enter Save Location
The side widget has been implemented as a <b>QWidget</b> that contains four labels arranged in a vertical layout. Apart from that, I also created the header file for the <b>WdgResourcePreview</b> class which would deal with the common UI for the Bundle Creator and the Resource Manager.
===== Week 2 =====
During this week, I focused on the development and integration of the <b>KisResourcePreview</b> class with the bundle creator and resource manager. I made several UI adjustments to cater specifically to the bundle creator, disabling certain features as needed. Additionally, I sourced icons from different locations and seamlessly integrated them into both dialogs. To achieve the desired visual aesthetics for the icons in the dialogs, I made necessary modifications to the <b>KisResourceItemDelegate</b> class. To enhance usability, I introduced a tool button that allows users to effortlessly switch between list view and grid view for better resource visualization.
[[File:SR2.png|left]]
Note how both of them share the same view (left section).
===== Week 3 =====
This week, I have successfully finished coding the <b>pageResourceChooser</b> and <b>TagChooser</b> classes. I have completed the implementation of their member functions and now, one can filter resources based on tags or names, facilitating efficient resource management. Moreover, one can conveniently add selected resource items to the designated "Selected" table for better organization. From the "Choose Tags" page, one can select the tags he wishes to embed.
[[File:Week3.gif|left]]
Apart from that, I completed the implementation of the tool button to switch between view modes. As a result, users can seamlessly switch between grid view and list view according to their personal preferences.
===== Week 4 =====
This week I completed the metadata information page (<b>Bundle Details Page</b>) and the bundle saver page (<b>Save to Page</b>). The Bundle Details page maintains consistency with the previous bundle creator, where one can fill out the bundle name, author, website etc.
[[File:demo5.png]]
As you can see, the new Save to Page provides a <b>summary</b> of the bundle details, which includes the number of selected resource items per resource type, and the tags chosen for embedding. This comprehensive summary allows users to review and confirm their bundle’s content before finalising the creation process.
The classes I created and implemented:
* <b>PageMetadataInfo</b>: For the metadata page
* <b>PageBundleSaver</b>: For the bundle saver page
For displaying the summary, I add to create queued signal slot connections between the following pairs:
* <b>Resource Choose Page</b> and <b>Bundle Saver Page</b> for displaying the count of selected resources per resource type
* <b>Tag Chooser Page</b> and <b>Bundle Saver Page</b> for listing the tags chosen for embedding
And finally, here is a demonstration of the fully functional Bundle Creator Wizard.
[[File:BundleCreator.gif]]
===== Week 5 =====
This week, I worked on re-designing the Tag Chooser Page of the Bundle Creator. Instead of sticking to a QComboBox, I opted for a tab-based design, with each tab representing a specific resource type. To implement each tab page, I created the '''WdgTagPreview''' class, where I replaced the traditional QListViews and QListWidgets with '''KisTagLabels''' for the Available list and '''KisTagSelectionWidget''' for the Selected list. The process of selecting tags is similar to how it's done in the Resource Manager.
[[File:Finaltags.png|left]]
Additionally, I spent some time on enhancing the appearance of the side widget. By adding icons and highlighting the selected page name, I managed to make it more visually appealing compared to its previous basic appearance.
===== Week 6 =====
I spent this week cleaning up the code and pushing final changes to the the merge request. I also dedicated some time to improving the side widget by enclosing it in a QFrame, which resulted in a more organized and visually appealing appearance. Additionally, I made adjustments to the highlight color of the labels for better visibility.
I remained active on KA, engaging with users to gather feedback on the user interface of the bundle creator. I also sought input on the bundle editing functionality to identify areas for further improvement.
===== Week 7 - 8 =====
I've dedicated these two weeks to implementing temporary bundle imports for editing. However, it appears that I've encountered a race condition that I haven't been able to resolve yet. I remained active on KA during the first weekend, received a few requests for modifications to the new interface. One of them was to change the resource type selection combobox to a writable combobox, allowing users to enter a partial name like "Bru" and have matching options such as "Brush Presets" and "Brushes" appear. Another request was to highlight the selected resource items in the "Available" table. I did some reading on Qt's threading during the second weekend and realized there might be a way to avoid using '''removeStorage()''', although I'm not sure if it's the right way to go about it.
===== Week 9 - 10 =====
[[File:Bundle_editor.gif|left]]
I focused mainly on enhancing the user interface of the Bundle Editor. Currently, the metadata and summary sections of the editor are functioning smoothly. Additionally, I've been devoting time to developing the resource selection and tag selection features.
===== Week 11 - 12 =====
Over the past two weeks, I focused on code cleanup and wrote the fifth blog post, where I explained the functioning of the Bundle Editor. Additionally, I dedicated some time to identifying and resolving several bugs that emerged during this period.
== Post GSoC ==
I've had a fun summer working on the Bundle Creator/Editor project for Krita. It's been a great learning opportunity, allowing me to dive deeper into both Krita and C++. Apart from that, I learnt UML diagrams and studied a few design patterns in Qt for writing one of my blog-posts. Some nasty bugs compelled me to learn the basics of threading in C++. Even though the official GSoC period is ending, I intend to continue working on the project till it's furnished and working perfectly. There are still a few bugs to work and a few tasks left to complete, including:
* Bug 1: Whenever a Gamut Mask, or Color Set present in the bundle, Krita crashes whenever a created bundle is edited twice. It occurs because in both KoGamutMask.cpp and KoColorSet.cpp the loadFromDevice() function has a Q_ASSERT(d->data.size() != 0);
* Bug 2: Whenever I create a bundle, and then open it again for editing, some of the resource items simply don't show up, and I notice a Could not load the resource from the bundle "gradients" "gradients/GPS Fire Incandescent.ggr" "/home/sriru/Downloads/bundles/c3.bundle" error. 
* Bug 3: Related to removeStorage()
* Write documentation for Bundle Creator/Editor.
== Important Commits ==
* [https://invent.kde.org/graphics/krita/-/merge_requests/1802/diffs?commit_id=2321de6a24a6013b090faf0e7f46fd442c8a2901 Improve Bundle Creator in Krita]
* [https://invent.kde.org/graphics/krita/-/merge_requests/1802/diffs?commit_id=04d40bc22fd5ecc897ba87108ed135370c3e7298 Implement Resource Chooser page]
* [https://invent.kde.org/graphics/krita/-/merge_requests/1802/diffs?commit_id=94c54d1806e035c076cfb6b92c3b9de3a9d69037 Add common UI to Resource Manager]
* [https://invent.kde.org/graphics/krita/-/merge_requests/1802/diffs?commit_id=e0cd7e47e3c7a75f2b95cee694e387da1ce9c707 Implement metadata and saver pages]
* [https://invent.kde.org/graphics/krita/-/merge_requests/1802/diffs?commit_id=3cb54b26df4a290fc8961f7415139cb2274839b4 Add toolbutton to switch views]
* [https://invent.kde.org/graphics/krita/-/merge_requests/1802/diffs?commit_id=b950caf321f7ea50fae9576f553ee686aa438f6c Add ToolButton for Selected Table]
* [https://invent.kde.org/graphics/krita/-/merge_requests/1802/diffs?commit_id=0553ff71046e8136241d03a17eb4dfcd637e9472 Apply background to icons]
* [https://invent.kde.org/graphics/krita/-/merge_requests/1802/diffs?commit_id=f672e61b865ed96b6dfa804449dc7829630d78ec Make icons smaller]
* [https://invent.kde.org/graphics/krita/-/merge_requests/1802/diffs?commit_id=443121afd18b366c96454b3f2098e8e5bf7fd2ec Add Summary]
* [https://invent.kde.org/graphics/krita/-/merge_requests/1802/diffs?commit_id=7bdf10e36639aa5ceec4103487f214fb1d213134 Add tags to summary]
* [https://invent.kde.org/graphics/krita/-/merge_requests/1802/diffs?commit_id=0d3a34baf12df9a129de3823cf456e7959e4aed5 Highlight side widget]
* [https://invent.kde.org/graphics/krita/-/merge_requests/1802/diffs?commit_id=90c8e2f6b8bc08a41c392a6c10f2fdd400779e39 Add enum for clarity]
* [https://invent.kde.org/graphics/krita/-/merge_requests/1802/diffs?commit_id=bacde075314042be235284c28270d4b9f5cacde5 Add enum in resource item viewer]
* [https://invent.kde.org/graphics/krita/-/merge_requests/1802/diffs?commit_id=6b257ec14c6cfec87cf0df1f947a09463c557047 Improve Tag Chooser]
* [https://invent.kde.org/graphics/krita/-/merge_requests/1802/diffs?commit_id=3fd7d08971a8e2c75ba79031d3e460d52bc23f5f Shift KisTagLabel to resourcewidgets]
* [https://invent.kde.org/graphics/krita/-/merge_requests/1802/diffs?commit_id=e91f4c96263976da0402ac31b8cf3b5f9f4b0b5a Add Bundle Editor UI code]
* [https://invent.kde.org/graphics/krita/-/merge_requests/1802/diffs?commit_id=b0d33b36e32c8b65005e3c9612e21b41e5b1764b Bundle Editor saving]
== Contacts ==
* <b>IRC</b>: Srirupa Datta (@sriru:libera.chat)
* <b>KDE identity</b>: [https://invent.kde.org/srirupa srirupa]
* <b>Email</b>: [email protected]
* <b>Krita Artists</b>: [https://krita-artists.org/u/srirupa_datta/summary Srirupa_Datta]
* <b>GitHub</b>: [https://github.com/srirupa19 Github]

Latest revision as of 08:23, 24 August 2023

Improving the Bundle Creator in Krita

Summary

The primary format to share resources in Krita is a Resource Bundle, which is a compressed file containing all the resources together. It also contains some other information like metadata and a manifest so Krita can check there’s no errors in the file.

Krita’s Bundle Creator allows one to create their own bundle from the resources of their choice. The project aims to improve the user interface of the current Bundle Creator, and allow the ability to edit bundles (which is currently not supported in Krita).


Project Proposal

Improving the Bundle Creator in Krita

Blog Posts

The list of all the blog posts for GSoC'23 has been listed here.

Merge Request

The merge request for this project can be viewed here.

Timeline

Week 1

I have created the Bundle Creator wizard with a side widget that displays the names of the four main sections (wizard pages) that will be present in the Bundle Creator. The pages can be navigated using the Next and Back buttons. The DlgCreateBundle class inherits from QWizard, which is responsible for creating the wizard. For each of the wizard pages, four classes have been created, each subclassing QWizardPage. Each of these classes handles the specific code related to the corresponding section. The 4 sections are:

  • Choose Resources
  • Choose Tags
  • Enter Bundle Details
  • Enter Save Location

The side widget has been implemented as a QWidget that contains four labels arranged in a vertical layout. Apart from that, I also created the header file for the WdgResourcePreview class which would deal with the common UI for the Bundle Creator and the Resource Manager.

Week 2

During this week, I focused on the development and integration of the KisResourcePreview class with the bundle creator and resource manager. I made several UI adjustments to cater specifically to the bundle creator, disabling certain features as needed. Additionally, I sourced icons from different locations and seamlessly integrated them into both dialogs. To achieve the desired visual aesthetics for the icons in the dialogs, I made necessary modifications to the KisResourceItemDelegate class. To enhance usability, I introduced a tool button that allows users to effortlessly switch between list view and grid view for better resource visualization.

Note how both of them share the same view (left section).


Week 3

This week, I have successfully finished coding the pageResourceChooser and TagChooser classes. I have completed the implementation of their member functions and now, one can filter resources based on tags or names, facilitating efficient resource management. Moreover, one can conveniently add selected resource items to the designated "Selected" table for better organization. From the "Choose Tags" page, one can select the tags he wishes to embed.

Apart from that, I completed the implementation of the tool button to switch between view modes. As a result, users can seamlessly switch between grid view and list view according to their personal preferences.


Week 4

This week I completed the metadata information page (Bundle Details Page) and the bundle saver page (Save to Page). The Bundle Details page maintains consistency with the previous bundle creator, where one can fill out the bundle name, author, website etc.

As you can see, the new Save to Page provides a summary of the bundle details, which includes the number of selected resource items per resource type, and the tags chosen for embedding. This comprehensive summary allows users to review and confirm their bundle’s content before finalising the creation process.

The classes I created and implemented:

  • PageMetadataInfo: For the metadata page
  • PageBundleSaver: For the bundle saver page

For displaying the summary, I add to create queued signal slot connections between the following pairs:

  • Resource Choose Page and Bundle Saver Page for displaying the count of selected resources per resource type
  • Tag Chooser Page and Bundle Saver Page for listing the tags chosen for embedding

And finally, here is a demonstration of the fully functional Bundle Creator Wizard.

Week 5

This week, I worked on re-designing the Tag Chooser Page of the Bundle Creator. Instead of sticking to a QComboBox, I opted for a tab-based design, with each tab representing a specific resource type. To implement each tab page, I created the WdgTagPreview class, where I replaced the traditional QListViews and QListWidgets with KisTagLabels for the Available list and KisTagSelectionWidget for the Selected list. The process of selecting tags is similar to how it's done in the Resource Manager.

Additionally, I spent some time on enhancing the appearance of the side widget. By adding icons and highlighting the selected page name, I managed to make it more visually appealing compared to its previous basic appearance.


Week 6

I spent this week cleaning up the code and pushing final changes to the the merge request. I also dedicated some time to improving the side widget by enclosing it in a QFrame, which resulted in a more organized and visually appealing appearance. Additionally, I made adjustments to the highlight color of the labels for better visibility.

I remained active on KA, engaging with users to gather feedback on the user interface of the bundle creator. I also sought input on the bundle editing functionality to identify areas for further improvement.

Week 7 - 8

I've dedicated these two weeks to implementing temporary bundle imports for editing. However, it appears that I've encountered a race condition that I haven't been able to resolve yet. I remained active on KA during the first weekend, received a few requests for modifications to the new interface. One of them was to change the resource type selection combobox to a writable combobox, allowing users to enter a partial name like "Bru" and have matching options such as "Brush Presets" and "Brushes" appear. Another request was to highlight the selected resource items in the "Available" table. I did some reading on Qt's threading during the second weekend and realized there might be a way to avoid using removeStorage(), although I'm not sure if it's the right way to go about it.

Week 9 - 10

I focused mainly on enhancing the user interface of the Bundle Editor. Currently, the metadata and summary sections of the editor are functioning smoothly. Additionally, I've been devoting time to developing the resource selection and tag selection features.


Week 11 - 12

Over the past two weeks, I focused on code cleanup and wrote the fifth blog post, where I explained the functioning of the Bundle Editor. Additionally, I dedicated some time to identifying and resolving several bugs that emerged during this period.

Post GSoC

I've had a fun summer working on the Bundle Creator/Editor project for Krita. It's been a great learning opportunity, allowing me to dive deeper into both Krita and C++. Apart from that, I learnt UML diagrams and studied a few design patterns in Qt for writing one of my blog-posts. Some nasty bugs compelled me to learn the basics of threading in C++. Even though the official GSoC period is ending, I intend to continue working on the project till it's furnished and working perfectly. There are still a few bugs to work and a few tasks left to complete, including:

  • Bug 1: Whenever a Gamut Mask, or Color Set present in the bundle, Krita crashes whenever a created bundle is edited twice. It occurs because in both KoGamutMask.cpp and KoColorSet.cpp the loadFromDevice() function has a Q_ASSERT(d->data.size() != 0);
  • Bug 2: Whenever I create a bundle, and then open it again for editing, some of the resource items simply don't show up, and I notice a Could not load the resource from the bundle "gradients" "gradients/GPS Fire Incandescent.ggr" "/home/sriru/Downloads/bundles/c3.bundle" error.
  • Bug 3: Related to removeStorage()
  • Write documentation for Bundle Creator/Editor.

Important Commits

Contacts

  • IRC: Srirupa Datta (@sriru:libera.chat)