source: trunk/Lucide/SOURCE/gui/printDlg.cpp @ 150

Last change on this file since 150 was 138, checked in by Eugene Romanenko, 15 years ago

Better solution for #78, move GUI to DLL, executor sets BeginLibPath? and loads GUI DLL (closes #78)

File size: 22.8 KB
Line 
1/* ***** BEGIN LICENSE BLOCK *****
2 * Version: CDDL 1.0/LGPL 2.1
3 *
4 * The contents of this file are subject to the COMMON DEVELOPMENT AND
5 * DISTRIBUTION LICENSE (CDDL) Version 1.0 (the "License"); you may not use
6 * this file except in compliance with the License. You may obtain a copy of
7 * the License at http://www.sun.com/cddl/
8 *
9 * Software distributed under the License is distributed on an "AS IS" basis,
10 * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
11 * for the specific language governing rights and limitations under the
12 * License.
13 *
14 * The Initial Developer of the Original Code is
15 * Eugene Romanenko, netlabs.org.
16 * Portions created by the Initial Developer are Copyright (C) 2006
17 * the Initial Developer. All Rights Reserved.
18 *
19 * Contributor(s):
20 *
21 * Alternatively, the contents of this file may be used under the terms of
22 * the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
23 * in which case the provisions of the LGPL are applicable instead of those
24 * above. If you wish to allow use of your version of this file only under the
25 * terms of the LGPL, and not to allow others to use your version of this file
26 * under the terms of the CDDL, indicate your decision by deleting the
27 * provisions above and replace them with the notice and other provisions
28 * required by the LGPL. If you do not delete the provisions above, a recipient
29 * may use your version of this file under the terms of any one of the CDDL
30 * or the LGPL.
31 *
32 * ***** END LICENSE BLOCK ***** */
33
34
35#define INCL_WIN
36#define INCL_DEV
37#define INCL_ERRORS
38#define INCL_SPL
39#define INCL_SPLDOSPRINT
40#include <os2.h>
41
42#include <ludoc.xh>
43
44#include "globals.h"
45#include "printDlg.h"
46#include "Lucide_res.h"
47#include "luutils.h"
48#include "messages.h"
49
50
51PrintDlg::PrintDlg( HWND hWndFrame, LuDocument *_doc, long _currentpage )
52{
53    hFrame      = hWndFrame;
54    doc         = _doc;
55    scalable    = _doc->isScalable( ev );
56    fixed       = _doc->isFixedImage( ev );
57    currentpage = _currentpage;
58    pcurForm    = new HCINFO;
59    memset( pcurForm, 0, sizeof( HCINFO ) );
60    psetup      = new PrintSetup;
61    memset( psetup, 0, sizeof( PrintSetup ) );
62}
63
64PrintDlg::~PrintDlg()
65{
66    delete pcurForm;
67    delete psetup;
68}
69
70ULONG PrintDlg::showDialog()
71{
72    return WinDlgBox( HWND_DESKTOP, hFrame, printDlgProc,
73                      _hmod, IDD_PRINT, this );
74}
75
76void PrintDlg::getPrintSetup( PrintSetup *p ) {
77    memcpy( p, psetup, sizeof( PrintSetup ) );
78}
79
80void PrintDlg::setCurrentQInfo( HWND hwnd, PPRQINFO3 q )
81{
82    memcpy( &(psetup->QueueInfo), q, sizeof( PRQINFO3 ) );
83    WinSetDlgItemText( hwnd, IDC_PNAME, psetup->QueueInfo.pszComment );
84    WinSetDlgItemText( hwnd, IDC_PDESCRIPTION, psetup->QueueInfo.pszDriverName );
85    WinEnableControl( hwnd, IDC_JOBPROPERTIES, TRUE );
86    WinEnableControl( hwnd, DID_OK, TRUE );
87
88    // Set the print type
89    if ( doc->isPostScriptExportable( ev ) && isPostscriptDevice() ) {
90        WinEnableControl( hwnd, IDC_TYPE_POSTSCRIPT, TRUE );
91        WinCheckButton( hwnd, IDC_TYPE_POSTSCRIPT, TRUE );
92    }
93    else {
94        WinEnableControl( hwnd, IDC_TYPE_POSTSCRIPT, FALSE );
95        WinCheckButton( hwnd, IDC_TYPE_ASIMAGE, TRUE );
96    }
97
98    WinSendMsg( hwnd, WM_CONTROL,
99                MPFROM2SHORT( IDC_TYPE_POSTSCRIPT, BN_CLICKED ),
100                MPFROMHWND( WinWindowFromID( hwnd, IDC_TYPE_POSTSCRIPT ) ) );
101
102    WinCheckButton( hwnd, isPortraitOrientation() ? IDC_PORTRAIT : IDC_LANDSCAPE, TRUE );
103
104    applyForm( hwnd );
105}
106
107void PrintDlg::enumQueues( HWND hwnd )
108{
109    HWND list = WinWindowFromID( hwnd, IDC_PNAME );
110    ULONG cReturned = 0, cTotal = 0, cbNeeded = 0;
111    SPLERR se = SplEnumQueue( NULL, 3, NULL, 0L, &cReturned,
112                              &cTotal, &cbNeeded, NULL );
113    if ( cTotal == 0L ) {
114        // TODO: 'no printers installed' message  (?)
115    }
116
117    pQueueInfo = (PPRQINFO3)malloc( cbNeeded );
118
119    se = SplEnumQueue( NULL, 3, pQueueInfo, cbNeeded, &cReturned,
120                       &cTotal, &cbNeeded, NULL );
121    if ( se != NO_ERROR ) {
122        // TODO: error message
123        free( pQueueInfo );
124        pQueueInfo = NULL;
125        return;
126    }
127
128    USHORT sEntry;
129    for ( ULONG i = 0; i < cReturned; i++ )
130    {
131        sEntry = (SHORT)WinInsertLboxItem( list, LIT_END, pQueueInfo[i].pszComment );
132        WinSendMsg( list, LM_SETITEMHANDLE,
133                    MPFROMSHORT(sEntry), MPFROMP( &(pQueueInfo[i]) ) );
134
135        if ( pQueueInfo[i].fsType & PRQ3_TYPE_APPDEFAULT ) {
136            setCurrentQInfo( hwnd, &( pQueueInfo[i] ) );
137        }
138    }
139}
140
141
142void PrintDlg::showJobProperties( HWND hwnd )
143{
144    if ( psetup->QueueInfo.pszName[0] == 0 ) {
145        return;
146    }
147
148    char achDriverName[ DRIVERNAME_LENGTH ];
149    char achDeviceName[ DEVICENAME_LENGTH ];
150
151    // The pszDriverName is of the form DRIVER.DEVICE (e.g.,
152    // LASERJET.HP LaserJet IID) so we need to separate it at the dot
153    int i = strcspn( psetup->QueueInfo.pszDriverName, "." );
154    if ( i > 0 ) {
155        strncpy( achDriverName, psetup->QueueInfo.pszDriverName, i );
156        achDriverName[ i ] = '\0';
157        strcpy( achDeviceName, &( psetup->QueueInfo.pszDriverName[ i + 1 ] ) );
158    }
159    else {
160        strcpy( achDriverName, psetup->QueueInfo.pszDriverName );
161        *achDeviceName = '\0';
162    }
163
164    // There may be more than one printer assigned to this print queue
165    // We will use the first in the comma separated list.  We would
166    // need an expanded dialog for the user to be more specific.
167    char *pszTemp = strchr( psetup->QueueInfo.pszPrinters, ',' );
168    if ( pszTemp != NULL ) {
169        // Strip off comma and trailing printer names
170        *pszTemp = '\0';
171    }
172
173    // Post the job properties dialog for the printer to allow the
174    // user to modify the options
175    DevPostDeviceModes( hab, psetup->QueueInfo.pDriverData, achDriverName,
176                        achDeviceName, psetup->QueueInfo.pszPrinters, DPDM_POSTJOBPROP );
177
178    WinCheckButton( hwnd, isPortraitOrientation() ? IDC_PORTRAIT : IDC_LANDSCAPE, TRUE );
179    applyForm( hwnd );
180}
181
182HDC PrintDlg::getInfoDC()
183{
184    char *achDriverName = new char[ DRIVERNAME_LENGTH ];
185    // build a devopenstruct for the call to DevOpenDC
186    DEVOPENSTRUC *dos   = new DEVOPENSTRUC;
187    memset( dos, 0, sizeof( DEVOPENSTRUC ) );
188    dos->pszLogAddress = psetup->QueueInfo.pszName;              // 1
189    strcpy( achDriverName, psetup->QueueInfo.pszDriverName );
190    achDriverName[ strcspn( achDriverName, "." ) ] = '\0';
191    dos->pszDriverName = achDriverName;                          // 2
192    dos->pdriv = psetup->QueueInfo.pDriverData;                  // 3
193
194    HDC hdcPrinterInfo = DevOpenDC( hab, OD_INFO, "*", 3L, (PDEVOPENDATA)dos, NULLHANDLE );
195
196    delete achDriverName;
197    delete dos;
198
199    return hdcPrinterInfo;
200}
201
202bool PrintDlg::isPostscriptDevice()
203{
204    long lTech = 0;
205    HDC hdcPrinterInfo = getInfoDC();
206    if ( hdcPrinterInfo != DEV_ERROR ) {
207        DevQueryCaps( hdcPrinterInfo, CAPS_TECHNOLOGY, sizeof(long), &lTech );
208        DevCloseDC( hdcPrinterInfo );
209    }
210    return ( lTech == CAPS_TECH_POSTSCRIPT );
211}
212
213// **************************************************
214// OpenWatcom headers doesn't have these declarations
215// **************************************************
216#ifndef DJP_SJ_ORIENTATION
217typedef struct _djpItem
218{
219    ULONG       cb;
220    ULONG       ulProperty;
221    LONG        lType;
222    ULONG       ulNumReturned;
223    ULONG       ulValue;
224} DJP_ITEM, *PDJP_ITEM;
225
226#define DJP_ALL                 1L
227#define DJP_CURRENT             2L
228#define DJP_NONE                0L
229#define DJP_SJ_ORIENTATION      1L
230
231#define DJP_ORI_PORTRAIT        1L
232#define DJP_ORI_LANDSCAPE       2L
233#define DJP_ORI_REV_PORTRAIT    3L
234#define DJP_ORI_REV_LANDSCAPE   4L
235#endif
236// **************************************************
237
238bool PrintDlg::isPortraitOrientation()
239{
240    bool rVal = true;
241
242    HDC hdcPrinterInfo = getInfoDC();
243    if ( hdcPrinterInfo != DEV_ERROR )
244    {
245        DJP_ITEM djp[ 2 ] = { { 0 } };
246
247        // Get Orientation from Job Properties
248        djp[0].cb = sizeof( DJP_ITEM );
249        djp[0].ulProperty = DJP_SJ_ORIENTATION;
250        djp[0].lType = DJP_CURRENT;
251        djp[0].ulNumReturned = 1;
252        djp[0].ulValue = 1;
253
254        djp[1].cb = sizeof( DJP_ITEM );
255        djp[1].ulProperty = 0;
256        djp[1].lType = DJP_NONE;
257        djp[1].ulNumReturned = 1;
258        djp[1].ulValue = 0;
259
260        LONG outSz = psetup->QueueInfo.pDriverData->cb;
261        LONG rc = DevEscape( hdcPrinterInfo, DEVESC_QUERYJOBPROPERTIES,
262                             sizeof( DJP_ITEM ) * 2, (PCHAR)djp,
263                             &outSz, (PCHAR)psetup->QueueInfo.pDriverData );
264
265        if ( ( rc == DEV_OK ) || ( rc == DEV_WARNING ) )
266        {
267            if ( ( djp[0].lType != DJP_NONE ) &&
268                 ( djp[0].ulProperty == DJP_SJ_ORIENTATION ) &&
269                 ( djp[0].lType > 0 ) )
270            {
271                if ( ( djp[0].ulValue == DJP_ORI_LANDSCAPE ) ||
272                     ( djp[0].ulValue == DJP_ORI_REV_LANDSCAPE ) ) {
273                    rVal = false;
274                }
275            }
276        }
277
278        DevCloseDC( hdcPrinterInfo );
279    }
280
281    return rVal;
282}
283
284
285void PrintDlg::setPortraitOrientation( bool portrait, HWND hwnd )
286{
287    HDC hdcPrinterInfo = getInfoDC();
288    if ( hdcPrinterInfo != DEV_ERROR )
289    {
290        DJP_ITEM djp[ 2 ] = { { 0 } };
291
292        // Set Orientation
293        djp[0].cb = sizeof( DJP_ITEM );
294        djp[0].ulProperty = DJP_SJ_ORIENTATION;
295        djp[0].lType = DJP_CURRENT;
296        djp[0].ulNumReturned = 1;
297        djp[0].ulValue = portrait ? DJP_ORI_PORTRAIT : DJP_ORI_LANDSCAPE;
298
299        djp[1].cb = sizeof( DJP_ITEM );
300        djp[1].ulProperty = 0;
301        djp[1].lType = DJP_NONE;
302        djp[1].ulNumReturned = 1;
303        djp[1].ulValue = 0;
304
305        LONG outSz = psetup->QueueInfo.pDriverData->cb;
306        DevEscape( hdcPrinterInfo, DEVESC_SETJOBPROPERTIES,
307                   sizeof( DJP_ITEM ) * 2, (PCHAR)djp,
308                   &outSz, (PCHAR)psetup->QueueInfo.pDriverData );
309
310        DevCloseDC( hdcPrinterInfo );
311
312        applyForm( hwnd );
313    }
314}
315
316
317bool PrintDlg::queryCurrentForm()
318{
319    HDC hdcPrinterInfo = getInfoDC();
320    if ( hdcPrinterInfo == DEV_ERROR ) {
321        return false;
322    }
323
324    LONG lForms = DevQueryHardcopyCaps( hdcPrinterInfo, 0, 0, NULL );
325    if ( lForms == DQHC_ERROR ) {
326        DevCloseDC( hdcPrinterInfo );
327        return false;
328    }
329
330    HCINFO *forms = new HCINFO[ lForms ];
331    memset( forms, 0, sizeof( HCINFO ) * lForms );
332    lForms = DevQueryHardcopyCaps( hdcPrinterInfo, 0, lForms, forms );
333    if ( lForms == DQHC_ERROR ) {
334        delete forms;
335        DevCloseDC( hdcPrinterInfo );
336        return false;
337    }
338
339    for ( LONG i = 0; i < lForms; i++ ) {
340        if ( forms[i].flAttributes & HCAPS_CURRENT ) {
341            memcpy( pcurForm, &( forms[i] ), sizeof( HCINFO ) );
342            break;
343        }
344    }
345
346    delete forms;
347    DevCloseDC( hdcPrinterInfo );
348    return true;
349}
350
351void PrintDlg::applyForm( HWND hwnd )
352{
353    if ( queryCurrentForm() )
354    {
355        WinSetDlgItemText( hwnd, IDC_SELECTED_FORM, pcurForm->szFormname );
356
357        long margin_top_min    = pcurForm->cy - pcurForm->yTopClip;
358        long margin_left_min   = pcurForm->xLeftClip;
359        long margin_bottom_min = pcurForm->yBottomClip;
360        long margin_right_min  = pcurForm->cx - pcurForm->xRightClip;
361
362        long margin_top_max    = pcurForm->cy - margin_bottom_min;
363        long margin_left_max   = pcurForm->cx - margin_right_min;
364        long margin_bottom_max = pcurForm->cy - margin_top_min;
365        long margin_right_max  = pcurForm->cx - margin_left_min;
366
367        WinSendDlgItemMsg( hwnd, IDC_MTOP, SPBM_SETLIMITS,
368                           MPFROMLONG( margin_top_max ), MPFROMLONG( margin_top_min ) );
369        WinSendDlgItemMsg( hwnd, IDC_MTOP, SPBM_SETCURRENTVALUE,
370                           MPFROMLONG( margin_top_min ), MPVOID );
371        WinSendDlgItemMsg( hwnd, IDC_MLEFT, SPBM_SETLIMITS,
372                           MPFROMLONG( margin_left_max ), MPFROMLONG( margin_left_min ) );
373        WinSendDlgItemMsg( hwnd, IDC_MLEFT, SPBM_SETCURRENTVALUE,
374                           MPFROMLONG( margin_left_min ), MPVOID );
375        WinSendDlgItemMsg( hwnd, IDC_MBOTTOM, SPBM_SETLIMITS,
376                           MPFROMLONG( margin_bottom_max ), MPFROMLONG( margin_bottom_min ) );
377        WinSendDlgItemMsg( hwnd, IDC_MBOTTOM, SPBM_SETCURRENTVALUE,
378                           MPFROMLONG( margin_bottom_min ), MPVOID );
379        WinSendDlgItemMsg( hwnd, IDC_MRIGHT, SPBM_SETLIMITS,
380                           MPFROMLONG( margin_right_max ), MPFROMLONG( margin_right_min ) );
381        WinSendDlgItemMsg( hwnd, IDC_MRIGHT, SPBM_SETCURRENTVALUE,
382                           MPFROMLONG( margin_right_min ), MPVOID );
383
384        //somPrintf( "cx %d, cy %d, xLeftClip %d, yBottomClip %d, xRightClip %d, yTopClip %d\n",
385        //           pcurForm->cx, pcurForm->cy, pcurForm->xLeftClip, pcurForm->yBottomClip,
386        //           pcurForm->xRightClip, pcurForm->yTopClip );
387
388    }
389    else {
390        WinSetDlgItemText( hwnd, IDC_SELECTED_FORM, "" );
391    }
392}
393
394
395// do not allow round-trip on spins
396static MRESULT EXPENTRY spinProc( HWND hwnd, ULONG msg, MPARAM mp1, MPARAM mp2 )
397{
398    PFNWP oldSpinProc = (PFNWP)WinQueryWindowULong( hwnd, QWL_USER );
399
400    if ( msg == SPBM_SPINDOWN )
401    {
402        LONG upLimit = 0, lowLimit = 0, curVal = 0;
403        WinSendMsg( hwnd, SPBM_QUERYLIMITS, MPFROMP( &upLimit ), MPFROMP( &lowLimit ) );
404        WinSendMsg( hwnd, SPBM_QUERYVALUE, MPFROMP( &curVal ), MPFROM2SHORT( 0, SPBQ_DONOTUPDATE ) );
405        if ( curVal <= lowLimit ) {
406            return (MRESULT)TRUE;
407        }
408    }
409    else if ( msg == SPBM_SPINUP )
410    {
411        LONG upLimit = 0, lowLimit = 0, curVal = 0;
412        WinSendMsg( hwnd, SPBM_QUERYLIMITS, MPFROMP( &upLimit ), MPFROMP( &lowLimit ) );
413        WinSendMsg( hwnd, SPBM_QUERYVALUE, MPFROMP( &curVal ), MPFROM2SHORT( 0, SPBQ_DONOTUPDATE ) );
414        if ( curVal >= upLimit ) {
415            return (MRESULT)TRUE;
416        }
417    }
418
419    return oldSpinProc( hwnd, msg, mp1, mp2 );
420}
421
422MRESULT EXPENTRY PrintDlg::printDlgProc( HWND hwnd, ULONG msg, MPARAM mp1, MPARAM mp2 )
423{
424    // This is a static method, so we don't know which instantiation we're
425    // dealing with. But we can get a pseudo-this from the parameter to
426    // WM_INITDLG, which we therafter store with the window and retrieve
427    // as follows:
428    PrintDlg *_this = (PrintDlg *)WinQueryWindowULong( hwnd, QWL_USER );
429
430    switch (msg)
431    {
432
433        // Dialog has just been created
434        case WM_INITDLG:
435        {
436            // Save the mp2 into our user data so that subsequent calls have
437            // access to the parent C++ object
438            WinSetWindowULong( hwnd, QWL_USER, (ULONG)mp2 );
439            _this = (PrintDlg *)mp2;
440            localizeDialog( hwnd );
441            centerWindow( _this->hFrame, hwnd );
442
443            // Print range
444            WinCheckButton( hwnd, IDC_RANGEALL, TRUE );
445
446            // Set the print range spins
447            long pages = _this->doc->getPageCount( ev );
448            WinSendDlgItemMsg( hwnd, IDC_PGFROM, SPBM_SETLIMITS,
449                               MPFROMLONG( pages ), MPFROMLONG( 1 ) );
450            WinSendDlgItemMsg( hwnd, IDC_PGFROM, SPBM_SETCURRENTVALUE,
451                               MPFROMLONG( 1 ), MPVOID );
452            WinSendDlgItemMsg( hwnd, IDC_PGTO, SPBM_SETLIMITS,
453                               MPFROMLONG( pages ), MPFROMLONG( 1 ) );
454            WinSendDlgItemMsg( hwnd, IDC_PGTO, SPBM_SETCURRENTVALUE,
455                               MPFROMLONG( pages ), MPVOID );
456
457            // Number of copies
458            WinSendDlgItemMsg( hwnd, IDC_COPIES, SPBM_SETLIMITS,
459                               MPFROMLONG( 999 ), MPFROMLONG( 1 ) );
460            WinSendDlgItemMsg( hwnd, IDC_COPIES, SPBM_SETCURRENTVALUE,
461                               MPFROMLONG( 1 ), MPVOID );
462
463            // Enum printer queues
464            _this->enumQueues( hwnd );
465
466            HWND spin = WinWindowFromID( hwnd, IDC_MLEFT );
467            PFNWP proc = WinSubclassWindow( spin, spinProc );
468            WinSetWindowULong( spin, QWL_USER, (ULONG)proc );
469            spin = WinWindowFromID( hwnd, IDC_MRIGHT );
470            proc = WinSubclassWindow( spin, spinProc );
471            WinSetWindowULong( spin, QWL_USER, (ULONG)proc );
472            spin = WinWindowFromID( hwnd, IDC_MTOP );
473            proc = WinSubclassWindow( spin, spinProc );
474            WinSetWindowULong( spin, QWL_USER, (ULONG)proc );
475            spin = WinWindowFromID( hwnd, IDC_MBOTTOM );
476            proc = WinSubclassWindow( spin, spinProc );
477            WinSetWindowULong( spin, QWL_USER, (ULONG)proc );
478
479            return (MRESULT)FALSE;
480        }
481
482        case WM_CONTROL:
483        {
484            switch ( SHORT1FROMMP(mp1) )
485            {
486                case IDC_PNAME:
487                {
488                    if ( SHORT2FROMMP(mp1) == CBN_LBSELECT )
489                    {
490                        SHORT rc = (SHORT)WinSendDlgItemMsg( hwnd, IDC_PNAME, LM_QUERYSELECTION,
491                                                             MPFROMSHORT( LIT_CURSOR ), MPVOID );
492                        if ( rc != LIT_NONE ) {
493                            MRESULT r = WinSendDlgItemMsg( hwnd, IDC_PNAME, LM_QUERYITEMHANDLE,
494                                                           MPFROMSHORT( rc ), MPVOID );
495                            _this->setCurrentQInfo( hwnd, (PPRQINFO3)r );
496                        }
497                    }
498                }
499                break;
500
501                case IDC_RANGEALL:
502                case IDC_RANGECURRENT:
503                case IDC_RANGEPAGES:
504                {
505                    BOOL en = WinQueryButtonCheckstate( hwnd, IDC_RANGEPAGES );
506                    WinEnableControl( hwnd, IDC_LABELFROM, en );
507                    WinEnableControl( hwnd, IDC_PGFROM, en );
508                    WinEnableControl( hwnd, IDC_LABELTO, en );
509                    WinEnableControl( hwnd, IDC_PGTO, en );
510                }
511                break;
512
513                case IDC_TYPE_POSTSCRIPT:
514                case IDC_TYPE_ASIMAGE:
515                {
516                    BOOL asimg = WinQueryButtonCheckstate( hwnd, IDC_TYPE_ASIMAGE );
517                    WinEnableControl( hwnd, IDC_HIGHER_IMAGE_QUALITY,
518                                      asimg && _this->scalable && !_this->fixed );
519                }
520                break;
521
522                case IDC_PORTRAIT:
523                case IDC_LANDSCAPE:
524                {
525                    bool portrait = WinQueryButtonCheckstate( hwnd, IDC_PORTRAIT );
526                    _this->setPortraitOrientation( portrait, hwnd );
527                }
528                break;
529
530            }
531        }
532        break;
533
534        case WM_COMMAND:
535            switch (SHORT1FROMMP(mp1))
536            {
537                case IDC_JOBPROPERTIES:
538                    _this->showJobProperties( hwnd );
539                    return (MRESULT)FALSE;
540
541                case DID_OK:
542                    {
543                        long ml = 0, mr = 0, mt = 0, mb = 0;
544                        WinSendDlgItemMsg( hwnd, IDC_MLEFT, SPBM_QUERYVALUE, MPFROMP( &ml ), MPFROM2SHORT( 0, SPBQ_UPDATEIFVALID ) );
545                        WinSendDlgItemMsg( hwnd, IDC_MRIGHT, SPBM_QUERYVALUE, MPFROMP( &mr ), MPFROM2SHORT( 0, SPBQ_UPDATEIFVALID ) );
546                        WinSendDlgItemMsg( hwnd, IDC_MTOP, SPBM_QUERYVALUE, MPFROMP( &mt ), MPFROM2SHORT( 0, SPBQ_UPDATEIFVALID ) );
547                        WinSendDlgItemMsg( hwnd, IDC_MBOTTOM, SPBM_QUERYVALUE, MPFROMP( &mb ), MPFROM2SHORT( 0, SPBQ_UPDATEIFVALID ) );
548
549                        if ( ( _this->pcurForm->cx < ( ml + mr ) ) ||
550                             ( _this->pcurForm->cy < ( mt + mb ) ) )
551                        {
552                            char *wrongmargins = newstrdupL( PD_WRONG_MARGINS );
553                            WinMessageBox( HWND_DESKTOP, _this->hFrame, wrongmargins, NULL,
554                                           1, MB_OK | MB_ERROR | MB_MOVEABLE );
555                            delete wrongmargins;
556                            return (MRESULT)FALSE;  // Return, don't leave dialog
557                        }
558
559                        _this->psetup->margin_left   = ml;
560                        _this->psetup->margin_right  = mr;
561                        _this->psetup->margin_top    = mt;
562                        _this->psetup->margin_bottom = mb;
563
564                        LONG cp = 0;
565                        WinSendDlgItemMsg( hwnd, IDC_COPIES, SPBM_QUERYVALUE, MPFROMP( &cp ), MPFROM2SHORT( 0, SPBQ_UPDATEIFVALID ) );
566                        _this->psetup->copies = cp;
567
568                        _this->psetup->range = RangeAll;
569                        _this->psetup->pgfrom = 1;
570                        _this->psetup->pgto = _this->doc->getPageCount( ev );
571
572                        if ( WinQueryButtonCheckstate( hwnd, IDC_RANGECURRENT ) ) {
573                            _this->psetup->range = RangeCurrent;
574                            _this->psetup->pgfrom = _this->currentpage;
575                            _this->psetup->pgto = _this->currentpage;
576                        }
577
578                        if ( WinQueryButtonCheckstate( hwnd, IDC_RANGEPAGES ) )
579                        {
580                            _this->psetup->range = RangePages;
581                            LONG tmpVal = 0;
582                            BOOL rc = (BOOL)WinSendDlgItemMsg( hwnd, IDC_PGFROM, SPBM_QUERYVALUE, MPFROMP( &tmpVal ), MPFROM2SHORT( 0, SPBQ_UPDATEIFVALID ) );
583                            if ( rc && ( tmpVal > 0 ) ) {
584                                _this->psetup->pgfrom = tmpVal;
585                            }
586                            rc = (BOOL)WinSendDlgItemMsg( hwnd, IDC_PGTO, SPBM_QUERYVALUE, MPFROMP( &tmpVal ), MPFROM2SHORT( 0, SPBQ_UPDATEIFVALID ) );
587                            if ( rc && ( tmpVal > 0 ) ) {
588                                _this->psetup->pgto = tmpVal;
589                            }
590                        }
591
592                        _this->psetup->ptype = TypePostScript;
593                        if ( WinQueryButtonCheckstate( hwnd, IDC_TYPE_ASIMAGE ) ) {
594                            _this->psetup->ptype = TypeAsImage;
595                        }
596                        _this->psetup->higherQuality = WinQueryButtonCheckstate( hwnd, IDC_HIGHER_IMAGE_QUALITY );
597
598                        WinDismissDlg( hwnd, DID_OK );
599                    }
600                    return (MRESULT)FALSE;
601
602                case DID_CANCEL:
603                    WinDismissDlg( hwnd, DID_CANCEL );
604                    return (MRESULT)FALSE;
605            };
606            return (MRESULT)FALSE;
607    }
608    return WinDefDlgProc( hwnd, msg, mp1, mp2 );
609}
610
611
Note: See TracBrowser for help on using the repository browser.