-
Notifications
You must be signed in to change notification settings - Fork 1.6k
Add a module panel
How to create a panel for plugin features, similar to Ranking, Graph or Layout? It is easy and fully integrated in Netbeans. Create your panel class and use Netbeans IDE to design the user interface. This page also explains how to work with the Perspective system.
-
Step 1: Right click on your module and select New > Other... and find Window like showed in the step 1 below. The window wizard asks where to put your panel. You can use already defined modes (i.e. positions):
- graphmode: Centered, full-size
- rankingmode: Top Left position
- layoutmode: Bottom Left position
- timelinemode: Below others, at the bottom
- filtersmode: Bottom Right
- contextmode: Top Right
- Step 2: Then check options about the panel policy showed in step2 and click on Next.
- Step 3: Fill the Class Name, the system shows which files are created. Your panel is a TopComponent subclass.
- Step 4: Click on Finish, files are created and you're invited to design your panel with Netbeans editor.
Your panel is now created and automatically registered. Start Gephi with your plugin and your panel is visible.
Overview, Data Laboratory and Preview are perspectives in Gephi. A perspective is simply a set of panels that works together. When users change the perspective, some panels are hidden and others are showed. When you define a new panel above, it is not part of a perspective and therefore is always visible, regardless which perspective you are. Follow the steps to associate your panel with a perspective.
- Add Desktop Perspective as a new module dependency. Right-click on your module and Properties.
- Go to your
TopComponent
sources and addPerspectiveMember
as interface. - Add the
@ServiceProvider
annotation to be registered by the system and implement methods (note: you will need to add the 'Desktop Perspective' to the Module Dependencies screenshots).
@ServiceProvider(service=PerspectiveMember.class)
public final class MyTopComponent extends TopComponent implements PerspectiveMember {
...
```java
Implement `open()` and `close()` methods like below to attach the component to the `LaboratoryPerspective`, works also for `OverviewPerspective` and `PreviewPerspective`:
```java
public boolean open(Perspective perspective) {
return perspective instanceof LaboratoryPerspective;
}
public boolean close(Perspective perspective) {
return true;
}
Specifically use close()
method if you want your panel to be visible on several perspectives.
Open the Bundle.properties file in your module and update CTL_MyTopComponent key.
In the TopComponent sources, uncomment the following line and set the icon path.
setIcon(ImageUtilities.loadImage(ICON_PATH, true));
- Developer Handbook
- Build
- Code Style
- Localization
- Datasets
- Import CSV Data
- Import Dynamic Data
- Scripting Plugin
- Quick Start
- Démarrage rapide (FR)
- Layout
- Spatialisations (FR)
- Statistics
- Import
- Spigot importer with Wizard
- Export
- Generator
- Filter
- Extend Data Laboratory
- Preview renderer
- Add a module panel
- Add a submenu
- Build a plugin without Gephi source code
- Update a plugin
- Code Sharing Strategy
- Graph Streaming