←フエルチラシノウラ。トップページへもどる。

【Java】Eclipseのビューでも利用されているCTabFolderの簡単なサンプル。【SWT】

Java SWT Eclipse View CTabFolder CTabItem タブ ビュー

【Java】Eclipseのビューでも利用されているCTabFolderの簡単なサンプル。【SWT】

CTabFolderとは


Java開発環境でお馴染みのEclipseで使われているビュー(View)といえば分かるでしょうか。
フレキシブルにサイズが変更できる内部ウィンドウのようなものです。
以下のサンプルはそのCTabFolderコンポーネントの簡単な使い方です。
※ JFaceを利用しています。

サンプル


import org.eclipse.jface.window.ApplicationWindow;
import org.eclipse.swt.SWT;
import org.eclipse.swt.custom.CTabFolder;
import org.eclipse.swt.custom.CTabFolder2Adapter;
import org.eclipse.swt.custom.CTabFolderEvent;
import org.eclipse.swt.custom.CTabItem;
import org.eclipse.swt.graphics.Image;
import org.eclipse.swt.layout.GridData;
import org.eclipse.swt.layout.GridLayout;
import org.eclipse.swt.widgets.Composite;
import org.eclipse.swt.widgets.Control;
import org.eclipse.swt.widgets.Display;
import org.eclipse.swt.widgets.Shell;
import org.eclipse.swt.widgets.Text;

public class CTabFolderTest extends ApplicationWindow {

/**
* main
*
* @param args
*/
public static void main(String[] args) {
new CTabFolderTest().run();
}

/**
* constructor
*/
public CTabFolderTest() {
super(null);
}

/**
* Runs the application
*/
public void run() {
setBlockOnOpen(true);
open();
Display.getCurrent().dispose();
}

/**
* Configures the shell
*
* @param shell
* the shell
*/
@Override
protected void configureShell(Shell shell) {
super.configureShell(shell);
// set title.
shell.setText("CTabFolder Test.");
// set window size.
shell.setSize(400, 400);
}

/**
* put widgets on Parent Composite.
*/
@Override
protected Control createContents(Composite parent) {
/***********************************
* create base composite.
***********************************/
// create "final" instance.
final Composite c = new Composite(parent, SWT.NONE);
// set layout.
c.setLayout(new GridLayout());

/***********************************
* create CTabFolder.
***********************************/
// create "final" instance.
final CTabFolder folder = new CTabFolder(c, SWT.BORDER);
// set layoutData.
folder.setLayoutData(new GridData(SWT.FILL, SWT.FILL, true, false));
folder.setMinimizeVisible(true);
folder.setMaximizeVisible(true);
folder.setSimple(false);
folder.setUnselectedImageVisible(false);
folder.setUnselectedCloseVisible(false);
// add listener for min, max, and restore buttons.
folder.addCTabFolder2Listener(new CTabFolder2Adapter() {
public void minimize(CTabFolderEvent event) {
folder.setMinimized(true);
c.layout(true);
}
public void maximize(CTabFolderEvent event) {
folder.setMaximized(true);
folder.setLayoutData(new GridData(SWT.FILL, SWT.FILL, true,
true));
c.layout(true);
}
public void restore(CTabFolderEvent event) {
folder.setMinimized(false);
folder.setMaximized(false);
folder.setLayoutData(new GridData(SWT.FILL, SWT.FILL, true,
false));
c.layout(true);
}
});

/***********************************
* create CTabItems.
***********************************/
for (int i = 0; i < 5; i++) {
// create CTabItem instance.
CTabItem item = new CTabItem(folder, SWT.CLOSE);
// set title of CTabItem.
item.setText("Item " + i);
// set image icon of CTabItem.
item.setImage(new Image(getShell().getDisplay(), 16, 16));
// put Text widget on "CTabFolder" composite. Don't put on CTabItem.
Text text = new Text(folder, SWT.MULTI | SWT.V_SCROLL
| SWT.H_SCROLL);
text.setText("Text for item " + i
+ "nnhogehoge.");
// set Text widget's control to CTabItem.
item.setControl(text);
}

return parent;
}
}


ポイント


1) ベースとなるコンポジットを作成
2) 1)の上にCTabFolderを乗せます。
3) 2)のCTabFolderにサイズ変更ボタンのリスナ(addCTabFolder2Listener)を追加します。
4) 2)のCTabFolderの上にCTabItemを乗せます。
5) 適当なコンポーネントを "CTabFolder" の上に乗せていきます。※注意 CTabItemの上ではありません!
6) CTabItemに 5) で作った適当なコンポーネントをsetControlします。


参考


SWTのチラシノウラ
http://goodjob.boy.jp/chirashinoura/search/SWT.html

http://goodjob.boy.jp/chirashinoura/id/163.html

作成日: 2007-10-18 10:25:01

最終更新日: 2007-10-18 10:25:01

▲このページの上へ