posts - 6, comments - 1, trackbacks - 0, articles - 0

2008年9月9日

public class NameManager implements INameManager {
       private Set namePool = new HashSet();
      

    public String generateName(String nameType) {

        if (!namePool.contains(nameType)) {
       namePool.add(nameType);
        return nameType;
  }

  int i = 1;
  while (namePool.contains(nameType + i)) {
   i++;
  }
  namePool.add(nameType + i);
  return nameType + i;
 }


posted @ 2008-09-23 11:44 jr4e 阅读(129) | 评论 (0)编辑 收藏

 ImageDescriptor temp = ImageDescriptor.createFromURL(url);

 org.eclipse.swt.graphics.Image image = temp.createImage();

posted @ 2008-09-19 12:38 jr4e 阅读(142) | 评论 (0)编辑 收藏

1.通过获得当前激活的editor来得到NameManager
IEditorPart editor = PlatformUI.getWorkbench()
    .getActiveWorkbenchWindow().getActivePage().getActiveEditor();
  ReportEditor reportEditor = null;
  if (editor instanceof ReportEditor)
   reportEditor = (ReportEditor) editor;

  String dsDisplayName = reportEditor.getDisplaynameByQDSName(table
    .getDataSet());
  INameManager nameManager = ((ReportEditorInput) reportEditor
    .getEditorInput()).getNameManager();
2.获得editPart的祖先的方法
GefUtilities.getAncestorOfClass(Class c, EditPart editPart)
public static EditPart getAncestorOfClass(Class c, EditPart editPart)

3.获得模型祖先的方法
ModelUtilities.getAncestorOfClass(Class c, EObject model));
public static EObject getAncestorOfClass(Class c, EObject model)

posted @ 2008-09-18 18:55 jr4e 阅读(181) | 评论 (0)编辑 收藏

Eclipse的Wizard是由一系列WizardPage组成的。缺省情况下,WizardDialog在初始化的时候就会调用每个WizardPage的createControl()方法来布局这些WizardPage,这是为了方便决定WizardDialog窗口的大小。但如果某个WizardPage里的控件是需要动态生成的,例如,用户在Page1里输入一个整数n,Page2里要根据这个整数生成n个文本框,由于Page2的createControl()只有一次被调用的机会,并且在得到n之前就被WizardDialog调用过了,集中布局的方式就为生成Page2的界面带来了困难。

和问题的描述比起来,解决的方法简单很多,只要覆盖Wizard的createPageControls()方法让它什么都不要做就可以了
@Override
public void createPageControls(Composite pageContainer) {
    
//super.createPageControls(pageContainer);
}

posted @ 2008-09-09 10:15 jr4e 阅读(294) | 评论 (1)编辑 收藏