1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
|
#include <Xw_Extension.h>
/* ifdef then trace on */
#ifdef TRACE
#define TRACE_SET_MARKER_ATTRIB
#endif
/*
XW_ATTRIB Xw_set_marker_attrib (awindow,color,type,width,mode):
XW_EXT_WINDOW *awindow
int color ; Color index to used 0 >= x < MAXCOLOR
int type ; Type can be TRUE if marker must be filled with the
set_poly_attrib attributes
int width ; Width index to used 0 >= x < MAXWIDTH
DRAWMODE mode ; Draw Mode must be one of DRAWMODE enum
Set Marker Color,Type and Marker current graphic attrib .
Returns Selected Marker Attribute Index if successful
Returns 0 if Bad Color,Type or Marker Index
*/
#ifdef XW_PROTOTYPE
XW_ATTRIB Xw_set_marker_attrib (void *awindow,int color,int type,int width,XW_DRAWMODE mode)
#else
XW_ATTRIB Xw_set_marker_attrib (awindow,color,type,width,mode)
void *awindow;
int color,type ;
int width ;
XW_DRAWMODE mode ;
#endif /*XW_PROTOTYPE*/
{
XW_EXT_WINDOW *pwindow = (XW_EXT_WINDOW*)awindow;
XGCValues gc_values ;
XW_ATTRIB code ;
int i,j,k,function,mask = 0;
unsigned long planemask,hcolor ;
if( !Xw_isdefine_window(pwindow) ) {
/*ERROR*Bad EXT_WINDOW Address*/
Xw_set_error(24,"Xw_set_marker_attrib",pwindow) ;
return (0) ;
}
if( _BINDEX > 0 ) return (1) ;
if ( !Xw_isdefine_color(_COLORMAP,color) ) {
/*ERROR*Bad Defined Color*/
Xw_set_error(41,"Xw_set_marker_attrib",&color) ;
return (0) ;
}
if ( !Xw_isdefine_width(_WIDTHMAP,width) ) {
/*WARNING*Bad Defined Width*/
Xw_set_error(52,"Xw_set_marker_attrib",&width) ;
width = 0 ;
}
if( !_WIDTHMAP || (_WIDTHMAP->widths[width] <= 1) ) width = 0 ;
code = QGCODE(color,type,width,mode) ;
if( code == pwindow->qgmark[pwindow->markindex].code ) {
/* The last index computed is already set*/
pwindow->qgmark[pwindow->markindex].count++ ;
return (pwindow->markindex+1) ;
}
for( i=j=0,k=MAXQG ; i<MAXQG ; i++ ) {
if( code == pwindow->qgmark[i].code ) k = i ;
if( pwindow->qgmark[i].count < pwindow->qgmark[j].count ) j = i;
}
if( k < MAXQG ) {
/* A GC index already exist,use it */
pwindow->markindex = k ;
pwindow->qgmark[k].count++ ;
return (k+1) ;
}
pwindow->markindex = j ;
pwindow->qgmark[j].count = 1 ;
Xw_get_color_attrib(pwindow,mode,color,&hcolor,&function,&planemask);
if( mode != QGMODE(pwindow->qgmark[j].code) ) {
mask |= GCFunction | GCPlaneMask | GCForeground ;
gc_values.function = function ;
gc_values.plane_mask = planemask ;
gc_values.foreground = hcolor ;
} else if( color != QGCOLOR(pwindow->qgmark[j].code) ) {
mask |= GCForeground;
gc_values.foreground = hcolor ;
}
if( width != QGWIDTH(pwindow->qgmark[j].code) ) {
mask |= GCLineWidth ;
if( width > 0 ) {
gc_values.line_width = _WIDTHMAP->widths[width] ;
} else {
gc_values.line_width = 0 ;
}
}
k = j+1 ;
if( mask ) {
XChangeGC(_DISPLAY,pwindow->qgmark[j].gc,mask,&gc_values) ;
pwindow->qgmark[j].code = code ;
#ifdef TRACE_SET_MARKER_ATTRIB
if( Xw_get_trace() > 1 ) {
printf(" %d = Xw_set_marker_attrib(%lx,%d,%d,%d,%d)\n",
k,(long ) pwindow,color,type,width,mode) ;
}
#endif
}
return (k) ;
}
|