gecko-dev/cmd/xfe/Microline3.0/examples/grid5.c

207 строки
6.1 KiB
C

/* -*- Mode: C; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 2 -*-
*
* The contents of this file are subject to the Netscape Public
* License Version 1.1 (the "License"); you may not use this file
* except in compliance with the License. You may obtain a copy of
* the License at http://www.mozilla.org/NPL/
*
* Software distributed under the License is distributed on an "AS
* IS" basis, WITHOUT WARRANTY OF ANY KIND, either express or
* implied. See the License for the specific language governing
* rights and limitations under the License.
*
* The Original Code is mozilla.org code.
*
* The Initial Developer of the Original Code is Netscape
* Communications Corporation. Portions created by Netscape are
* Copyright (C) 1998 Netscape Communications Corporation. All
* Rights Reserved.
*
* Contributor(s):
*/
/*
* The following source code is part of the Microline Widget Library.
* The Microline widget library is made available to Mozilla developers
* under the Netscape Public License (NPL) by Neuron Data. To learn
* more about Neuron Data, please visit the Neuron Data Home Page at
* http://www.neurondata.com.
*/
#include <Xm/Xm.h>
#include <XmL/Grid.h>
#define TITLEFONT "-*-helvetica-bold-r-*--*-140-*-*-*-*-iso8859-1"
#define BOLDFONT "-*-helvetica-bold-r-*--*-120-*-*-*-*-iso8859-1"
#define TEXTFONT "-*-helvetica-medium-r-*--*-100-*-*-*-*-iso8859-1"
static char *data =
"|1996 Income Summary\n\
|Shampoo|Conditioner|Soap|Total\n\
Revenues:\n\
Sales|$ 1,600,000|$ 1,000,000|$ 800,000|$ 3,400,000\n\
Less Discounts|(16,000)|(10,000)|(8,000)|(34,000)\n\
Less Return Allowance|(8,000)|(5,000)|(4,000)|(17,000)\n\
Net Revenue|1,576,000|985,000|792,000|3,349,000\n\
\n\
Less Expenses:\n\
Cost of Goods Sold|(640,000)|(330,000)|(264,000)|(1,234,000)\n\
Salary Expense|(380,000)|(280,000)|(180,000)|(840,000)\n\
Marketing Expense|(157,600)|(98,500)|(79,200)|(335,300)\n\
Rent Expense|(36,000)|(36,000)|(36,000)|(108,000)\n\
Misc. Other Expense|(36,408)|(22,335)|(16,776)|(75,519)\n\
Total Expenses|(1,250,008)|(766,835)|(575,976)|(2,592,819)\n\
\n\
Income Tax Expense|(130,397)|(87,266)|(86,410)|(304,072)\n\
Net Income|195,595|130,899|129,614|456,109";
main(argc, argv)
int argc;
char *argv[];
{
XtAppContext app;
Widget shell, grid;
int i, r;
shell = XtAppInitialize(&app, "Grid5", NULL, 0,
&argc, argv, NULL, NULL, 0);
grid = XtVaCreateManagedWidget("grid",
xmlGridWidgetClass, shell,
XtVaTypedArg, XmNbackground, XmRString, "#C0C0C0", 8,
XtVaTypedArg, XmNforeground, XmRString, "black", 6,
XmNheadingColumns, 1,
XmNcolumns, 3,
XmNfooterColumns, 1,
XmNsimpleWidths, "24c 11c 11c 11c 11c",
XmNvisibleColumns, 10,
XmNvisibleRows, 14,
XtVaTypedArg, XmNfontList, XmRString, TEXTFONT,
strlen(TEXTFONT) + 1,
XmNselectionPolicy, XmSELECT_NONE,
NULL);
XtVaSetValues(grid,
XmNlayoutFrozen, True,
NULL);
/* Add 'Income Summary' heading row with yellow background */
XtVaSetValues(grid,
XmNcellDefaults, True,
XtVaTypedArg, XmNcellBackground, XmRString, "#FFFF00", 8,
XtVaTypedArg, XmNcellForeground, XmRString, "#000080", 8,
XmNcellLeftBorderType, XmBORDER_NONE,
XmNcellRightBorderType, XmBORDER_NONE,
XmNcellTopBorderType, XmBORDER_NONE,
XtVaTypedArg, XmNcellBottomBorderColor, XmRString, "black", 6,
XmNcellAlignment, XmALIGNMENT_CENTER,
NULL);
XmLGridAddRows(grid, XmHEADING, -1, 1);
/* Set span on '1996 Income Summary' cell in heading row */
XtVaSetValues(grid,
XmNrowType, XmHEADING,
XmNrow, 0,
XmNcolumn, 0,
XmNcellColumnSpan, 2,
XtVaTypedArg, XmNcellFontList, XmRString, TITLEFONT,
strlen(TITLEFONT) + 1,
NULL);
/* Add 'Shampoo Conditioner Soap' heading row with white background */
XtVaSetValues(grid,
XmNcellDefaults, True,
XtVaTypedArg, XmNcellFontList, XmRString, BOLDFONT,
strlen(BOLDFONT) + 1,
XtVaTypedArg, XmNcellBackground, XmRString, "white", 6,
XtVaTypedArg, XmNcellForeground, XmRString, "black", 6,
XmNcellBottomBorderType, XmBORDER_NONE,
NULL);
XmLGridAddRows(grid, XmHEADING, -1, 1);
/* Add content and footer rows with heading column 0 left justified */
XtVaSetValues(grid,
XmNcellDefaults, True,
XmNcellAlignment, XmALIGNMENT_RIGHT,
XtVaTypedArg, XmNcellFontList, XmRString, TEXTFONT,
strlen(TEXTFONT) + 1,
NULL);
XtVaSetValues(grid,
XmNcellDefaults, True,
XmNcolumnType, XmHEADING,
XmNcolumn, 0,
XmNcellAlignment, XmALIGNMENT_LEFT,
NULL);
XmLGridAddRows(grid, XmCONTENT, -1, 15);
/* Add footer row with blue background */
XtVaSetValues(grid,
XmNcellDefaults, True,
XtVaTypedArg, XmNcellForeground, XmRString, "white", 6,
XtVaTypedArg, XmNcellBackground, XmRString, "#000080", 8,
XtVaTypedArg, XmNcellFontList, XmRString, BOLDFONT,
strlen(BOLDFONT) + 1,
NULL);
XmLGridAddRows(grid, XmFOOTER, -1, 1);
/* Bold 'Revenues' cell */
XtVaSetValues(grid,
XmNcolumnType, XmHEADING,
XmNcolumn, 0,
XmNrow, 0,
XtVaTypedArg, XmNcellFontList, XmRString, BOLDFONT,
strlen(BOLDFONT) + 1,
NULL);
/* Bold 'Less Expenses' cell */
XtVaSetValues(grid,
XmNcolumnType, XmHEADING,
XmNcolumn, 0,
XmNrow, 6,
XtVaTypedArg, XmNcellFontList, XmRString, BOLDFONT,
strlen(BOLDFONT) + 1,
NULL);
/* Grey middle and footer content column */
XtVaSetValues(grid,
XmNcolumnType, XmALL_TYPES,
XmNcolumnRangeStart, 2,
XmNcolumnRangeEnd, 4,
XmNcolumnStep, 2,
XtVaTypedArg, XmNcellBackground, XmRString, "#E8E8E8", 8,
NULL);
/* Grey 'Conditioner' and 'Total' cell in heading row 1 */
XtVaSetValues(grid,
XmNrowType, XmHEADING,
XmNrow, 1,
XmNcolumnType, XmALL_TYPES,
XmNcolumnRangeStart, 2,
XmNcolumnRangeEnd, 4,
XmNcolumnStep, 2,
XtVaTypedArg, XmNcellBackground, XmRString, "#E8E8E8", 8,
NULL);
/* Blue and bold 'Net Revenue' and 'Total Expenses' rows */
XtVaSetValues(grid,
XmNrowRangeStart, 4,
XmNrowRangeEnd, 12,
XmNrowStep, 8,
XmNcolumnType, XmALL_TYPES,
XtVaTypedArg, XmNcellForeground, XmRString, "white", 6,
XtVaTypedArg, XmNcellBackground, XmRString, "#000080", 8,
XtVaTypedArg, XmNcellFontList, XmRString, BOLDFONT,
strlen(BOLDFONT) + 1,
NULL);
XtVaSetValues(grid,
XmNlayoutFrozen, False,
NULL);
XmLGridSetStrings(grid, data);
XtRealizeWidget(shell);
XtAppMainLoop(app);
}