~ubuntu-branches/ubuntu/quantal/viewpdf.app/quantal

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
/*
 * Copyright (C) 2004  Stefan Kleine Stegemann
 *
 * This program is free software; you can redistribute it and/or
 * modify it under the terms of the GNU General Public License
 * as published by the Free Software Foundation; either version 2
 * of the License, or (at your option) any later version.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program; if not, write to the Free Software
 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
 */

#import <Foundation/Foundation.h>
#import <AppKit/AppKit.h>
#import "PDFContentView.h"

/**
 * A view that provides standard tools for a PDF document.
 * These tools include things like page navigation controls,
 * zoom controls etc.
 */
@interface DocumentTools : NSView
{
   id target;
   
   NSButton*     firstBT;
   NSButton*     previousBT;
   NSButton*     nextBT;
   NSButton*     lastBT;
   NSTextField*  pageTF;
   NSTextField*  nbpageTF;
   NSButton*     zoomInBT;
   NSTextField*  zoomTF;
   NSButton*     zoomOutBT;
   NSButton*     fitPageBT;
   NSButton*     fitWidthBT;
   NSButton*     fitHeightBT;
}

/** The frame size of the view is calculated automatically during
    initialization. Thus, the frame's size may be modified to hold
    all tool views. The frame may be heightened but it is never 
    belittled. You can safley use 0, 0 for the frame's size and rely
    on the initialization to determine and set the minimum required
    width.  */
- (id) initWithFrame: (NSRect)aFrame target: (id)aTarget;

/** A DocumentTools view will send all actions of it's embeded
    controls to a target object.  */
- (void) setTarget: (id)aTarget;

/** Set the page number to be displayed in the page field.  */
- (void) setPage: (int)aPage;

/** Set the number of pages in the displayed document.  */
- (void) setPageCount: (int)aPageCount;

/** Set the content's for the zoom textfield.  */
- (void) setZoom: (float)aFactor;

/** Set the actual page resize policy. The state of the buttons which
    control the policy is modified accordingly.  */
- (void) setResizePolicy: (ResizePolicy)aPolicy;

/** Transfer focus to page field.  */
- (void) focusPageField;

@end