Development/Tutorials/Kross/ActionCollections: Difference between revisions
Mark for updating |
|||
(3 intermediate revisions by 2 users not shown) | |||
Line 1: | Line 1: | ||
{{Review|Port to KF5}} | |||
== Basics == | == Basics == | ||
Kross::ActionCollections, much like KActionCollections, represent a group of actions. A Kross::ActionCollection is used to group Kross::Actions together and collectively give them an icon, description, name and display text. | Kross::ActionCollections, much like KActionCollections, represent a group of actions. A Kross::ActionCollection is used to group Kross::Actions together and collectively give them an icon, description, name and display text. | ||
You can create a new Kross::ActionCollection like this: | You can create a new Kross::ActionCollection like this: | ||
< | <syntaxhighlight lang="cpp"> | ||
actionCollection = new Kross::ActionCollection("actioncollection",Kross::Manager::self().actionCollection()); | actionCollection = new Kross::ActionCollection("actioncollection",Kross::Manager::self().actionCollection()); | ||
</ | </syntaxhighlight> | ||
The first parameter, "actioncollection" in the example above, can be replaced by any name you want and should be useful and reasonably chosen. Passing in the collection returned by Kross::Manager::self()->actionCollection() defines that this is a toplevel collection. This is usefull if you want to have sub collections for different types of Kross::Actions. | The first parameter, "actioncollection" in the example above, can be replaced by any name you want and should be useful and reasonably chosen. Passing in the collection returned by Kross::Manager::self()->actionCollection() defines that this is a toplevel collection. This is usefull if you want to have sub collections for different types of Kross::Actions. | ||
== Using it == | == Using it == | ||
Now that we have created a Kross::ActionCollection it is time to populate it with Kross::Actions. Therefore we next create some actions, each of which can have different code and interpreters. | Now that we have created a Kross::ActionCollection it is time to populate it with Kross::Actions. Therefore we next create some actions, each of which can have different code and interpreters. | ||
< | <syntaxhighlight lang="cpp"> | ||
Kross::Action *action1 = new Kross::Action(actionCollection,QUrl("path/to/some/snippet.py")); | Kross::Action *action1 = new Kross::Action(actionCollection,QUrl("path/to/some/snippet.py")); | ||
Kross::Action *action2 = new Kross::Action(actionCollection,QUrl("path/to/some/snippet.js")); | Kross::Action *action2 = new Kross::Action(actionCollection,QUrl("path/to/some/snippet.js")); | ||
Kross::Action *action3 = new Kross::Action(actionCollection,QUrl("path/to/some/snippet.rb")); | Kross::Action *action3 = new Kross::Action(actionCollection,QUrl("path/to/some/snippet.rb")); | ||
</ | </syntaxhighlight> | ||
Each time we declare an Action, we gave it the Kross::ActionCollection the Action should be a child of as the first parameter and a path to a file as the second. | Each time we declare an Action, we gave it the Kross::ActionCollection the Action should be a child of as the first parameter and a path to a file as the second. | ||
' | ' | ||
Line 20: | Line 22: | ||
Once we have declared the Kross::Actions we can either access them by their fully qualified name (the second Argument in the constructor) : | Once we have declared the Kross::Actions we can either access them by their fully qualified name (the second Argument in the constructor) : | ||
< | <syntaxhighlight lang="cpp"> | ||
actioncollection->action("path/to/some/snippet.js"); | actioncollection->action("path/to/some/snippet.js"); | ||
</ | </syntaxhighlight> | ||
or iterate through all Kross::Actions and trigger those that match a pattern for example: | or iterate through all Kross::Actions and trigger those that match a pattern for example: | ||
< | <syntaxhighlight lang="cpp"> | ||
foreach(Kross::Action* myAction, actioncollection->actions()) { | foreach(Kross::Action* myAction, actioncollection->actions()) { | ||
if(myAction->name().contains("py", Qt::CaseInsensitive)) { | if(myAction->name().contains("py", Qt::CaseInsensitive)) { | ||
Line 32: | Line 34: | ||
} | } | ||
} | } | ||
</ | </syntaxhighlight> | ||
Notice that we connected the SIGNAL finished(Kross::Action*) before triggering the script. Otherwise the SLOT finished(Kross::Action*) won't run. | Notice that we connected the SIGNAL finished(Kross::Action*) before triggering the script. Otherwise the SLOT finished(Kross::Action*) won't run. | ||
Latest revision as of 08:22, 31 May 2019
Parts to be reviewed:
Port to KF5Basics
Kross::ActionCollections, much like KActionCollections, represent a group of actions. A Kross::ActionCollection is used to group Kross::Actions together and collectively give them an icon, description, name and display text.
You can create a new Kross::ActionCollection like this:
actionCollection = new Kross::ActionCollection("actioncollection",Kross::Manager::self().actionCollection());
The first parameter, "actioncollection" in the example above, can be replaced by any name you want and should be useful and reasonably chosen. Passing in the collection returned by Kross::Manager::self()->actionCollection() defines that this is a toplevel collection. This is usefull if you want to have sub collections for different types of Kross::Actions.
Using it
Now that we have created a Kross::ActionCollection it is time to populate it with Kross::Actions. Therefore we next create some actions, each of which can have different code and interpreters.
Kross::Action *action1 = new Kross::Action(actionCollection,QUrl("path/to/some/snippet.py"));
Kross::Action *action2 = new Kross::Action(actionCollection,QUrl("path/to/some/snippet.js"));
Kross::Action *action3 = new Kross::Action(actionCollection,QUrl("path/to/some/snippet.rb"));
Each time we declare an Action, we gave it the Kross::ActionCollection the Action should be a child of as the first parameter and a path to a file as the second. '
Once we have declared the Kross::Actions we can either access them by their fully qualified name (the second Argument in the constructor) :
actioncollection->action("path/to/some/snippet.js");
or iterate through all Kross::Actions and trigger those that match a pattern for example:
foreach(Kross::Action* myAction, actioncollection->actions()) {
if(myAction->name().contains("py", Qt::CaseInsensitive)) {
myAction->setInterpreter("python");
connect(myAction,SIGNAL(finished(Kross::Action* )),this ,SLOT(finished(Kross::Action*)));
myAction->trigger();
}
}
Notice that we connected the SIGNAL finished(Kross::Action*) before triggering the script. Otherwise the SLOT finished(Kross::Action*) won't run.
What now?
With the ActionCollection and the metadata interfaces such as name() icon() and description() you can create a small MVC so users can enable/disable some of the actions you loaded from your files.
Happy hacking!