stackLayout

原创 2006年06月18日 12:54:00

StackLayout stackLayout = new StackLayout();
Composite clabels = createComposite(body, SWT.BORDER,
                                    stackLayout);
Label[] labels = new Label[5];
:
for (int i = 0; i < labels.length; i++) {
    Label xlabel = new Label(clabels, SWT.CENTER);
    xlabel.setText("Stack " + i);
    labels[i] = xlabel;
}
stackLayout.topControl = labels[0];
:
protected Composite createComposite(Composite parent,
                                    int style,
                                    Layout layout) {
    Composite c =  new Composite(parent, style);
    if (layout != null) {
        c.setLayout(layout);
    }
    return c;
}
protected Composite createComposite(Composite parent,
                                    Layout layout) {
    return createComposite(parent, SWT.NONE, layout);
}

////////////////////////////

another example

//////////////////

/*******************************************************************************
* Copyright (c) 2000, 2003 IBM Corporation and others.
* All rights reserved. This program and the accompanying materials
* are made available under the terms of the Common Public License v1.0
* which accompanies this distribution, and is available at
* http://www.eclipse.org/legal/cpl-v10.html
*
* Contributors:
*     IBM Corporation - initial API and implementation
*******************************************************************************/

package org.eclipse.swt.custom;


import org.eclipse.swt.*;
import org.eclipse.swt.graphics.*;
import org.eclipse.swt.widgets.*;

/**
* This Layout stacks all the controls one on top of the other and resizes all controls
* to have the same size and location.
* The control specified in topControl is visible and all other controls are not visible.
* Users must set the topControl value to flip between the visible items and then call
* layout() on the composite which has the StackLayout.
*
* <p> Here is an example which places ten buttons in a stack layout and
* flips between them:
*
* <pre><code>
* public static void main(String[] args) {
* Display display = new Display();
* Shell shell = new Shell(display);
* shell.setLayout(new GridLayout());
*
* final Composite parent = new Composite(shell, SWT.NONE);
* parent.setLayoutData(new GridData(GridData.FILL_BOTH));
* final StackLayout layout = new StackLayout();
* parent.setLayout(layout);
* final Button[] bArray = new Button[10];
* for (int i = 0; i &lt; 10; i++) {
* bArray[i] = new Button(parent, SWT.PUSH);
* bArray[i].setText("Button "+i);
* }
* layout.topControl = bArray[0];
*
* Button b = new Button(shell, SWT.PUSH);
* b.setText("Show Next Button");
* final int[] index = new int[1];
* b.addListener(SWT.Selection, new Listener(){
* public void handleEvent(Event e) {
* index[0] = (index[0] + 1) % 10;
* layout.topControl = bArray[index[0]];
* parent.layout();
* }
* });
*
* shell.open();
* while (shell != null && !shell.isDisposed()) {
* if (!display.readAndDispatch())
* display.sleep();
* }
* }
* </code></pre>
*/


public class StackLayout extends Layout {

/**
* marginWidth specifies the number of pixels of horizontal margin
* that will be placed along the left and right edges of the layout.
*
* The default value is 0.
*/

public int marginWidth = 0;
/**
* marginHeight specifies the number of pixels of vertical margin
* that will be placed along the top and bottom edges of the layout.
*
* The default value is 0.
*/

public int marginHeight = 0;

/**
* topControl the Control that is displayed at the top of the stack.
* All other controls that are children of the parent composite will not be visible.
*/

public Control topControl;

protected Point computeSize(Composite composite, int wHint, int hHint, boolean flushCache) {
Control children[] = composite.getChildren();

int maxWidth = 0;
int maxHeight = 0;
for (int i = 0; i < children.length; i++) {
Point size = children[i].computeSize(wHint, hHint, flushCache);
maxWidth = Math.max(size.x, maxWidth);
maxHeight = Math.max(size.y, maxHeight);
}

int width = wHint, height = hHint;
if (wHint == SWT.DEFAULT) width = maxWidth;
if (hHint == SWT.DEFAULT) height = maxHeight;
return new Point(width + 2 * marginWidth, height + 2 * marginHeight);
}

protected void layout(Composite composite, boolean flushCache) {
Control children[] = composite.getChildren();
Rectangle rect = composite.getClientArea();
rect.x += marginWidth;
rect.y += marginHeight;
rect.width -= 2 * marginWidth;
rect.height -= 2 * marginHeight;
for (int i = 0; i < children.length; i++) {
children[i].setBounds(rect);
children[i].setVisible(children[i] == topControl);

}
}
String getName () {
String string = getClass ().getName ();
int index = string.lastIndexOf ('.');
if (index == -1) return string;
return string.substring (index + 1, string.length ());
}
public String toString () {
String string = getName ()+" {";
if (marginWidth != 0) string += "marginWidth="+marginWidth+" ";
if (marginHeight != 0) string += "marginHeight="+marginHeight+" ";
if (topControl != null) string += "topControl="+topControl+" ";
string = string.trim();
string += "}";
return string;
}
}


版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

swing stackLayout 包

  • 2013-04-02 11:09
  • 1.31MB
  • 下载

自定义层叠布局StackLayout

一.效果1.层叠显示,通过xml属性可控制Y轴偏移量,X轴偏移量,缩放比例。 //Y轴方向的偏移量,负数向上偏移,正数向下偏移 <attr name="of...

Xamarin.Forms 用户界面——控件——布局——StackLayout

StackLayout 使用StackLayout来显示一个维度的视图集合。 PDF用于离线使用 下载PDF 示例代码: 布局 BusinessTumble示例 相关文章: L...

xamarin.forms使用stacklayout自定义列表及相关加载状态处理。

xamarin.forms本身有提供ListView控件,个人觉得不够灵活,而且在和ScrollView嵌套使用时,会存在内外两个滚动条问题,不好处理。 我们可以用ScrollView和StackL...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)