Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Added menu option for Change Element -> Other…
This allow for input of any element Solves bug 3445
- Loading branch information
Showing
2 changed files
with
115 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
105 changes: 105 additions & 0 deletions
105
.../net.bioclipse.cdk.jchempaint/src/net/bioclipse/cdk/jchempaint/handlers/AddOtherAtom.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,105 @@ | ||
package net.bioclipse.cdk.jchempaint.handlers; | ||
|
||
import static org.eclipse.jface.window.Window.OK; | ||
|
||
import java.util.ArrayList; | ||
import java.util.Collection; | ||
import java.util.List; | ||
|
||
import org.eclipse.core.commands.ExecutionEvent; | ||
import org.eclipse.core.commands.ExecutionException; | ||
import org.eclipse.core.commands.IHandler; | ||
import org.eclipse.core.runtime.IAdaptable; | ||
import org.eclipse.jface.window.ApplicationWindow; | ||
import org.eclipse.swt.SWT; | ||
import org.eclipse.swt.events.SelectionEvent; | ||
import org.eclipse.swt.events.SelectionListener; | ||
import org.eclipse.swt.widgets.Combo; | ||
import org.eclipse.swt.widgets.Composite; | ||
import org.eclipse.swt.widgets.Control; | ||
import org.eclipse.swt.widgets.Shell; | ||
import org.eclipse.ui.IWorkbenchWindow; | ||
import org.eclipse.ui.handlers.HandlerUtil; | ||
import org.openscience.cdk.controller.IChemModelRelay; | ||
import org.openscience.cdk.controller.edit.CompositEdit; | ||
import org.openscience.cdk.controller.edit.IEdit; | ||
import org.openscience.cdk.controller.edit.SetSymbol; | ||
import org.openscience.cdk.interfaces.IAtom; | ||
import org.openscience.cdk.tools.periodictable.PeriodicTable; | ||
|
||
|
||
public class AddOtherAtom extends AbstractJChemPaintHandler implements IHandler { | ||
|
||
@Override | ||
public Object execute( ExecutionEvent event ) throws ExecutionException { | ||
IChemModelRelay relay = getChemModelRelay( event ); | ||
Collection<?> c = getSelection( event ); | ||
|
||
IWorkbenchWindow window = HandlerUtil | ||
.getActiveWorkbenchWindowChecked(event); | ||
AddAtomDialog dialog = new AddAtomDialog( window.getShell() ); | ||
int result = dialog.open(); | ||
if(result == OK ) | ||
setAtoms(relay,c,dialog.getInput()); | ||
return null; | ||
} | ||
|
||
private void setAtoms(IChemModelRelay relay,Collection<?> c,String o) { | ||
|
||
List<IEdit> edits = new ArrayList<IEdit>(c.size()); | ||
for(Object element: c) { | ||
IAtom atom = null; | ||
if(element instanceof IAdaptable) | ||
atom = (IAtom) ((IAdaptable)element).getAdapter( IAtom.class ); | ||
if(atom!=null) | ||
edits.add( SetSymbol.setSymbol( atom, o ) ); | ||
} | ||
relay.execute( CompositEdit.compose( edits ) ); | ||
} | ||
|
||
} | ||
|
||
class AddAtomDialog extends ApplicationWindow { | ||
|
||
private String input; | ||
|
||
public AddAtomDialog(Shell parentShell) { | ||
super( parentShell ); | ||
setBlockOnOpen( true ); | ||
setShellStyle( SWT.NONE ); | ||
} | ||
|
||
@Override | ||
protected Control createContents( Composite parent ) { | ||
final Combo combo = new Combo( parent, SWT.SIMPLE ); | ||
combo.setItems( getAtomicNumbers() ); | ||
combo.addSelectionListener( new SelectionListener() { | ||
|
||
@Override | ||
public void widgetSelected( SelectionEvent e ) { | ||
} | ||
|
||
@Override | ||
public void widgetDefaultSelected( SelectionEvent e ) { | ||
input = combo.getText(); | ||
AddAtomDialog.this.setReturnCode( OK ); | ||
AddAtomDialog.this.close(); | ||
} | ||
} ); | ||
return parent; | ||
} | ||
|
||
public String getInput() { return input;} | ||
|
||
public static String[] getAtomicNumbers() { | ||
List<String> candidates = new ArrayList<String>(112); | ||
for(int i=1;i<200;i++) { | ||
String symbol = PeriodicTable.getSymbol( i ); | ||
if( symbol!=null) { | ||
candidates.add( symbol ); | ||
} | ||
} | ||
return candidates.toArray( new String[candidates.size()] ); | ||
} | ||
|
||
} |