author | alwin <alwin> | 2004-11-12 15:57:59 (UTC) |
---|---|---|
committer | alwin <alwin> | 2004-11-12 15:57:59 (UTC) |
commit | e1ed329d0b8be10ac6e019d37b82afcf21990691 (patch) (unidiff) | |
tree | 0c84e2c4fd062487932de9add39a083da194cca0 | |
parent | de558d6f0bc31f58ffaa894a0236f0d9cb5d73e0 (diff) | |
download | opie-e1ed329d0b8be10ac6e019d37b82afcf21990691.zip opie-e1ed329d0b8be10ac6e019d37b82afcf21990691.tar.gz opie-e1ed329d0b8be10ac6e019d37b82afcf21990691.tar.bz2 |
- fixed a bug in docview-lister: different files may have same docview
name. So mapping filenames to docname isn't usefull.
- when opie-eye is started from doctab closing the imagewindow
closes the application
- when a doc-link is changed while opie-eye is running it get the
changes, too.
-rw-r--r-- | noncore/graphics/opie-eye/gui/iconview.cpp | 64 | ||||
-rw-r--r-- | noncore/graphics/opie-eye/gui/iconview.h | 4 | ||||
-rw-r--r-- | noncore/graphics/opie-eye/gui/imageview.cpp | 15 | ||||
-rw-r--r-- | noncore/graphics/opie-eye/gui/imageview.h | 2 | ||||
-rw-r--r-- | noncore/graphics/opie-eye/gui/mainwindow.cpp | 47 | ||||
-rw-r--r-- | noncore/graphics/opie-eye/gui/mainwindow.h | 3 | ||||
-rw-r--r-- | noncore/graphics/opie-eye/impl/doc/doc_lister.cpp | 137 | ||||
-rw-r--r-- | noncore/graphics/opie-eye/impl/doc/doc_lister.h | 8 |
8 files changed, 178 insertions, 102 deletions
diff --git a/noncore/graphics/opie-eye/gui/iconview.cpp b/noncore/graphics/opie-eye/gui/iconview.cpp index 948477c..138e661 100644 --- a/noncore/graphics/opie-eye/gui/iconview.cpp +++ b/noncore/graphics/opie-eye/gui/iconview.cpp | |||
@@ -7,726 +7,742 @@ | |||
7 | 7 | ||
8 | #include <lib/imagecache.h> | 8 | #include <lib/imagecache.h> |
9 | #include <gui/imageinfoui.h> | 9 | #include <gui/imageinfoui.h> |
10 | 10 | ||
11 | #include <iface/dirview.h> | 11 | #include <iface/dirview.h> |
12 | #include <iface/dirlister.h> | 12 | #include <iface/dirlister.h> |
13 | 13 | ||
14 | #include <opie2/oconfig.h> | 14 | #include <opie2/oconfig.h> |
15 | #include <opie2/okeyconfigwidget.h> | 15 | #include <opie2/okeyconfigwidget.h> |
16 | #include <opie2/odebug.h> | 16 | #include <opie2/odebug.h> |
17 | #include <opie2/oimagescrollview.h> | 17 | #include <opie2/oimagescrollview.h> |
18 | 18 | ||
19 | #include <qpe/resource.h> | 19 | #include <qpe/resource.h> |
20 | #include <qpe/qpemessagebox.h> | 20 | #include <qpe/qpemessagebox.h> |
21 | #include <qpe/ir.h> | 21 | #include <qpe/ir.h> |
22 | #include <qpe/qcopenvelope_qws.h> | 22 | #include <qpe/qcopenvelope_qws.h> |
23 | #include <qpe/qpeapplication.h> | 23 | #include <qpe/qpeapplication.h> |
24 | 24 | ||
25 | #include <qiconview.h> | 25 | #include <qiconview.h> |
26 | #include <qlabel.h> | 26 | #include <qlabel.h> |
27 | #include <qhbox.h> | 27 | #include <qhbox.h> |
28 | #include <qcombobox.h> | 28 | #include <qcombobox.h> |
29 | #include <qdir.h> | 29 | #include <qdir.h> |
30 | #include <qapplication.h> | 30 | #include <qapplication.h> |
31 | #include <qmainwindow.h> | 31 | #include <qmainwindow.h> |
32 | #include <qtimer.h> | 32 | #include <qtimer.h> |
33 | #include <qstyle.h> | 33 | #include <qstyle.h> |
34 | 34 | ||
35 | 35 | ||
36 | using Opie::Core::OKeyConfigItem; | 36 | using Opie::Core::OKeyConfigItem; |
37 | 37 | ||
38 | /* | 38 | /* |
39 | * The Icons, Request Cache and IconViewItem for the IconView | 39 | * The Icons, Request Cache and IconViewItem for the IconView |
40 | */ | 40 | */ |
41 | namespace { | 41 | namespace { |
42 | static QPixmap* _dirPix = 0; | 42 | static QPixmap* _dirPix = 0; |
43 | static QPixmap* _unkPix = 0; | 43 | static QPixmap* _unkPix = 0; |
44 | static QPixmap* _cpyPix = 0; | 44 | static QPixmap* _cpyPix = 0; |
45 | static QPixmap* _emptyPix = 0; | 45 | static QPixmap* _emptyPix = 0; |
46 | class IconViewItem : public QIconViewItem { | 46 | class IconViewItem : public QIconViewItem { |
47 | public: | 47 | public: |
48 | IconViewItem( QIconView*, const QString& path, const QString& name,int a_iconsize, bool isDir = false); | 48 | IconViewItem( QIconView*, const QString& path, const QString& name,int a_iconsize, bool isDir = false); |
49 | QPixmap* pixmap()const; | 49 | QPixmap* pixmap()const; |
50 | QString path()const { return m_path; } | 50 | QString path()const { return m_path; } |
51 | bool isDir()const { return m_isDir; } | 51 | bool isDir()const { return m_isDir; } |
52 | void setText( const QString& ); | 52 | void setText( const QString& ); |
53 | bool textOnly()const{return m_textOnly;} | 53 | bool textOnly()const{return m_textOnly;} |
54 | void setTextOnly(bool how){m_textOnly=how;} | 54 | void setTextOnly(bool how){m_textOnly=how;} |
55 | /* just for starting recalc of item rect! */ | 55 | /* just for starting recalc of item rect! */ |
56 | virtual void setPixmap( const QPixmap & icon, bool recalc, bool redraw = TRUE ); | 56 | virtual void setPixmap( const QPixmap & icon, bool recalc, bool redraw = TRUE ); |
57 | /* just for starting recalc of item rect! */ | 57 | /* just for starting recalc of item rect! */ |
58 | virtual void setPixmap( const QPixmap & icon); | 58 | virtual void setPixmap( const QPixmap & icon); |
59 | 59 | ||
60 | protected: | 60 | protected: |
61 | mutable QPixmap* m_pix; | 61 | mutable QPixmap* m_pix; |
62 | int m_iconsize; | 62 | int m_iconsize; |
63 | void check_pix()const; | 63 | void check_pix()const; |
64 | 64 | ||
65 | private: | 65 | private: |
66 | QString m_path; | 66 | QString m_path; |
67 | bool m_isDir : 1; | 67 | bool m_isDir : 1; |
68 | bool m_noInfo :1; | 68 | bool m_noInfo :1; |
69 | bool m_textOnly:1; | 69 | bool m_textOnly:1; |
70 | bool m_NameOnly:1; | 70 | bool m_NameOnly:1; |
71 | bool m_Pixset:1; | 71 | bool m_Pixset:1; |
72 | }; | 72 | }; |
73 | class TextViewItem : public IconViewItem { | 73 | class TextViewItem : public IconViewItem { |
74 | TextViewItem( QIconView*, const QString& path, const QString& name, int a_iconsize , bool isDir = false); | 74 | TextViewItem( QIconView*, const QString& path, const QString& name, int a_iconsize , bool isDir = false); |
75 | QPixmap *pixmap()const; | 75 | QPixmap *pixmap()const; |
76 | void setText( const QString& ); | 76 | void setText( const QString& ); |
77 | }; | 77 | }; |
78 | class ThumbViewItem : public IconViewItem { | 78 | class ThumbViewItem : public IconViewItem { |
79 | ThumbViewItem( QIconView*, const QString& path, const QString& name, int a_iconsize, bool isDir = false ); | 79 | ThumbViewItem( QIconView*, const QString& path, const QString& name, int a_iconsize, bool isDir = false ); |
80 | QPixmap *pixmap()const; | 80 | QPixmap *pixmap()const; |
81 | void setText( const QString& ); | 81 | void setText( const QString& ); |
82 | }; | 82 | }; |
83 | 83 | ||
84 | 84 | ||
85 | /* | 85 | /* |
86 | * If we request an Image or String | 86 | * If we request an Image or String |
87 | * we add it to the map | 87 | * we add it to the map |
88 | */ | 88 | */ |
89 | static QMap<QString, IconViewItem*> g_stringInf; | 89 | static QMap<QString, IconViewItem*> g_stringInf; |
90 | static QMap<QString, IconViewItem*> g_stringPix; | 90 | static QMap<QString, IconViewItem*> g_stringPix; |
91 | 91 | ||
92 | IconViewItem::IconViewItem( QIconView* view,const QString& path, | 92 | IconViewItem::IconViewItem( QIconView* view,const QString& path, |
93 | const QString& name, int a_iconsize, bool isDir) | 93 | const QString& name, int a_iconsize, bool isDir) |
94 | : QIconViewItem( view, name ), m_path( path ), m_isDir( isDir ), | 94 | : QIconViewItem( view, name ), m_path( path ), m_isDir( isDir ), |
95 | m_noInfo( false ),m_textOnly(false),m_Pixset(false) | 95 | m_noInfo( false ),m_textOnly(false),m_Pixset(false) |
96 | { | 96 | { |
97 | m_iconsize = a_iconsize; | 97 | m_iconsize = a_iconsize; |
98 | if ( isDir ) { | 98 | if ( isDir ) { |
99 | if (!_dirPix ) { | 99 | if (!_dirPix ) { |
100 | _dirPix = new QPixmap( Resource::loadPixmap("advancedfm/FileBrowser")); | 100 | _dirPix = new QPixmap( Resource::loadPixmap("advancedfm/FileBrowser")); |
101 | } | 101 | } |
102 | } else { | 102 | } else { |
103 | if (!_unkPix ) { | 103 | if (!_unkPix ) { |
104 | _unkPix = new QPixmap( Resource::loadPixmap( "UnknownDocument" ) ); | 104 | _unkPix = new QPixmap( Resource::loadPixmap( "UnknownDocument" ) ); |
105 | } | 105 | } |
106 | } | 106 | } |
107 | check_pix(); | 107 | check_pix(); |
108 | } | 108 | } |
109 | 109 | ||
110 | inline void IconViewItem::check_pix()const | 110 | inline void IconViewItem::check_pix()const |
111 | { | 111 | { |
112 | if (_dirPix && _dirPix->width()>m_iconsize) { | 112 | if (_dirPix && _dirPix->width()>m_iconsize) { |
113 | QImage Pix = _dirPix->convertToImage(); | 113 | QImage Pix = _dirPix->convertToImage(); |
114 | *_dirPix = Pix.smoothScale(m_iconsize,m_iconsize); | 114 | *_dirPix = Pix.smoothScale(m_iconsize,m_iconsize); |
115 | } | 115 | } |
116 | if (!_cpyPix && _unkPix) { | 116 | if (!_cpyPix && _unkPix) { |
117 | if (_unkPix->width()>=m_iconsize) { | 117 | if (_unkPix->width()>=m_iconsize) { |
118 | QImage Pix = _unkPix->convertToImage(); | 118 | QImage Pix = _unkPix->convertToImage(); |
119 | _cpyPix = new QPixmap(); | 119 | _cpyPix = new QPixmap(); |
120 | if (_unkPix->width()>m_iconsize) { | 120 | if (_unkPix->width()>m_iconsize) { |
121 | *_cpyPix = Pix.smoothScale(m_iconsize,m_iconsize); | 121 | *_cpyPix = Pix.smoothScale(m_iconsize,m_iconsize); |
122 | } else { | 122 | } else { |
123 | _cpyPix->convertFromImage(Pix); | 123 | _cpyPix->convertFromImage(Pix); |
124 | } | 124 | } |
125 | 125 | ||
126 | } else { | 126 | } else { |
127 | _cpyPix = new QPixmap(m_iconsize,m_iconsize); | 127 | _cpyPix = new QPixmap(m_iconsize,m_iconsize); |
128 | _cpyPix->fill(); | 128 | _cpyPix->fill(); |
129 | QPainter pa(_cpyPix); | 129 | QPainter pa(_cpyPix); |
130 | int offset = (m_iconsize-_unkPix->width())/2; | 130 | int offset = (m_iconsize-_unkPix->width())/2; |
131 | int offy = (m_iconsize-_unkPix->height())/2; | 131 | int offy = (m_iconsize-_unkPix->height())/2; |
132 | if (offy<0) offy=0; | 132 | if (offy<0) offy=0; |
133 | pa.drawPixmap(offset,offy,*_unkPix); | 133 | pa.drawPixmap(offset,offy,*_unkPix); |
134 | pa.end(); | 134 | pa.end(); |
135 | } | 135 | } |
136 | } | 136 | } |
137 | } | 137 | } |
138 | 138 | ||
139 | inline void IconViewItem::setPixmap( const QPixmap & , bool, bool ) | 139 | inline void IconViewItem::setPixmap( const QPixmap & , bool, bool ) |
140 | { | 140 | { |
141 | m_Pixset = true; | 141 | m_Pixset = true; |
142 | calcRect(text()); | 142 | calcRect(text()); |
143 | } | 143 | } |
144 | inline void IconViewItem::setPixmap( const QPixmap & ) | 144 | inline void IconViewItem::setPixmap( const QPixmap & ) |
145 | { | 145 | { |
146 | m_Pixset = true; | 146 | m_Pixset = true; |
147 | calcRect(text()); | 147 | calcRect(text()); |
148 | } | 148 | } |
149 | 149 | ||
150 | inline QPixmap* IconViewItem::pixmap()const { | 150 | inline QPixmap* IconViewItem::pixmap()const { |
151 | // owarn << "Name is " << m_path.right( 15 ) << " rect is " << rect().x() << " " << rect().y() | 151 | // owarn << "Name is " << m_path.right( 15 ) << " rect is " << rect().x() << " " << rect().y() |
152 | // << " " << rect().width() << " " << rect().height() << " | " << iconView()->contentsX() | 152 | // << " " << rect().width() << " " << rect().height() << " | " << iconView()->contentsX() |
153 | // << " " << iconView()->contentsY() << oendl; | 153 | // << " " << iconView()->contentsY() << oendl; |
154 | 154 | ||
155 | if (textOnly()&&!m_isDir) { | 155 | if (textOnly()&&!m_isDir) { |
156 | if (!_emptyPix) _emptyPix = new QPixmap(0,0,1); | 156 | if (!_emptyPix) _emptyPix = new QPixmap(0,0,1); |
157 | return _emptyPix; | 157 | return _emptyPix; |
158 | } | 158 | } |
159 | if ( m_isDir ) | 159 | if ( m_isDir ) |
160 | return _dirPix; | 160 | return _dirPix; |
161 | else{ | 161 | else{ |
162 | if (!m_noInfo && !g_stringInf.contains( m_path ) ) { | 162 | if (!m_noInfo && !g_stringInf.contains( m_path ) ) { |
163 | g_stringInf.insert( m_path, const_cast<IconViewItem*>(this)); | 163 | g_stringInf.insert( m_path, const_cast<IconViewItem*>(this)); |
164 | currentView()->dirLister()->imageInfo( m_path ); | 164 | currentView()->dirLister()->imageInfo( m_path ); |
165 | } | 165 | } |
166 | 166 | ||
167 | m_pix = PPixmapCache::self()->cachedImage( m_path, m_iconsize, m_iconsize ); | 167 | m_pix = PPixmapCache::self()->cachedImage( m_path, m_iconsize, m_iconsize ); |
168 | if (!m_pix && !g_stringPix.contains( m_path )) { | 168 | if (!m_pix && !g_stringPix.contains( m_path )) { |
169 | check_pix(); | 169 | check_pix(); |
170 | g_stringPix.insert( m_path, const_cast<IconViewItem*>(this)); | 170 | g_stringPix.insert( m_path, const_cast<IconViewItem*>(this)); |
171 | currentView()->dirLister()->thumbNail( m_path, m_iconsize, m_iconsize); | 171 | currentView()->dirLister()->thumbNail( m_path, m_iconsize, m_iconsize); |
172 | } | 172 | } |
173 | return m_pix ? m_pix : _cpyPix; | 173 | return m_pix ? m_pix : _cpyPix; |
174 | } | 174 | } |
175 | } | 175 | } |
176 | inline void IconViewItem::setText( const QString& str ) { | 176 | inline void IconViewItem::setText( const QString& str ) { |
177 | QString text = QIconViewItem::text()+"\n"+str; | 177 | QString text = QIconViewItem::text()+"\n"+str; |
178 | m_noInfo = true; | 178 | m_noInfo = true; |
179 | QIconViewItem::setText( text ); | 179 | QIconViewItem::setText( text ); |
180 | } | 180 | } |
181 | } | 181 | } |
182 | 182 | ||
183 | 183 | ||
184 | /* | 184 | /* |
185 | * Set up the GUI.. initialize the slave set up gui | 185 | * Set up the GUI.. initialize the slave set up gui |
186 | * and also load a dir | 186 | * and also load a dir |
187 | */ | 187 | */ |
188 | PIconView::PIconView( QWidget* wid, Opie::Core::OConfig* cfg ) | 188 | PIconView::PIconView( QWidget* wid, Opie::Core::OConfig* cfg ) |
189 | : QVBox( wid ), m_cfg( cfg ), m_updatet( false ) | 189 | : QVBox( wid ), m_cfg( cfg ), m_updatet( false ) |
190 | { | 190 | { |
191 | { | 191 | { |
192 | QCopEnvelope( "QPE/Application/opie-eye_slave", "refUp()" ); | 192 | QCopEnvelope( "QPE/Application/opie-eye_slave", "refUp()" ); |
193 | } | 193 | } |
194 | m_path = QDir::homeDirPath(); | 194 | m_path = QDir::homeDirPath(); |
195 | m_mode = 0; | 195 | m_mode = 0; |
196 | m_iconsize = 32; | 196 | m_iconsize = 32; |
197 | m_internalReset = false; | 197 | m_internalReset = false; |
198 | m_customWidget = 0; | 198 | m_customWidget = 0; |
199 | m_setDocCalled = false; | ||
199 | 200 | ||
200 | m_hbox = new QHBox( this ); | 201 | m_hbox = new QHBox( this ); |
201 | QLabel* lbl = new QLabel( m_hbox ); | 202 | QLabel* lbl = new QLabel( m_hbox ); |
202 | lbl->setText( tr("View as" ) ); | 203 | lbl->setText( tr("View as" ) ); |
203 | 204 | ||
204 | m_views = new QComboBox( m_hbox, "View As" ); | 205 | m_views = new QComboBox( m_hbox, "View As" ); |
205 | 206 | ||
206 | m_view= new QIconView( this ); | 207 | m_view= new QIconView( this ); |
207 | connect(m_view, SIGNAL(clicked(QIconViewItem*) ), | 208 | connect(m_view, SIGNAL(clicked(QIconViewItem*) ), |
208 | this, SLOT(slotClicked(QIconViewItem*)) ); | 209 | this, SLOT(slotClicked(QIconViewItem*)) ); |
209 | connect(m_view, SIGNAL(returnPressed(QIconViewItem*)), | 210 | connect(m_view, SIGNAL(returnPressed(QIconViewItem*)), |
210 | this, SLOT(slotClicked(QIconViewItem*)) ); | 211 | this, SLOT(slotClicked(QIconViewItem*)) ); |
211 | 212 | ||
212 | m_view->setArrangement( QIconView::LeftToRight ); | 213 | m_view->setArrangement( QIconView::LeftToRight ); |
213 | 214 | ||
214 | m_mode = m_cfg->readNumEntry("ListViewMode", 1); | 215 | m_mode = m_cfg->readNumEntry("ListViewMode", 1); |
215 | QString lastView = m_cfg->readEntry("LastView",""); | ||
216 | |||
217 | if (m_mode < 1 || m_mode>3) m_mode = 1; | 216 | if (m_mode < 1 || m_mode>3) m_mode = 1; |
218 | |||
219 | m_view->setItemTextPos( QIconView::Right ); | 217 | m_view->setItemTextPos( QIconView::Right ); |
220 | if (m_mode >1) { | 218 | if (m_mode >1) { |
221 | m_view->setResizeMode(QIconView::Adjust); | 219 | m_view->setResizeMode(QIconView::Adjust); |
222 | } else { | 220 | } else { |
223 | m_view->setResizeMode(QIconView::Fixed); | 221 | m_view->setResizeMode(QIconView::Fixed); |
224 | } | 222 | } |
225 | m_iconsize = m_cfg->readNumEntry("iconsize", 32); | 223 | m_iconsize = m_cfg->readNumEntry("iconsize", 32); |
226 | if (m_iconsize<12)m_iconsize = 12; | 224 | if (m_iconsize<12)m_iconsize = 12; |
227 | if (m_iconsize>64)m_iconsize = 64; | 225 | if (m_iconsize>64)m_iconsize = 64; |
228 | 226 | ||
229 | calculateGrid(); | 227 | calculateGrid(); |
230 | |||
231 | initKeys(); | 228 | initKeys(); |
232 | |||
233 | loadViews(); | 229 | loadViews(); |
234 | int cc=0; | 230 | } |
235 | for (; cc<m_views->count();++cc) { | 231 | |
236 | if (m_views->text(cc)==lastView) { | 232 | void PIconView::setDoccalled(bool how) |
237 | break; | 233 | { |
238 | } | 234 | m_setDocCalled = how; |
239 | } | ||
240 | if (cc<m_views->count()) { | ||
241 | m_views->setCurrentItem(cc); | ||
242 | slotViewChanged(cc); | ||
243 | } else { | ||
244 | slotViewChanged(m_views->currentItem()); | ||
245 | } | ||
246 | connect( m_views, SIGNAL(activated(int)), | ||
247 | this, SLOT(slotViewChanged(int)) ); | ||
248 | } | 235 | } |
249 | 236 | ||
250 | /* | 237 | /* |
251 | * Unref the slave and save the keyboard manager | 238 | * Unref the slave and save the keyboard manager |
252 | */ | 239 | */ |
253 | PIconView::~PIconView() { | 240 | PIconView::~PIconView() { |
254 | { | 241 | { |
255 | QCopEnvelope( "QPE/Application/opie-eye_slave", "refDown()" ); | 242 | QCopEnvelope( "QPE/Application/opie-eye_slave", "refDown()" ); |
256 | } | 243 | } |
257 | m_viewManager->save(); | 244 | m_viewManager->save(); |
258 | delete m_viewManager; | 245 | delete m_viewManager; |
259 | } | 246 | } |
260 | 247 | ||
261 | Opie::Core::OKeyConfigManager* PIconView::manager() { | 248 | Opie::Core::OKeyConfigManager* PIconView::manager() { |
262 | return m_viewManager; | 249 | return m_viewManager; |
263 | } | 250 | } |
264 | 251 | ||
265 | 252 | ||
266 | /* | 253 | /* |
267 | * init the KeyBoard Shortcuts | 254 | * init the KeyBoard Shortcuts |
268 | * called from the c'tor | 255 | * called from the c'tor |
269 | */ | 256 | */ |
270 | void PIconView::initKeys() { | 257 | void PIconView::initKeys() { |
271 | Opie::Core::OKeyPair::List lst; | 258 | Opie::Core::OKeyPair::List lst; |
272 | lst.append( Opie::Core::OKeyPair::upArrowKey() ); | 259 | lst.append( Opie::Core::OKeyPair::upArrowKey() ); |
273 | lst.append( Opie::Core::OKeyPair::downArrowKey() ); | 260 | lst.append( Opie::Core::OKeyPair::downArrowKey() ); |
274 | lst.append( Opie::Core::OKeyPair::leftArrowKey() ); | 261 | lst.append( Opie::Core::OKeyPair::leftArrowKey() ); |
275 | lst.append( Opie::Core::OKeyPair::rightArrowKey() ); | 262 | lst.append( Opie::Core::OKeyPair::rightArrowKey() ); |
276 | lst.append( Opie::Core::OKeyPair::returnKey() ); | 263 | lst.append( Opie::Core::OKeyPair::returnKey() ); |
277 | 264 | ||
278 | m_viewManager = new Opie::Core::OKeyConfigManager(m_cfg, "View-KeyBoard-Config", | 265 | m_viewManager = new Opie::Core::OKeyConfigManager(m_cfg, "View-KeyBoard-Config", |
279 | lst, false,this, "keyconfig name" ); | 266 | lst, false,this, "keyconfig name" ); |
280 | m_viewManager->addKeyConfig( OKeyConfigItem(tr("Beam Current Item") , "beam", | 267 | m_viewManager->addKeyConfig( OKeyConfigItem(tr("Beam Current Item") , "beam", |
281 | Resource::loadPixmap("beam"), BeamItem, | 268 | Resource::loadPixmap("beam"), BeamItem, |
282 | Opie::Core::OKeyPair(Qt::Key_B, Qt::ShiftButton), | 269 | Opie::Core::OKeyPair(Qt::Key_B, Qt::ShiftButton), |
283 | this, SLOT(slotBeam())) ); | 270 | this, SLOT(slotBeam())) ); |
284 | m_viewManager->addKeyConfig( OKeyConfigItem(tr("Delete Current Item"), "delete", | 271 | m_viewManager->addKeyConfig( OKeyConfigItem(tr("Delete Current Item"), "delete", |
285 | Resource::loadPixmap("trash"), DeleteItem, | 272 | Resource::loadPixmap("trash"), DeleteItem, |
286 | Opie::Core::OKeyPair(Qt::Key_D, Qt::ShiftButton), | 273 | Opie::Core::OKeyPair(Qt::Key_D, Qt::ShiftButton), |
287 | this, SLOT(slotTrash())) ); | 274 | this, SLOT(slotTrash())) ); |
288 | m_viewManager->addKeyConfig( OKeyConfigItem(tr("View Current Item"), "view", | 275 | m_viewManager->addKeyConfig( OKeyConfigItem(tr("View Current Item"), "view", |
289 | Resource::loadPixmap("1to1"), ViewItem, | 276 | Resource::loadPixmap("1to1"), ViewItem, |
290 | Opie::Core::OKeyPair(Qt::Key_V, Qt::ShiftButton), | 277 | Opie::Core::OKeyPair(Qt::Key_V, Qt::ShiftButton), |
291 | this, SLOT(slotShowImage()))); | 278 | this, SLOT(slotShowImage()))); |
292 | m_viewManager->addKeyConfig( OKeyConfigItem(tr("Show Image Info") , "info", | 279 | m_viewManager->addKeyConfig( OKeyConfigItem(tr("Show Image Info") , "info", |
293 | Resource::loadPixmap("DocumentTypeWord"), InfoItem, | 280 | Resource::loadPixmap("DocumentTypeWord"), InfoItem, |
294 | Opie::Core::OKeyPair(Qt::Key_I, Qt::ShiftButton ), | 281 | Opie::Core::OKeyPair(Qt::Key_I, Qt::ShiftButton ), |
295 | this, SLOT(slotImageInfo()) ) ); | 282 | this, SLOT(slotImageInfo()) ) ); |
296 | m_viewManager->addKeyConfig( OKeyConfigItem(tr("Start slideshow"), "slideshow", | 283 | m_viewManager->addKeyConfig( OKeyConfigItem(tr("Start slideshow"), "slideshow", |
297 | Resource::loadPixmap("1to1"), SlideItem, | 284 | Resource::loadPixmap("1to1"), SlideItem, |
298 | Opie::Core::OKeyPair(Qt::Key_S, Qt::ShiftButton), | 285 | Opie::Core::OKeyPair(Qt::Key_S, Qt::ShiftButton), |
299 | this, SLOT(slotStartSlide()))); | 286 | this, SLOT(slotStartSlide()))); |
300 | m_viewManager->load(); | 287 | m_viewManager->load(); |
301 | m_viewManager->handleWidget( m_view ); | 288 | m_viewManager->handleWidget( m_view ); |
302 | } | 289 | } |
303 | 290 | ||
304 | 291 | ||
305 | /* | 292 | /* |
306 | * change one dir up | 293 | * change one dir up |
307 | */ | 294 | */ |
308 | void PIconView::slotDirUp() | 295 | void PIconView::slotDirUp() |
309 | { | 296 | { |
310 | slotChangeDir( currentView()->dirLister()->dirUp( m_path ) ); | 297 | slotChangeDir( currentView()->dirLister()->dirUp( m_path ) ); |
311 | } | 298 | } |
312 | 299 | ||
313 | /* | 300 | /* |
314 | * change the dir | 301 | * change the dir |
315 | */ | 302 | */ |
316 | void PIconView::slotChangeDir(const QString& path) { | 303 | void PIconView::slotChangeDir(const QString& path) { |
317 | if ( !currentView() ) | 304 | if ( !currentView() ) |
318 | return; | 305 | return; |
319 | 306 | ||
320 | PDirLister *lister = currentView()->dirLister(); | 307 | PDirLister *lister = currentView()->dirLister(); |
321 | if (!lister ) | 308 | if (!lister ) |
322 | return; | 309 | return; |
323 | 310 | ||
324 | /* | 311 | /* |
325 | * Say what we want and take what we get | 312 | * Say what we want and take what we get |
326 | */ | 313 | */ |
327 | lister->setStartPath( path ); | 314 | lister->setStartPath( path ); |
328 | m_path = lister->currentPath(); | 315 | m_path = lister->currentPath(); |
329 | 316 | ||
330 | m_view->viewport()->setUpdatesEnabled( false ); | 317 | m_view->viewport()->setUpdatesEnabled( false ); |
331 | m_view->clear(); | 318 | m_view->clear(); |
332 | 319 | ||
333 | // Also invalidate the cache. We can't cancel the operations anyway | 320 | // Also invalidate the cache. We can't cancel the operations anyway |
334 | g_stringPix.clear(); | 321 | g_stringPix.clear(); |
335 | g_stringInf.clear(); | 322 | g_stringInf.clear(); |
336 | 323 | ||
337 | /* | 324 | /* |
338 | * add files and folders | 325 | * add files and folders |
339 | */ | 326 | */ |
340 | addFolders( lister->folders() ); | 327 | addFolders( lister->folders() ); |
341 | addFiles( lister->files() ); | 328 | addFiles( lister->files() ); |
342 | m_view->viewport()->setUpdatesEnabled( true ); | 329 | m_view->viewport()->setUpdatesEnabled( true ); |
343 | 330 | ||
344 | // looks ugly | 331 | // looks ugly |
345 | static_cast<QMainWindow*>(parent())->setCaption( QObject::tr("%1 - O View", "Name of the dir").arg( m_path ) ); | 332 | static_cast<QMainWindow*>(parent())->setCaption( QObject::tr("%1 - O View", "Name of the dir").arg( m_path ) ); |
346 | } | 333 | } |
347 | 334 | ||
348 | /** | 335 | /** |
349 | * get the current file name | 336 | * get the current file name |
350 | * @param isDir see if this is a dir or real file | 337 | * @param isDir see if this is a dir or real file |
351 | */ | 338 | */ |
352 | QString PIconView::currentFileName(bool &isDir)const { | 339 | QString PIconView::currentFileName(bool &isDir)const { |
353 | isDir = false; | 340 | isDir = false; |
354 | QIconViewItem* _it = m_view->currentItem(); | 341 | QIconViewItem* _it = m_view->currentItem(); |
355 | if ( !_it ) | 342 | if ( !_it ) |
356 | return QString::null; | 343 | return QString::null; |
357 | 344 | ||
358 | IconViewItem* it = static_cast<IconViewItem*>( _it ); | 345 | IconViewItem* it = static_cast<IconViewItem*>( _it ); |
359 | isDir = it->isDir(); | 346 | isDir = it->isDir(); |
360 | return it->path(); | 347 | return it->path(); |
361 | } | 348 | } |
362 | 349 | ||
363 | QString PIconView::nextFileName(bool &isDir)const | 350 | QString PIconView::nextFileName(bool &isDir)const |
364 | { | 351 | { |
365 | isDir = false; | 352 | isDir = false; |
366 | QIconViewItem* _it1 = m_view->currentItem(); | 353 | QIconViewItem* _it1 = m_view->currentItem(); |
367 | if ( !_it1 ) | 354 | if ( !_it1 ) |
368 | return QString::null; | 355 | return QString::null; |
369 | QIconViewItem* _it = _it1->nextItem(); | 356 | QIconViewItem* _it = _it1->nextItem(); |
370 | if ( !_it ) | 357 | if ( !_it ) |
371 | return QString::null; | 358 | return QString::null; |
372 | IconViewItem* it = static_cast<IconViewItem*>( _it ); | 359 | IconViewItem* it = static_cast<IconViewItem*>( _it ); |
373 | isDir = it->isDir(); | 360 | isDir = it->isDir(); |
374 | return it->path(); | 361 | return it->path(); |
375 | } | 362 | } |
376 | 363 | ||
377 | QString PIconView::prevFileName(bool &isDir)const{ | 364 | QString PIconView::prevFileName(bool &isDir)const{ |
378 | isDir = false; | 365 | isDir = false; |
379 | QIconViewItem* _it = m_view->currentItem(); | 366 | QIconViewItem* _it = m_view->currentItem(); |
380 | if ( !_it ) | 367 | if ( !_it ) |
381 | return QString::null; | 368 | return QString::null; |
382 | _it = _it->prevItem(); | 369 | _it = _it->prevItem(); |
383 | if ( !_it ) | 370 | if ( !_it ) |
384 | return QString::null; | 371 | return QString::null; |
385 | IconViewItem* it = static_cast<IconViewItem*>( _it ); | 372 | IconViewItem* it = static_cast<IconViewItem*>( _it ); |
386 | isDir = it->isDir(); | 373 | isDir = it->isDir(); |
387 | return it->path(); | 374 | return it->path(); |
388 | } | 375 | } |
389 | 376 | ||
390 | void PIconView::slotTrash() { | 377 | void PIconView::slotTrash() { |
391 | bool isDir; | 378 | bool isDir; |
392 | QString pa = currentFileName( isDir ); | 379 | QString pa = currentFileName( isDir ); |
393 | if ( isDir && pa.isEmpty() ) | 380 | if ( isDir && pa.isEmpty() ) |
394 | return; | 381 | return; |
395 | 382 | ||
396 | if (!QPEMessageBox::confirmDelete( this, | 383 | if (!QPEMessageBox::confirmDelete( this, |
397 | tr("Delete Image" ), | 384 | tr("Delete Image" ), |
398 | tr("the Image %1" ).arg(pa))) | 385 | tr("the Image %1" ).arg(pa))) |
399 | return | 386 | return |
400 | 387 | ||
401 | 388 | ||
402 | currentView()->dirLister()->deleteImage( pa ); | 389 | currentView()->dirLister()->deleteImage( pa ); |
403 | delete m_view->currentItem(); | 390 | delete m_view->currentItem(); |
404 | } | 391 | } |
405 | 392 | ||
406 | /* | 393 | /* |
407 | * see what views are available | 394 | * see what views are available |
408 | */ | 395 | */ |
409 | void PIconView::loadViews() { | 396 | void PIconView::loadViews() { |
410 | ViewMap::Iterator it; | 397 | ViewMap::Iterator it; |
411 | ViewMap* map = viewMap(); | 398 | ViewMap* map = viewMap(); |
412 | for ( it = map->begin(); it != map->end(); ++it ) | 399 | for ( it = map->begin(); it != map->end(); ++it ) |
413 | m_views->insertItem( it.key() ); | 400 | m_views->insertItem( it.key() ); |
414 | } | 401 | } |
415 | 402 | ||
416 | void PIconView::resetView() { | 403 | void PIconView::resetView() { |
417 | m_internalReset = true; | 404 | m_internalReset = true; |
418 | // Also invalidate the cache. We can't cancel the operations anyway | 405 | // Also invalidate the cache. We can't cancel the operations anyway |
419 | g_stringPix.clear(); | 406 | g_stringPix.clear(); |
420 | g_stringInf.clear(); | 407 | g_stringInf.clear(); |
421 | if (m_mode>1) { | 408 | if (m_mode>1) { |
422 | int osize = m_iconsize; | 409 | int osize = m_iconsize; |
423 | m_iconsize = m_cfg->readNumEntry("iconsize", 32); | 410 | m_iconsize = m_cfg->readNumEntry("iconsize", 32); |
424 | if (m_iconsize<12)m_iconsize = 12; | 411 | if (m_iconsize<12)m_iconsize = 12; |
425 | if (m_iconsize>64)m_iconsize = 64; | 412 | if (m_iconsize>64)m_iconsize = 64; |
426 | if (osize != m_iconsize) { | 413 | if (osize != m_iconsize) { |
427 | if (_dirPix){ | 414 | if (_dirPix){ |
428 | delete _dirPix; | 415 | delete _dirPix; |
429 | _dirPix = 0; | 416 | _dirPix = 0; |
430 | } | 417 | } |
431 | if (_cpyPix){ | 418 | if (_cpyPix){ |
432 | delete _cpyPix; | 419 | delete _cpyPix; |
433 | _cpyPix = 0; | 420 | _cpyPix = 0; |
434 | } | 421 | } |
435 | calculateGrid(); | 422 | calculateGrid(); |
436 | } | 423 | } |
437 | } else { | 424 | } else { |
438 | m_iconsize = 64; | 425 | m_iconsize = 64; |
439 | } | 426 | } |
440 | slotViewChanged(m_views->currentItem()); | 427 | slotViewChanged(m_views->currentItem()); |
441 | m_internalReset = false; | 428 | m_internalReset = false; |
442 | } | 429 | } |
443 | 430 | ||
431 | void PIconView::polish() | ||
432 | { | ||
433 | odebug << "===\n" | ||
434 | << "PIconView::polish()\n" | ||
435 | << "====" << oendl; | ||
436 | QVBox::polish(); | ||
437 | |||
438 | QString lastView = m_cfg->readEntry("LastView",""); | ||
439 | int cc=0; | ||
440 | for (; cc<m_views->count();++cc) { | ||
441 | if (m_views->text(cc)==lastView) { | ||
442 | break; | ||
443 | } | ||
444 | } | ||
445 | if (cc<m_views->count()) { | ||
446 | m_views->setCurrentItem(cc); | ||
447 | slotViewChanged(cc); | ||
448 | } else { | ||
449 | slotViewChanged(m_views->currentItem()); | ||
450 | } | ||
451 | connect( m_views, SIGNAL(activated(int)), | ||
452 | this, SLOT(slotViewChanged(int)) ); | ||
453 | } | ||
454 | |||
444 | /* | 455 | /* |
445 | *swicth view reloadDir and connect signals | 456 | *swicth view reloadDir and connect signals |
446 | */ | 457 | */ |
447 | void PIconView::slotViewChanged( int i) { | 458 | void PIconView::slotViewChanged( int i) { |
448 | if (!m_views->count() ) { | 459 | if (!m_views->count() ) { |
449 | setCurrentView( 0l); | 460 | setCurrentView( 0l); |
450 | return; | 461 | return; |
451 | } | 462 | } |
452 | 463 | ||
453 | if (m_customWidget) { | 464 | if (m_customWidget) { |
454 | delete m_customWidget; | 465 | delete m_customWidget; |
455 | m_customWidget = 0; | 466 | m_customWidget = 0; |
456 | } | 467 | } |
457 | PDirView* cur = currentView(); | 468 | PDirView* cur = currentView(); |
458 | if (cur) { | 469 | if (cur) { |
459 | delete cur; | 470 | delete cur; |
460 | } | 471 | } |
461 | QString str = m_views->text(i); | 472 | QString str = m_views->text(i); |
462 | ViewMap* map = viewMap(); | 473 | ViewMap* map = viewMap(); |
463 | if (!map) { | 474 | if (!map) { |
464 | setCurrentView(0l); | 475 | setCurrentView(0l); |
465 | return; | 476 | return; |
466 | } | 477 | } |
467 | 478 | ||
468 | if (map->find(str) == map->end()) { | 479 | if (map->find(str) == map->end()) { |
469 | owarn << "Key not found" << oendl; | 480 | owarn << "Key not found" << oendl; |
470 | setCurrentView(0l); | 481 | setCurrentView(0l); |
471 | return; | 482 | return; |
472 | } | 483 | } |
473 | 484 | ||
474 | m_cfg->writeEntry("LastView",str); | 485 | m_cfg->writeEntry("LastView",str); |
475 | m_cfg->write(); | 486 | m_cfg->write(); |
476 | cur = (*(*map)[str])(*m_cfg); | 487 | cur = (*(*map)[str])(*m_cfg); |
477 | setCurrentView( cur ); | 488 | setCurrentView( cur ); |
478 | m_customWidget = cur->widget(m_hbox); | 489 | m_customWidget = cur->widget(m_hbox); |
479 | if (m_customWidget) { | 490 | if (m_customWidget) { |
480 | odebug << "Got a widget" << oendl; | 491 | odebug << "Got a widget" << oendl; |
481 | m_customWidget->show(); | 492 | m_customWidget->show(); |
482 | } | 493 | } |
483 | 494 | ||
484 | /* connect to the signals of the lister */ | 495 | /* connect to the signals of the lister */ |
485 | PDirLister* lis = cur->dirLister(); | 496 | PDirLister* lis = cur->dirLister(); |
486 | connect(lis, SIGNAL(sig_thumbInfo(const QString&, const QString& )), | 497 | connect(lis, SIGNAL(sig_thumbInfo(const QString&, const QString& )), |
487 | this, SLOT( slotThumbInfo(const QString&, const QString&))); | 498 | this, SLOT( slotThumbInfo(const QString&, const QString&))); |
488 | connect(lis, SIGNAL( sig_thumbNail(const QString&, const QPixmap&)), | 499 | connect(lis, SIGNAL( sig_thumbNail(const QString&, const QPixmap&)), |
489 | this, SLOT(slotThumbNail(const QString&, const QPixmap&))); | 500 | this, SLOT(slotThumbNail(const QString&, const QPixmap&))); |
490 | connect(lis, SIGNAL(sig_start()), | 501 | connect(lis, SIGNAL(sig_start()), |
491 | this, SLOT(slotStart())); | 502 | this, SLOT(slotStart())); |
492 | connect(lis, SIGNAL(sig_end()) , | 503 | connect(lis, SIGNAL(sig_end()) , |
493 | this, SLOT(slotEnd()) ); | 504 | this, SLOT(slotEnd()) ); |
494 | connect(lis,SIGNAL(sig_reloadDir()),this,SLOT(slotReloadDir())); | 505 | connect(lis,SIGNAL(sig_reloadDir()),this,SLOT(slotReloadDir())); |
495 | 506 | ||
496 | /* reload now with default Path | 507 | /* reload now with default Path |
497 | * but only if it isn't a reset like from setupdlg | 508 | * but only if it isn't a reset like from setupdlg |
498 | */ | 509 | */ |
499 | if (!m_internalReset) { | 510 | if (!m_internalReset) { |
500 | m_path = lis->defaultPath(); | 511 | m_path = lis->defaultPath(); |
501 | } | 512 | } |
502 | QTimer::singleShot( 0, this, SLOT(slotReloadDir())); | 513 | QTimer::singleShot( 0, this, SLOT(slotReloadDir())); |
503 | } | 514 | } |
504 | 515 | ||
505 | 516 | ||
506 | void PIconView::slotReloadDir() { | 517 | void PIconView::slotReloadDir() { |
507 | slotChangeDir( m_path ); | 518 | slotChangeDir( m_path ); |
508 | } | 519 | } |
509 | 520 | ||
510 | 521 | ||
511 | /* | 522 | /* |
512 | * add files and folders | 523 | * add files and folders |
513 | */ | 524 | */ |
514 | void PIconView::addFolders( const QStringList& lst) { | 525 | void PIconView::addFolders( const QStringList& lst) { |
515 | QStringList::ConstIterator it; | 526 | QStringList::ConstIterator it; |
516 | IconViewItem * _iv; | 527 | IconViewItem * _iv; |
517 | 528 | ||
518 | for(it=lst.begin(); it != lst.end(); ++it ) { | 529 | for(it=lst.begin(); it != lst.end(); ++it ) { |
519 | _iv = new IconViewItem( m_view, m_path+"/"+(*it), (*it),m_iconsize, true ); | 530 | _iv = new IconViewItem( m_view, m_path+"/"+(*it), (*it),m_iconsize, true ); |
520 | if (m_mode==3) _iv->setTextOnly(true); | 531 | if (m_mode==3) _iv->setTextOnly(true); |
521 | } | 532 | } |
522 | } | 533 | } |
523 | 534 | ||
524 | void PIconView::addFiles( const QStringList& lst) { | 535 | void PIconView::addFiles( const QStringList& lst) { |
525 | QStringList::ConstIterator it; | 536 | QStringList::ConstIterator it; |
526 | IconViewItem * _iv; | 537 | IconViewItem * _iv; |
527 | QPixmap*m_pix = 0; | 538 | QPixmap*m_pix = 0; |
528 | QString pre = ""; | 539 | QString pre = ""; |
529 | if (!m_path.isEmpty()) { | 540 | if (!m_path.isEmpty()) { |
530 | pre = m_path+"/"; | 541 | pre = m_path+"/"; |
531 | } | 542 | } |
543 | QString s = ""; | ||
544 | int pos; | ||
532 | for (it=lst.begin(); it!= lst.end(); ++it ) { | 545 | for (it=lst.begin(); it!= lst.end(); ++it ) { |
533 | m_pix = PPixmapCache::self()->cachedImage( pre+(*it), m_iconsize, m_iconsize ); | 546 | s = (*it); |
534 | _iv = new IconViewItem( m_view, pre+(*it), (*it),m_iconsize ); | 547 | pos = s.find(char(0)); |
548 | m_pix = PPixmapCache::self()->cachedImage( pre+(*it), m_iconsize, m_iconsize ); | ||
549 | if (pos>-1) { | ||
550 | _iv = new IconViewItem( m_view, s.mid(pos+1), s.left(pos),m_iconsize ); | ||
551 | } else { | ||
552 | _iv = new IconViewItem( m_view, pre+(*it), (*it),m_iconsize ); | ||
553 | } | ||
535 | if (m_mode==3) { | 554 | if (m_mode==3) { |
536 | _iv->setTextOnly(true); | 555 | _iv->setTextOnly(true); |
537 | _iv->setPixmap(QPixmap()); | 556 | _iv->setPixmap(QPixmap()); |
538 | |||
539 | |||
540 | |||
541 | } else { | 557 | } else { |
542 | if (m_pix) _iv->setPixmap(*m_pix); | 558 | if (m_pix) _iv->setPixmap(*m_pix); |
543 | } | 559 | } |
544 | } | 560 | } |
545 | 561 | ||
546 | } | 562 | } |
547 | 563 | ||
548 | /* | 564 | /* |
549 | * user clicked on the item. Change dir or view | 565 | * user clicked on the item. Change dir or view |
550 | */ | 566 | */ |
551 | void PIconView::slotClicked(QIconViewItem* _it) { | 567 | void PIconView::slotClicked(QIconViewItem* _it) { |
552 | if(!_it ) | 568 | if(!_it ) |
553 | return; | 569 | return; |
554 | 570 | ||
555 | IconViewItem* it = static_cast<IconViewItem*>(_it); | 571 | IconViewItem* it = static_cast<IconViewItem*>(_it); |
556 | if( it->isDir() ) | 572 | if( it->isDir() ) |
557 | slotChangeDir( it->path() ); | 573 | slotChangeDir( it->path() ); |
558 | else // view image | 574 | else // view image |
559 | slotShowImage(); | 575 | slotShowImage(); |
560 | } | 576 | } |
561 | 577 | ||
562 | /* | 578 | /* |
563 | * Return was pressed. which is triggered by the keydown | 579 | * Return was pressed. which is triggered by the keydown |
564 | * handler. The problem is that the key up will be handled | 580 | * handler. The problem is that the key up will be handled |
565 | * by the ImageDisplayer and goes to the next image | 581 | * by the ImageDisplayer and goes to the next image |
566 | */ | 582 | */ |
567 | void PIconView::slotRetrun( QIconViewItem *_it ) { | 583 | void PIconView::slotRetrun( QIconViewItem *_it ) { |
568 | if(!_it ) | 584 | if(!_it ) |
569 | return; | 585 | return; |
570 | 586 | ||
571 | IconViewItem* it = static_cast<IconViewItem*>(_it); | 587 | IconViewItem* it = static_cast<IconViewItem*>(_it); |
572 | if( it->isDir() ) | 588 | if( it->isDir() ) |
573 | slotChangeDir( it->path() ); | 589 | slotChangeDir( it->path() ); |
574 | else | 590 | else |
575 | QTimer::singleShot(0, this, SLOT(slotShowImage()) ); | 591 | QTimer::singleShot(0, this, SLOT(slotShowImage()) ); |
576 | } | 592 | } |
577 | 593 | ||
578 | /* | 594 | /* |
579 | * got thumb info add to the cache if items is visible | 595 | * got thumb info add to the cache if items is visible |
580 | * we later need update after processing of slave is done | 596 | * we later need update after processing of slave is done |
581 | */ | 597 | */ |
582 | void PIconView::slotThumbInfo( const QString& _path, const QString& str ) { | 598 | void PIconView::slotThumbInfo( const QString& _path, const QString& str ) { |
583 | IconViewItem* item = g_stringInf[_path]; | 599 | IconViewItem* item = g_stringInf[_path]; |
584 | if (!item ) | 600 | if (!item ) |
585 | return; | 601 | return; |
586 | 602 | ||
587 | if (m_mode == 2) { | 603 | if (m_mode == 2) { |
588 | return; | 604 | return; |
589 | } | 605 | } |
590 | if ( item->intersects(QRect( m_view->contentsX(),m_view->contentsY(), | 606 | if ( item->intersects(QRect( m_view->contentsX(),m_view->contentsY(), |
591 | m_view->contentsWidth(), m_view->contentsHeight() ) ) ) | 607 | m_view->contentsWidth(), m_view->contentsHeight() ) ) ) |
592 | m_updatet = true; | 608 | m_updatet = true; |
593 | 609 | ||
594 | item->setText( str ); | 610 | item->setText( str ); |
595 | g_stringInf.remove( _path ); | 611 | g_stringInf.remove( _path ); |
596 | } | 612 | } |
597 | 613 | ||
598 | /* | 614 | /* |
599 | * got thumbnail and see if it is visible so we need to update later | 615 | * got thumbnail and see if it is visible so we need to update later |
600 | */ | 616 | */ |
601 | void PIconView::slotThumbNail(const QString& _path, const QPixmap &pix) { | 617 | void PIconView::slotThumbNail(const QString& _path, const QPixmap &pix) { |
602 | IconViewItem* item = g_stringPix[_path]; | 618 | IconViewItem* item = g_stringPix[_path]; |
603 | if (!item ) | 619 | if (!item ) |
604 | return; | 620 | return; |
605 | 621 | ||
606 | if ( item->intersects(QRect( m_view->contentsX(),m_view->contentsY(), | 622 | if ( item->intersects(QRect( m_view->contentsX(),m_view->contentsY(), |
607 | m_view->contentsWidth(), m_view->contentsHeight() ) ) ) | 623 | m_view->contentsWidth(), m_view->contentsHeight() ) ) ) |
608 | m_updatet = true; | 624 | m_updatet = true; |
609 | 625 | ||
610 | if (pix.width()>0) { | 626 | if (pix.width()>0) { |
611 | if (pix.width()<m_iconsize) { | 627 | if (pix.width()<m_iconsize) { |
612 | QPixmap p(m_iconsize,m_iconsize); | 628 | QPixmap p(m_iconsize,m_iconsize); |
613 | p.fill(); | 629 | p.fill(); |
614 | QPainter pa(&p); | 630 | QPainter pa(&p); |
615 | int offset = (m_iconsize-pix.width())/2; | 631 | int offset = (m_iconsize-pix.width())/2; |
616 | int offy = (m_iconsize-pix.height())/2; | 632 | int offy = (m_iconsize-pix.height())/2; |
617 | if (offy<0) offy=0; | 633 | if (offy<0) offy=0; |
618 | pa.drawPixmap(offset,offy,pix); | 634 | pa.drawPixmap(offset,offy,pix); |
619 | pa.end(); | 635 | pa.end(); |
620 | PPixmapCache::self()->insertImage( _path, p, m_iconsize, m_iconsize ); | 636 | PPixmapCache::self()->insertImage( _path, p, m_iconsize, m_iconsize ); |
621 | item->setPixmap(p,true); | 637 | item->setPixmap(p,true); |
622 | } else { | 638 | } else { |
623 | PPixmapCache::self()->insertImage( _path, pix, m_iconsize, m_iconsize ); | 639 | PPixmapCache::self()->insertImage( _path, pix, m_iconsize, m_iconsize ); |
624 | item->setPixmap(pix,true); | 640 | item->setPixmap(pix,true); |
625 | } | 641 | } |
626 | 642 | ||
627 | } else { | 643 | } else { |
628 | PPixmapCache::self()->insertImage( _path, Resource::loadPixmap( "UnknownDocument" ), m_iconsize, m_iconsize ); | 644 | PPixmapCache::self()->insertImage( _path, Resource::loadPixmap( "UnknownDocument" ), m_iconsize, m_iconsize ); |
629 | } | 645 | } |
630 | g_stringPix.remove( _path ); | 646 | g_stringPix.remove( _path ); |
631 | m_view->arrangeItemsInGrid(true); | 647 | m_view->arrangeItemsInGrid(true); |
632 | } | 648 | } |
633 | 649 | ||
634 | 650 | ||
635 | /* | 651 | /* |
636 | * FIXME rename | 652 | * FIXME rename |
637 | */ | 653 | */ |
638 | void PIconView::slotRename() { | 654 | void PIconView::slotRename() { |
639 | 655 | ||
640 | } | 656 | } |
641 | 657 | ||
642 | 658 | ||
643 | /* | 659 | /* |
644 | * BEAM the current file | 660 | * BEAM the current file |
645 | */ | 661 | */ |
646 | void PIconView::slotBeam() { | 662 | void PIconView::slotBeam() { |
647 | bool isDir; | 663 | bool isDir; |
648 | QString pa = currentFileName( isDir ); | 664 | QString pa = currentFileName( isDir ); |
649 | if ( isDir && pa.isEmpty() ) | 665 | if ( isDir && pa.isEmpty() ) |
650 | return; | 666 | return; |
651 | 667 | ||
652 | Ir* ir = new Ir( this ); | 668 | Ir* ir = new Ir( this ); |
653 | connect( ir, SIGNAL(done(Ir*)), | 669 | connect( ir, SIGNAL(done(Ir*)), |
654 | this, SLOT(slotBeamDone(Ir*))); | 670 | this, SLOT(slotBeamDone(Ir*))); |
655 | ir->send(pa, tr( "Image" ) ); | 671 | ir->send(pa, tr( "Image" ) ); |
656 | } | 672 | } |
657 | 673 | ||
658 | /* | 674 | /* |
659 | * BEAM done clean up | 675 | * BEAM done clean up |
660 | */ | 676 | */ |
661 | void PIconView::slotBeamDone( Ir* ir) { | 677 | void PIconView::slotBeamDone( Ir* ir) { |
662 | delete ir; | 678 | delete ir; |
663 | } | 679 | } |
664 | 680 | ||
665 | void PIconView::slotStart() { | 681 | void PIconView::slotStart() { |
666 | m_view->viewport()->setUpdatesEnabled( false ); | 682 | m_view->viewport()->setUpdatesEnabled( false ); |
667 | } | 683 | } |
668 | 684 | ||
669 | void PIconView::slotEnd() { | 685 | void PIconView::slotEnd() { |
670 | if ( m_updatet ) | 686 | if ( m_updatet ) |
671 | m_view->arrangeItemsInGrid( ); | 687 | m_view->arrangeItemsInGrid( ); |
672 | m_view->viewport()->setUpdatesEnabled( true ); | 688 | m_view->viewport()->setUpdatesEnabled( true ); |
673 | m_updatet = false; | 689 | m_updatet = false; |
674 | } | 690 | } |
675 | 691 | ||
676 | void PIconView::slotShowLast() | 692 | void PIconView::slotShowLast() |
677 | { | 693 | { |
678 | QIconViewItem* last_it = m_view->lastItem(); | 694 | QIconViewItem* last_it = m_view->lastItem(); |
679 | if (!last_it) return; | 695 | if (!last_it) return; |
680 | m_view->setCurrentItem(last_it); | 696 | m_view->setCurrentItem(last_it); |
681 | IconViewItem* it = static_cast<IconViewItem*>( last_it ); | 697 | IconViewItem* it = static_cast<IconViewItem*>( last_it ); |
682 | bool isDir = it->isDir(); | 698 | bool isDir = it->isDir(); |
683 | QString name = it->path(); | 699 | QString name = it->path(); |
684 | if (!isDir && !name.isEmpty()) { | 700 | if (!isDir && !name.isEmpty()) { |
685 | slotShowImage(name); | 701 | slotShowImage(name); |
686 | return; | 702 | return; |
687 | } | 703 | } |
688 | bool first_loop = true; | 704 | bool first_loop = true; |
689 | while(isDir==true) { | 705 | while(isDir==true) { |
690 | if (!first_loop) { | 706 | if (!first_loop) { |
691 | m_view->setCurrentItem(m_view->currentItem()->prevItem()); | 707 | m_view->setCurrentItem(m_view->currentItem()->prevItem()); |
692 | } else { | 708 | } else { |
693 | first_loop = false; | 709 | first_loop = false; |
694 | } | 710 | } |
695 | name = prevFileName(isDir); | 711 | name = prevFileName(isDir); |
696 | } | 712 | } |
697 | 713 | ||
698 | if (name.isEmpty()) return; | 714 | if (name.isEmpty()) return; |
699 | /* if we got a name we have a prev item */ | 715 | /* if we got a name we have a prev item */ |
700 | m_view->setCurrentItem(m_view->currentItem()->prevItem()); | 716 | m_view->setCurrentItem(m_view->currentItem()->prevItem()); |
701 | slotShowImage(name); | 717 | slotShowImage(name); |
702 | } | 718 | } |
703 | 719 | ||
704 | bool PIconView::slotShowFirst() | 720 | bool PIconView::slotShowFirst() |
705 | { | 721 | { |
706 | /* stop when reached - otherwise we may get an endless loop */ | 722 | /* stop when reached - otherwise we may get an endless loop */ |
707 | QIconViewItem* first_it = m_view->firstItem(); | 723 | QIconViewItem* first_it = m_view->firstItem(); |
708 | if (!first_it) return false; | 724 | if (!first_it) return false; |
709 | m_view->setCurrentItem(first_it); | 725 | m_view->setCurrentItem(first_it); |
710 | IconViewItem* it = static_cast<IconViewItem*>( first_it ); | 726 | IconViewItem* it = static_cast<IconViewItem*>( first_it ); |
711 | bool isDir = it->isDir(); | 727 | bool isDir = it->isDir(); |
712 | QString name = it->path(); | 728 | QString name = it->path(); |
713 | if (!isDir && !name.isEmpty()) { | 729 | if (!isDir && !name.isEmpty()) { |
714 | slotShowImage(name); | 730 | slotShowImage(name); |
715 | return false; | 731 | return false; |
716 | } | 732 | } |
717 | bool first_loop = true; | 733 | bool first_loop = true; |
718 | while(isDir==true) { | 734 | while(isDir==true) { |
719 | /* if name is empty isDir is false, too. */ | 735 | /* if name is empty isDir is false, too. */ |
720 | if (!first_loop) { | 736 | if (!first_loop) { |
721 | m_view->setCurrentItem(m_view->currentItem()->nextItem()); | 737 | m_view->setCurrentItem(m_view->currentItem()->nextItem()); |
722 | } else { | 738 | } else { |
723 | first_loop = false; | 739 | first_loop = false; |
724 | } | 740 | } |
725 | name = nextFileName(isDir); | 741 | name = nextFileName(isDir); |
726 | } | 742 | } |
727 | if (name.isEmpty()) return false; | 743 | if (name.isEmpty()) return false; |
728 | /* if we got a name we have a next item */ | 744 | /* if we got a name we have a next item */ |
729 | m_view->setCurrentItem(m_view->currentItem()->nextItem()); | 745 | m_view->setCurrentItem(m_view->currentItem()->nextItem()); |
730 | slotShowImage(name); | 746 | slotShowImage(name); |
731 | return true; | 747 | return true; |
732 | } | 748 | } |
diff --git a/noncore/graphics/opie-eye/gui/iconview.h b/noncore/graphics/opie-eye/gui/iconview.h index 78dda58..6e08fd8 100644 --- a/noncore/graphics/opie-eye/gui/iconview.h +++ b/noncore/graphics/opie-eye/gui/iconview.h | |||
@@ -1,104 +1,108 @@ | |||
1 | /* | 1 | /* |
2 | * GPLv2 zecke@handhelds.org | 2 | * GPLv2 zecke@handhelds.org |
3 | * No WArranty... | 3 | * No WArranty... |
4 | */ | 4 | */ |
5 | 5 | ||
6 | #ifndef PHUNK_ICON_VIEW_H | 6 | #ifndef PHUNK_ICON_VIEW_H |
7 | #define PHUNK_ICON_VIEW_H | 7 | #define PHUNK_ICON_VIEW_H |
8 | 8 | ||
9 | #include <qvbox.h> | 9 | #include <qvbox.h> |
10 | 10 | ||
11 | 11 | ||
12 | class QIconView; | 12 | class QIconView; |
13 | class QIconViewItem; | 13 | class QIconViewItem; |
14 | class QComboBox; | 14 | class QComboBox; |
15 | class PIconViewItem; | 15 | class PIconViewItem; |
16 | class PDirLister; | 16 | class PDirLister; |
17 | class Ir; | 17 | class Ir; |
18 | 18 | ||
19 | namespace Opie { | 19 | namespace Opie { |
20 | namespace Core{ | 20 | namespace Core{ |
21 | class OConfig; | 21 | class OConfig; |
22 | class OKeyConfigManager; | 22 | class OKeyConfigManager; |
23 | } | 23 | } |
24 | } | 24 | } |
25 | 25 | ||
26 | class PIconView : public QVBox { | 26 | class PIconView : public QVBox { |
27 | Q_OBJECT | 27 | Q_OBJECT |
28 | friend class PIconViewItem; | 28 | friend class PIconViewItem; |
29 | enum ActionIds { | 29 | enum ActionIds { |
30 | BeamItem, DeleteItem, ViewItem, InfoItem,SlideItem | 30 | BeamItem, DeleteItem, ViewItem, InfoItem,SlideItem |
31 | }; | 31 | }; |
32 | public: | 32 | public: |
33 | PIconView( QWidget* wid, Opie::Core::OConfig *cfg ); | 33 | PIconView( QWidget* wid, Opie::Core::OConfig *cfg ); |
34 | ~PIconView(); | 34 | ~PIconView(); |
35 | void resetView(); | 35 | void resetView(); |
36 | Opie::Core::OKeyConfigManager* manager(); | 36 | Opie::Core::OKeyConfigManager* manager(); |
37 | 37 | ||
38 | void setDoccalled(bool); | ||
39 | |||
38 | signals: | 40 | signals: |
39 | void sig_showInfo( const QString& ); | 41 | void sig_showInfo( const QString& ); |
40 | void sig_display(const QString&); | 42 | void sig_display(const QString&); |
41 | void sig_startslide(int timeout); | 43 | void sig_startslide(int timeout); |
42 | 44 | ||
43 | public slots: | 45 | public slots: |
44 | virtual void slotShowNext(); | 46 | virtual void slotShowNext(); |
45 | virtual void slotShowPrev(); | 47 | virtual void slotShowPrev(); |
46 | virtual void slotShowLast(); | 48 | virtual void slotShowLast(); |
47 | virtual bool slotShowFirst(); | 49 | virtual bool slotShowFirst(); |
50 | virtual void polish(); | ||
48 | 51 | ||
49 | protected: | 52 | protected: |
50 | void resizeEvent( QResizeEvent* ); | 53 | void resizeEvent( QResizeEvent* ); |
51 | 54 | ||
52 | private: | 55 | private: |
53 | void initKeys(); | 56 | void initKeys(); |
54 | QString currentFileName(bool &isDir)const; | 57 | QString currentFileName(bool &isDir)const; |
55 | QString nextFileName(bool &isDir)const; | 58 | QString nextFileName(bool &isDir)const; |
56 | QString prevFileName(bool &isDir)const; | 59 | QString prevFileName(bool &isDir)const; |
57 | void loadViews(); | 60 | void loadViews(); |
58 | void calculateGrid(QResizeEvent*e = 0); | 61 | void calculateGrid(QResizeEvent*e = 0); |
62 | bool m_setDocCalled:1; | ||
59 | 63 | ||
60 | private slots: | 64 | private slots: |
61 | void slotDirUp(); | 65 | void slotDirUp(); |
62 | void slotChangeDir(const QString&); | 66 | void slotChangeDir(const QString&); |
63 | void slotTrash(); | 67 | void slotTrash(); |
64 | void slotViewChanged( int ); | 68 | void slotViewChanged( int ); |
65 | void slotReloadDir(); | 69 | void slotReloadDir(); |
66 | void slotRename(); | 70 | void slotRename(); |
67 | void slotBeam(); | 71 | void slotBeam(); |
68 | void slotBeamDone( Ir* ); | 72 | void slotBeamDone( Ir* ); |
69 | 73 | ||
70 | void slotShowImage(); | 74 | void slotShowImage(); |
71 | void slotShowImage( const QString& ); | 75 | void slotShowImage( const QString& ); |
72 | void slotImageInfo(); | 76 | void slotImageInfo(); |
73 | void slotImageInfo( const QString& ); | 77 | void slotImageInfo( const QString& ); |
74 | void slotStartSlide(); | 78 | void slotStartSlide(); |
75 | 79 | ||
76 | void slotStart(); | 80 | void slotStart(); |
77 | void slotEnd(); | 81 | void slotEnd(); |
78 | 82 | ||
79 | /* for performance reasons make it inline in the future */ | 83 | /* for performance reasons make it inline in the future */ |
80 | void addFolders( const QStringList& ); | 84 | void addFolders( const QStringList& ); |
81 | void addFiles( const QStringList& ); | 85 | void addFiles( const QStringList& ); |
82 | void slotClicked(QIconViewItem* ); | 86 | void slotClicked(QIconViewItem* ); |
83 | void slotRetrun(QIconViewItem* ); | 87 | void slotRetrun(QIconViewItem* ); |
84 | 88 | ||
85 | /**/ | 89 | /**/ |
86 | void slotThumbInfo(const QString&, const QString&); | 90 | void slotThumbInfo(const QString&, const QString&); |
87 | void slotThumbNail(const QString&, const QPixmap&); | 91 | void slotThumbNail(const QString&, const QPixmap&); |
88 | 92 | ||
89 | void slotChangeMode( int ); | 93 | void slotChangeMode( int ); |
90 | private: | 94 | private: |
91 | Opie::Core::OKeyConfigManager *m_viewManager; | 95 | Opie::Core::OKeyConfigManager *m_viewManager; |
92 | Opie::Core::OConfig *m_cfg; | 96 | Opie::Core::OConfig *m_cfg; |
93 | QComboBox* m_views; | 97 | QComboBox* m_views; |
94 | QIconView* m_view; | 98 | QIconView* m_view; |
95 | QString m_path; | 99 | QString m_path; |
96 | bool m_updatet : 1; | 100 | bool m_updatet : 1; |
97 | int m_mode; | 101 | int m_mode; |
98 | bool m_internalReset:1; | 102 | bool m_internalReset:1; |
99 | int m_iconsize; | 103 | int m_iconsize; |
100 | QHBox*m_hbox; | 104 | QHBox*m_hbox; |
101 | QWidget*m_customWidget; | 105 | QWidget*m_customWidget; |
102 | }; | 106 | }; |
103 | 107 | ||
104 | #endif | 108 | #endif |
diff --git a/noncore/graphics/opie-eye/gui/imageview.cpp b/noncore/graphics/opie-eye/gui/imageview.cpp index ebdfc60..ac6474c 100644 --- a/noncore/graphics/opie-eye/gui/imageview.cpp +++ b/noncore/graphics/opie-eye/gui/imageview.cpp | |||
@@ -1,242 +1,255 @@ | |||
1 | #include "imageview.h" | 1 | #include "imageview.h" |
2 | 2 | ||
3 | #include <opie2/odebug.h> | 3 | #include <opie2/odebug.h> |
4 | #include <opie2/oconfig.h> | 4 | #include <opie2/oconfig.h> |
5 | #include <opie2/okeyconfigwidget.h> | 5 | #include <opie2/okeyconfigwidget.h> |
6 | 6 | ||
7 | #include <qpe/resource.h> | 7 | #include <qpe/resource.h> |
8 | #include <qpe/qpeapplication.h> | 8 | #include <qpe/qpeapplication.h> |
9 | #include <qpopupmenu.h> | 9 | #include <qpopupmenu.h> |
10 | #include <qtimer.h> | 10 | #include <qtimer.h> |
11 | #include <qaction.h> | 11 | #include <qaction.h> |
12 | 12 | ||
13 | using namespace Opie::Core; | 13 | using namespace Opie::Core; |
14 | 14 | ||
15 | ImageView::ImageView(Opie::Core::OConfig *cfg, QWidget* parent, const char* name, WFlags fl ) | 15 | ImageView::ImageView(Opie::Core::OConfig *cfg, QWidget* parent, const char* name, WFlags fl ) |
16 | : Opie::MM::OImageScrollView(parent,name,fl) | 16 | : Opie::MM::OImageScrollView(parent,name,fl) |
17 | { | 17 | { |
18 | m_viewManager = 0; | 18 | m_viewManager = 0; |
19 | focus_in_count = 0; | 19 | focus_in_count = 0; |
20 | m_cfg = cfg; | 20 | m_cfg = cfg; |
21 | m_isFullScreen = false; | 21 | m_isFullScreen = false; |
22 | m_ignore_next_in = false; | 22 | m_ignore_next_in = false; |
23 | m_slideTimer = 0; | 23 | m_slideTimer = 0; |
24 | QPEApplication::setStylusOperation(viewport(),QPEApplication::RightOnHold); | 24 | QPEApplication::setStylusOperation(viewport(),QPEApplication::RightOnHold); |
25 | initKeys(); | 25 | initKeys(); |
26 | m_slideValue = 5; | 26 | m_slideValue = 5; |
27 | m_gDisplayType = 0; | 27 | m_gDisplayType = 0; |
28 | m_gPrevNext = 0; | 28 | m_gPrevNext = 0; |
29 | m_hGroup = 0; | 29 | m_hGroup = 0; |
30 | closeIfHide = false; | ||
30 | } | 31 | } |
31 | 32 | ||
32 | void ImageView::setMenuActions(QActionGroup*hGroup,QActionGroup*nextprevGroup, QActionGroup*disptypeGroup) | 33 | void ImageView::setMenuActions(QActionGroup*hGroup,QActionGroup*nextprevGroup, QActionGroup*disptypeGroup) |
33 | { | 34 | { |
34 | m_gDisplayType = disptypeGroup; | 35 | m_gDisplayType = disptypeGroup; |
35 | m_gPrevNext = nextprevGroup; | 36 | m_gPrevNext = nextprevGroup; |
36 | m_hGroup = hGroup; | 37 | m_hGroup = hGroup; |
37 | } | 38 | } |
38 | 39 | ||
39 | ImageView::~ImageView() | 40 | ImageView::~ImageView() |
40 | { | 41 | { |
41 | odebug << "Destructor imageview" << oendl; | 42 | odebug << "Destructor imageview" << oendl; |
42 | delete m_viewManager; | 43 | delete m_viewManager; |
43 | } | 44 | } |
44 | 45 | ||
45 | Opie::Core::OKeyConfigManager* ImageView::manager() | 46 | Opie::Core::OKeyConfigManager* ImageView::manager() |
46 | { | 47 | { |
47 | if (!m_viewManager) { | 48 | if (!m_viewManager) { |
48 | initKeys(); | 49 | initKeys(); |
49 | } | 50 | } |
50 | return m_viewManager; | 51 | return m_viewManager; |
51 | } | 52 | } |
52 | 53 | ||
53 | void ImageView::startSlide(int value) | 54 | void ImageView::startSlide(int value) |
54 | { | 55 | { |
55 | if (!m_slideTimer) { | 56 | if (!m_slideTimer) { |
56 | m_slideTimer = new QTimer(this); | 57 | m_slideTimer = new QTimer(this); |
57 | } | 58 | } |
58 | m_slideValue=value; | 59 | m_slideValue=value; |
59 | connect(m_slideTimer,SIGNAL(timeout()),SLOT(nextSlide())); | 60 | connect(m_slideTimer,SIGNAL(timeout()),SLOT(nextSlide())); |
60 | /* this "+1" is one millisecond. with that we can setup a slideshowvalue | 61 | /* this "+1" is one millisecond. with that we can setup a slideshowvalue |
61 | of 0. eg "as fast as possible". | 62 | of 0. eg "as fast as possible". |
62 | */ | 63 | */ |
63 | m_slideTimer->start(m_slideValue*1000+1,true); | 64 | m_slideTimer->start(m_slideValue*1000+1,true); |
64 | } | 65 | } |
65 | 66 | ||
66 | void ImageView::stopSlide() | 67 | void ImageView::stopSlide() |
67 | { | 68 | { |
68 | if (!m_slideTimer) { | 69 | if (!m_slideTimer) { |
69 | return; | 70 | return; |
70 | } | 71 | } |
71 | m_slideTimer->stop(); | 72 | m_slideTimer->stop(); |
72 | delete m_slideTimer; | 73 | delete m_slideTimer; |
73 | m_slideTimer = 0; | 74 | m_slideTimer = 0; |
74 | } | 75 | } |
75 | 76 | ||
76 | void ImageView::nextSlide() | 77 | void ImageView::nextSlide() |
77 | { | 78 | { |
78 | if (!m_slideTimer) { | 79 | if (!m_slideTimer) { |
79 | return; | 80 | return; |
80 | } | 81 | } |
81 | #if 0 | 82 | #if 0 |
82 | if (isHidden()) { | 83 | if (isHidden()) { |
83 | delete m_slideTimer; | 84 | delete m_slideTimer; |
84 | m_slideTimer = 0; | 85 | m_slideTimer = 0; |
85 | return; | 86 | return; |
86 | } | 87 | } |
87 | #endif | 88 | #endif |
88 | emit dispNext(); | 89 | emit dispNext(); |
89 | m_slideTimer->start(m_slideValue*1000,true); | 90 | m_slideTimer->start(m_slideValue*1000,true); |
90 | } | 91 | } |
91 | void ImageView::initKeys() | 92 | void ImageView::initKeys() |
92 | { | 93 | { |
93 | odebug << "init imageview keys" << oendl; | 94 | odebug << "init imageview keys" << oendl; |
94 | if (!m_cfg) { | 95 | if (!m_cfg) { |
95 | m_cfg = new Opie::Core::OConfig("opie-eye"); | 96 | m_cfg = new Opie::Core::OConfig("opie-eye"); |
96 | m_cfg->setGroup("image_view_keys" ); | 97 | m_cfg->setGroup("image_view_keys" ); |
97 | } | 98 | } |
98 | Opie::Core::OKeyPair::List lst; | 99 | Opie::Core::OKeyPair::List lst; |
99 | lst.append( Opie::Core::OKeyPair::upArrowKey() ); | 100 | lst.append( Opie::Core::OKeyPair::upArrowKey() ); |
100 | lst.append( Opie::Core::OKeyPair::downArrowKey() ); | 101 | lst.append( Opie::Core::OKeyPair::downArrowKey() ); |
101 | lst.append( Opie::Core::OKeyPair::leftArrowKey() ); | 102 | lst.append( Opie::Core::OKeyPair::leftArrowKey() ); |
102 | lst.append( Opie::Core::OKeyPair::rightArrowKey() ); | 103 | lst.append( Opie::Core::OKeyPair::rightArrowKey() ); |
103 | lst.append( Opie::Core::OKeyPair(Qt::Key_Escape,0)); | 104 | lst.append( Opie::Core::OKeyPair(Qt::Key_Escape,0)); |
104 | 105 | ||
105 | m_viewManager = new Opie::Core::OKeyConfigManager(m_cfg, "image_view_keys", | 106 | m_viewManager = new Opie::Core::OKeyConfigManager(m_cfg, "image_view_keys", |
106 | lst, false,this, "image_view_keys" ); | 107 | lst, false,this, "image_view_keys" ); |
107 | 108 | ||
108 | /** | 109 | /** |
109 | * Handle KeyEvents when they're pressed. This avoids problems | 110 | * Handle KeyEvents when they're pressed. This avoids problems |
110 | * with 'double next' on Return. | 111 | * with 'double next' on Return. |
111 | * The Return press would switch to this view and the return | 112 | * The Return press would switch to this view and the return |
112 | * release would emit the dispNext Signal. | 113 | * release would emit the dispNext Signal. |
113 | */ | 114 | */ |
114 | m_viewManager->setEventMask( Opie::Core::OKeyConfigManager::MaskPressed ); | 115 | m_viewManager->setEventMask( Opie::Core::OKeyConfigManager::MaskPressed ); |
115 | 116 | ||
116 | m_viewManager->addKeyConfig( Opie::Core::OKeyConfigItem(tr("View Image Info"), "imageviewinfo", | 117 | m_viewManager->addKeyConfig( Opie::Core::OKeyConfigItem(tr("View Image Info"), "imageviewinfo", |
117 | Resource::loadPixmap("1to1"), ViewInfo, | 118 | Resource::loadPixmap("1to1"), ViewInfo, |
118 | Opie::Core::OKeyPair(Qt::Key_I,0), | 119 | Opie::Core::OKeyPair(Qt::Key_I,0), |
119 | this, SLOT(slotShowImageInfo()))); | 120 | this, SLOT(slotShowImageInfo()))); |
120 | 121 | ||
121 | m_viewManager->addKeyConfig( Opie::Core::OKeyConfigItem(tr("Toggle autorotate"), "imageautorotate", | 122 | m_viewManager->addKeyConfig( Opie::Core::OKeyConfigItem(tr("Toggle autorotate"), "imageautorotate", |
122 | Resource::loadPixmap("rotate"), Autorotate, | 123 | Resource::loadPixmap("rotate"), Autorotate, |
123 | Opie::Core::OKeyPair(Qt::Key_R,0), | 124 | Opie::Core::OKeyPair(Qt::Key_R,0), |
124 | this, SIGNAL(toggleAutorotate()))); | 125 | this, SIGNAL(toggleAutorotate()))); |
125 | m_viewManager->addKeyConfig( Opie::Core::OKeyConfigItem(tr("Toggle autoscale"), "imageautoscale", | 126 | m_viewManager->addKeyConfig( Opie::Core::OKeyConfigItem(tr("Toggle autoscale"), "imageautoscale", |
126 | Resource::loadPixmap("1to1"), Autoscale, | 127 | Resource::loadPixmap("1to1"), Autoscale, |
127 | Opie::Core::OKeyPair(Qt::Key_S,0), | 128 | Opie::Core::OKeyPair(Qt::Key_S,0), |
128 | this, SIGNAL(toggleAutoscale()))); | 129 | this, SIGNAL(toggleAutoscale()))); |
129 | 130 | ||
130 | m_viewManager->addKeyConfig( Opie::Core::OKeyConfigItem(tr("Switch to next image"), "imageshownext", | 131 | m_viewManager->addKeyConfig( Opie::Core::OKeyConfigItem(tr("Switch to next image"), "imageshownext", |
131 | Resource::loadPixmap("forward"), ShowNext, | 132 | Resource::loadPixmap("forward"), ShowNext, |
132 | Opie::Core::OKeyPair(Qt::Key_Return,0), | 133 | Opie::Core::OKeyPair(Qt::Key_Return,0), |
133 | this, SIGNAL(dispNext()))); | 134 | this, SIGNAL(dispNext()))); |
134 | m_viewManager->addKeyConfig( Opie::Core::OKeyConfigItem(tr("Switch to previous image"), "imageshowprev", | 135 | m_viewManager->addKeyConfig( Opie::Core::OKeyConfigItem(tr("Switch to previous image"), "imageshowprev", |
135 | Resource::loadPixmap("back"), ShowPrevious, | 136 | Resource::loadPixmap("back"), ShowPrevious, |
136 | Opie::Core::OKeyPair(Qt::Key_P,0), | 137 | Opie::Core::OKeyPair(Qt::Key_P,0), |
137 | this, SIGNAL(dispPrev()))); | 138 | this, SIGNAL(dispPrev()))); |
138 | m_viewManager->addKeyConfig( Opie::Core::OKeyConfigItem(tr("Toggle fullscreen"), "imagefullscreen", | 139 | m_viewManager->addKeyConfig( Opie::Core::OKeyConfigItem(tr("Toggle fullscreen"), "imagefullscreen", |
139 | Resource::loadPixmap("fullscreen"), FullScreen, | 140 | Resource::loadPixmap("fullscreen"), FullScreen, |
140 | Opie::Core::OKeyPair(Qt::Key_F,0), | 141 | Opie::Core::OKeyPair(Qt::Key_F,0), |
141 | this, SIGNAL(toggleFullScreen()))); | 142 | this, SIGNAL(toggleFullScreen()))); |
142 | m_viewManager->addKeyConfig( Opie::Core::OKeyConfigItem(tr("Toggle thumbnail"), "imagezoomer", | 143 | m_viewManager->addKeyConfig( Opie::Core::OKeyConfigItem(tr("Toggle thumbnail"), "imagezoomer", |
143 | Resource::loadPixmap("mag"), Zoomer, | 144 | Resource::loadPixmap("mag"), Zoomer, |
144 | Opie::Core::OKeyPair(Qt::Key_T,0), | 145 | Opie::Core::OKeyPair(Qt::Key_T,0), |
145 | this, SIGNAL(toggleZoomer()))); | 146 | this, SIGNAL(toggleZoomer()))); |
146 | m_viewManager->handleWidget( this ); | 147 | m_viewManager->handleWidget( this ); |
147 | m_viewManager->load(); | 148 | m_viewManager->load(); |
148 | } | 149 | } |
149 | 150 | ||
150 | void ImageView::keyReleaseEvent(QKeyEvent * e) | 151 | void ImageView::keyReleaseEvent(QKeyEvent * e) |
151 | { | 152 | { |
152 | if (!e || e->state()!=0) { | 153 | if (!e || e->state()!=0) { |
153 | return; | 154 | return; |
154 | } | 155 | } |
155 | if (e->key()==Qt::Key_Escape && fullScreen()) emit hideMe(); | 156 | if (e->key()==Qt::Key_Escape) { |
157 | if (fullScreen()) { | ||
158 | emit hideMe(); | ||
159 | } | ||
160 | if (closeIfHide) { | ||
161 | QTimer::singleShot(0, qApp, SLOT(closeAllWindows())); | ||
162 | } | ||
163 | } | ||
164 | } | ||
165 | |||
166 | void ImageView::setCloseIfHide(bool how) | ||
167 | { | ||
168 | closeIfHide = how; | ||
156 | } | 169 | } |
157 | 170 | ||
158 | void ImageView::slotShowImageInfo() | 171 | void ImageView::slotShowImageInfo() |
159 | { | 172 | { |
160 | emit dispImageInfo(m_lastName); | 173 | emit dispImageInfo(m_lastName); |
161 | } | 174 | } |
162 | 175 | ||
163 | void ImageView::contentsMousePressEvent ( QMouseEvent * e) | 176 | void ImageView::contentsMousePressEvent ( QMouseEvent * e) |
164 | { | 177 | { |
165 | if (e->button()==1) { | 178 | if (e->button()==1) { |
166 | return OImageScrollView::contentsMousePressEvent(e); | 179 | return OImageScrollView::contentsMousePressEvent(e); |
167 | } | 180 | } |
168 | odebug << "Popup " << oendl; | 181 | odebug << "Popup " << oendl; |
169 | QPopupMenu *m = new QPopupMenu(0); | 182 | QPopupMenu *m = new QPopupMenu(0); |
170 | if (!m) return; | 183 | if (!m) return; |
171 | if (m_hGroup) { | 184 | if (m_hGroup) { |
172 | m_hGroup->addTo(m); | 185 | m_hGroup->addTo(m); |
173 | } | 186 | } |
174 | if (fullScreen()) { | 187 | if (fullScreen()) { |
175 | if (m_gPrevNext) { | 188 | if (m_gPrevNext) { |
176 | m->insertSeparator(); | 189 | m->insertSeparator(); |
177 | m_gPrevNext->addTo(m); | 190 | m_gPrevNext->addTo(m); |
178 | } | 191 | } |
179 | if (m_gDisplayType) { | 192 | if (m_gDisplayType) { |
180 | m->insertSeparator(); | 193 | m->insertSeparator(); |
181 | m_gDisplayType->addTo(m); | 194 | m_gDisplayType->addTo(m); |
182 | } | 195 | } |
183 | } | 196 | } |
184 | m->setFocus(); | 197 | m->setFocus(); |
185 | m->exec( QPoint( QCursor::pos().x(), QCursor::pos().y()) ); | 198 | m->exec( QPoint( QCursor::pos().x(), QCursor::pos().y()) ); |
186 | if (m_hGroup) { | 199 | if (m_hGroup) { |
187 | m_hGroup->removeFrom(m); | 200 | m_hGroup->removeFrom(m); |
188 | } | 201 | } |
189 | if (m_gPrevNext) { | 202 | if (m_gPrevNext) { |
190 | m_gPrevNext->removeFrom(m); | 203 | m_gPrevNext->removeFrom(m); |
191 | } | 204 | } |
192 | if (m_gDisplayType) { | 205 | if (m_gDisplayType) { |
193 | m_gDisplayType->removeFrom(m); | 206 | m_gDisplayType->removeFrom(m); |
194 | } | 207 | } |
195 | delete m; | 208 | delete m; |
196 | } | 209 | } |
197 | 210 | ||
198 | void ImageView::setFullScreen(bool how,bool force) | 211 | void ImageView::setFullScreen(bool how,bool force) |
199 | { | 212 | { |
200 | m_isFullScreen = how; | 213 | m_isFullScreen = how; |
201 | if (how) { | 214 | if (how) { |
202 | m_ignore_next_in = true; | 215 | m_ignore_next_in = true; |
203 | setFixedSize(qApp->desktop()->size()); | 216 | setFixedSize(qApp->desktop()->size()); |
204 | if (force) showFullScreen(); | 217 | if (force) showFullScreen(); |
205 | } else { | 218 | } else { |
206 | setMinimumSize(10,10); | 219 | setMinimumSize(10,10); |
207 | } | 220 | } |
208 | } | 221 | } |
209 | 222 | ||
210 | void ImageView::focusInEvent(QFocusEvent *) | 223 | void ImageView::focusInEvent(QFocusEvent *) |
211 | { | 224 | { |
212 | // Always do it here, no matter the size. | 225 | // Always do it here, no matter the size. |
213 | odebug << "Focus in (view)" << oendl; | 226 | odebug << "Focus in (view)" << oendl; |
214 | //if (fullScreen()) parentWidget()->showNormal(); | 227 | //if (fullScreen()) parentWidget()->showNormal(); |
215 | if (m_ignore_next_in){m_ignore_next_in=false;return;} | 228 | if (m_ignore_next_in){m_ignore_next_in=false;return;} |
216 | if (fullScreen()) enableFullscreen(); | 229 | if (fullScreen()) enableFullscreen(); |
217 | } | 230 | } |
218 | 231 | ||
219 | void ImageView::hide() | 232 | void ImageView::hide() |
220 | { | 233 | { |
221 | if (fullScreen()) { | 234 | if (fullScreen()) { |
222 | m_ignore_next_in = true; | 235 | m_ignore_next_in = true; |
223 | showNormal(); | 236 | showNormal(); |
224 | } | 237 | } |
225 | QWidget::hide(); | 238 | QWidget::hide(); |
226 | } | 239 | } |
227 | void ImageView::enableFullscreen() | 240 | void ImageView::enableFullscreen() |
228 | { | 241 | { |
229 | if (!fullScreen()) return; | 242 | if (!fullScreen()) return; |
230 | if (m_ignore_next_in) {m_ignore_next_in = false;return;} | 243 | if (m_ignore_next_in) {m_ignore_next_in = false;return;} |
231 | 244 | ||
232 | setUpdatesEnabled(false); | 245 | setUpdatesEnabled(false); |
233 | // This is needed because showNormal() forcefully changes the window | 246 | // This is needed because showNormal() forcefully changes the window |
234 | // style to WSTyle_TopLevel. | 247 | // style to WSTyle_TopLevel. |
235 | reparent(0, WStyle_Customize | WStyle_NoBorder, QPoint(0,0)); | 248 | reparent(0, WStyle_Customize | WStyle_NoBorder, QPoint(0,0)); |
236 | // Enable fullscreen. | 249 | // Enable fullscreen. |
237 | /* this is the trick - I don't now why, but after a showFullScreen QTE toggles the focus | 250 | /* this is the trick - I don't now why, but after a showFullScreen QTE toggles the focus |
238 | * so we must block it here! */ | 251 | * so we must block it here! */ |
239 | m_ignore_next_in = true; | 252 | m_ignore_next_in = true; |
240 | showFullScreen(); | 253 | showFullScreen(); |
241 | setUpdatesEnabled(true); | 254 | setUpdatesEnabled(true); |
242 | } | 255 | } |
diff --git a/noncore/graphics/opie-eye/gui/imageview.h b/noncore/graphics/opie-eye/gui/imageview.h index 2408211..f1067bb 100644 --- a/noncore/graphics/opie-eye/gui/imageview.h +++ b/noncore/graphics/opie-eye/gui/imageview.h | |||
@@ -1,76 +1,78 @@ | |||
1 | #ifndef _IMAGE_VIEW_H | 1 | #ifndef _IMAGE_VIEW_H |
2 | #define _IMAGE_VIEW_H | 2 | #define _IMAGE_VIEW_H |
3 | 3 | ||
4 | #include <opie2/oimagescrollview.h> | 4 | #include <opie2/oimagescrollview.h> |
5 | 5 | ||
6 | #include <qwidget.h> | 6 | #include <qwidget.h> |
7 | 7 | ||
8 | class QTimer; | 8 | class QTimer; |
9 | class QActionGroup; | 9 | class QActionGroup; |
10 | class QAction; | 10 | class QAction; |
11 | 11 | ||
12 | namespace Opie { | 12 | namespace Opie { |
13 | namespace Core { | 13 | namespace Core { |
14 | class OConfig; | 14 | class OConfig; |
15 | class OKeyConfigManager; | 15 | class OKeyConfigManager; |
16 | } | 16 | } |
17 | } | 17 | } |
18 | 18 | ||
19 | class ImageView:public Opie::MM::OImageScrollView | 19 | class ImageView:public Opie::MM::OImageScrollView |
20 | { | 20 | { |
21 | Q_OBJECT | 21 | Q_OBJECT |
22 | 22 | ||
23 | enum ActionIds { | 23 | enum ActionIds { |
24 | ViewInfo, | 24 | ViewInfo, |
25 | FullScreen, | 25 | FullScreen, |
26 | ShowNext, | 26 | ShowNext, |
27 | ShowPrevious, | 27 | ShowPrevious, |
28 | Zoomer, | 28 | Zoomer, |
29 | Autorotate, | 29 | Autorotate, |
30 | Autoscale | 30 | Autoscale |
31 | }; | 31 | }; |
32 | 32 | ||
33 | public: | 33 | public: |
34 | ImageView(Opie::Core::OConfig *cfg,QWidget* parent,const char* name = 0, WFlags fl = 0 ); | 34 | ImageView(Opie::Core::OConfig *cfg,QWidget* parent,const char* name = 0, WFlags fl = 0 ); |
35 | virtual ~ImageView(); | 35 | virtual ~ImageView(); |
36 | Opie::Core::OKeyConfigManager* manager(); | 36 | Opie::Core::OKeyConfigManager* manager(); |
37 | void setFullScreen(bool how,bool force=true); | 37 | void setFullScreen(bool how,bool force=true); |
38 | bool fullScreen(){return m_isFullScreen;} | 38 | bool fullScreen(){return m_isFullScreen;} |
39 | virtual void enableFullscreen(); | 39 | virtual void enableFullscreen(); |
40 | void stopSlide(); | 40 | void stopSlide(); |
41 | void setMenuActions(QActionGroup*hGroup,QActionGroup*nextprevGroup, QActionGroup*disptypeGroup); | 41 | void setMenuActions(QActionGroup*hGroup,QActionGroup*nextprevGroup, QActionGroup*disptypeGroup); |
42 | void setCloseIfHide(bool); | ||
42 | 43 | ||
43 | signals: | 44 | signals: |
44 | void dispImageInfo(const QString&); | 45 | void dispImageInfo(const QString&); |
45 | void dispNext(); | 46 | void dispNext(); |
46 | void dispPrev(); | 47 | void dispPrev(); |
47 | void toggleFullScreen(); | 48 | void toggleFullScreen(); |
48 | void hideMe(); | 49 | void hideMe(); |
49 | void toggleZoomer(); | 50 | void toggleZoomer(); |
50 | void toggleAutoscale(); | 51 | void toggleAutoscale(); |
51 | void toggleAutorotate(); | 52 | void toggleAutorotate(); |
52 | 53 | ||
53 | protected: | 54 | protected: |
54 | Opie::Core::OConfig * m_cfg; | 55 | Opie::Core::OConfig * m_cfg; |
55 | Opie::Core::OKeyConfigManager*m_viewManager; | 56 | Opie::Core::OKeyConfigManager*m_viewManager; |
56 | void initKeys(); | 57 | void initKeys(); |
57 | bool m_isFullScreen:1; | 58 | bool m_isFullScreen:1; |
58 | bool m_ignore_next_in:1; | 59 | bool m_ignore_next_in:1; |
59 | int focus_in_count; | 60 | int focus_in_count; |
60 | QTimer*m_slideTimer; | 61 | QTimer*m_slideTimer; |
61 | int m_slideValue; | 62 | int m_slideValue; |
62 | virtual void focusInEvent ( QFocusEvent * ); | 63 | virtual void focusInEvent ( QFocusEvent * ); |
63 | QActionGroup *m_gDisplayType,*m_gPrevNext,*m_hGroup; | 64 | QActionGroup *m_gDisplayType,*m_gPrevNext,*m_hGroup; |
65 | bool closeIfHide:1; | ||
64 | 66 | ||
65 | public slots: | 67 | public slots: |
66 | virtual void hide(); | 68 | virtual void hide(); |
67 | virtual void startSlide(int); | 69 | virtual void startSlide(int); |
68 | virtual void nextSlide(); | 70 | virtual void nextSlide(); |
69 | 71 | ||
70 | protected slots: | 72 | protected slots: |
71 | virtual void slotShowImageInfo(); | 73 | virtual void slotShowImageInfo(); |
72 | virtual void keyReleaseEvent(QKeyEvent * e); | 74 | virtual void keyReleaseEvent(QKeyEvent * e); |
73 | virtual void contentsMousePressEvent ( QMouseEvent * e); | 75 | virtual void contentsMousePressEvent ( QMouseEvent * e); |
74 | }; | 76 | }; |
75 | 77 | ||
76 | #endif | 78 | #endif |
diff --git a/noncore/graphics/opie-eye/gui/mainwindow.cpp b/noncore/graphics/opie-eye/gui/mainwindow.cpp index f443ccb..295f93f 100644 --- a/noncore/graphics/opie-eye/gui/mainwindow.cpp +++ b/noncore/graphics/opie-eye/gui/mainwindow.cpp | |||
@@ -1,710 +1,733 @@ | |||
1 | /* | 1 | /* |
2 | * GPLv2 zecke@handhelds.org | 2 | * GPLv2 zecke@handhelds.org |
3 | * No WArranty... | 3 | * No WArranty... |
4 | */ | 4 | */ |
5 | #include "mainwindow.h" | 5 | #include "mainwindow.h" |
6 | #include "imageview.h" | 6 | #include "imageview.h" |
7 | 7 | ||
8 | #include "iconview.h" | 8 | #include "iconview.h" |
9 | #include "filesystem.h" | 9 | #include "filesystem.h" |
10 | #include "imageinfoui.h" | 10 | #include "imageinfoui.h" |
11 | #include "viewmodebutton.h" | 11 | #include "viewmodebutton.h" |
12 | #include "basesetup.h" | 12 | #include "basesetup.h" |
13 | 13 | ||
14 | #include <iface/ifaceinfo.h> | 14 | #include <iface/ifaceinfo.h> |
15 | #include <iface/dirview.h> | 15 | #include <iface/dirview.h> |
16 | 16 | ||
17 | #include <opie2/odebug.h> | 17 | #include <opie2/odebug.h> |
18 | #include <opie2/owidgetstack.h> | 18 | #include <opie2/owidgetstack.h> |
19 | #include <opie2/oapplicationfactory.h> | 19 | #include <opie2/oapplicationfactory.h> |
20 | #include <opie2/otabwidget.h> | 20 | #include <opie2/otabwidget.h> |
21 | #include <opie2/okeyconfigwidget.h> | 21 | #include <opie2/okeyconfigwidget.h> |
22 | 22 | ||
23 | #include <qpe/resource.h> | 23 | #include <qpe/resource.h> |
24 | #include <qpe/config.h> | 24 | #include <qpe/config.h> |
25 | #include <qpe/ir.h> | 25 | #include <qpe/ir.h> |
26 | #include <qpe/storage.h> | 26 | #include <qpe/storage.h> |
27 | #include <qpe/applnk.h> | 27 | #include <qpe/applnk.h> |
28 | 28 | ||
29 | #include <qtoolbar.h> | 29 | #include <qtoolbar.h> |
30 | #include <qtoolbutton.h> | 30 | #include <qtoolbutton.h> |
31 | #include <qlayout.h> | 31 | #include <qlayout.h> |
32 | #include <qdialog.h> | 32 | #include <qdialog.h> |
33 | #include <qmap.h> | 33 | #include <qmap.h> |
34 | #include <qtimer.h> | 34 | #include <qtimer.h> |
35 | #include <qframe.h> | 35 | #include <qframe.h> |
36 | #include <qmenubar.h> | 36 | #include <qmenubar.h> |
37 | #include <qaction.h> | 37 | #include <qaction.h> |
38 | 38 | ||
39 | //OPIE_EXPORT_APP_V2( Opie::Core::OApplicationFactory<PMainWindow>,"Opie Eye" ) | 39 | //OPIE_EXPORT_APP_V2( Opie::Core::OApplicationFactory<PMainWindow>,"Opie Eye" ) |
40 | OPIE_EXPORT_APP( Opie::Core::OApplicationFactory<PMainWindow>) | 40 | OPIE_EXPORT_APP( Opie::Core::OApplicationFactory<PMainWindow>) |
41 | 41 | ||
42 | PMainWindow::PMainWindow(QWidget* wid, const char* name, WFlags style) | 42 | PMainWindow::PMainWindow(QWidget* wid, const char* name, WFlags style) |
43 | : QMainWindow( wid, name, style ), m_info( 0 ), m_disp( 0 ) | 43 | : QMainWindow( wid, name, style ), m_info( 0 ), m_disp( 0 ) |
44 | { | 44 | { |
45 | setCaption( QObject::tr("Opie Eye Caramba" ) ); | 45 | setCaption( QObject::tr("Opie Eye Caramba" ) ); |
46 | m_cfg = new Opie::Core::OConfig("opie-eye"); | 46 | m_cfg = new Opie::Core::OConfig("opie-eye"); |
47 | m_cfg->setGroup("main" ); | 47 | m_cfg->setGroup("main" ); |
48 | readConfig(); | 48 | readConfig(); |
49 | m_setDocCalled = false; | ||
50 | m_polishDone = false; | ||
49 | 51 | ||
50 | m_storage = new StorageInfo(); | 52 | m_storage = new StorageInfo(); |
51 | connect(m_storage, SIGNAL(disksChanged() ), | 53 | connect(m_storage, SIGNAL(disksChanged() ), |
52 | this, SLOT( dirChanged() ) ); | 54 | this, SLOT( dirChanged() ) ); |
53 | 55 | ||
54 | m_stack = new Opie::Ui::OWidgetStack( this ); | 56 | m_stack = new Opie::Ui::OWidgetStack( this ); |
55 | setCentralWidget( m_stack ); | 57 | setCentralWidget( m_stack ); |
56 | 58 | ||
57 | m_view = new PIconView( m_stack, m_cfg ); | 59 | m_view = new PIconView( m_stack, m_cfg ); |
58 | m_stack->addWidget( m_view, IconView ); | 60 | m_stack->addWidget( m_view, IconView ); |
59 | m_stack->raiseWidget( IconView ); | 61 | m_stack->raiseWidget( IconView ); |
60 | 62 | ||
61 | connect(m_view, SIGNAL(sig_display(const QString&)), | 63 | connect(m_view, SIGNAL(sig_display(const QString&)), |
62 | this, SLOT(slotDisplay(const QString&))); | 64 | this, SLOT(slotDisplay(const QString&))); |
63 | connect(m_view, SIGNAL(sig_showInfo(const QString&)), | 65 | connect(m_view, SIGNAL(sig_showInfo(const QString&)), |
64 | this, SLOT(slotShowInfo(const QString&)) ); | 66 | this, SLOT(slotShowInfo(const QString&)) ); |
65 | connect(this,SIGNAL(changeListMode(int)),m_view,SLOT(slotChangeMode(int))); | 67 | connect(this,SIGNAL(changeListMode(int)),m_view,SLOT(slotChangeMode(int))); |
66 | 68 | ||
67 | m_stack->forceMode(Opie::Ui::OWidgetStack::NoForce); | 69 | m_stack->forceMode(Opie::Ui::OWidgetStack::NoForce); |
68 | 70 | ||
69 | listviewMenu = 0; | 71 | listviewMenu = 0; |
70 | /* setup menu and toolbar */ | 72 | /* setup menu and toolbar */ |
71 | setupActions(); | 73 | setupActions(); |
72 | setupToolbar(); | 74 | setupToolbar(); |
73 | setupMenu(); | 75 | setupMenu(); |
74 | m_aHideToolbar->setOn(m_cfg->readBoolEntry("showtoolbar",true)); | 76 | m_aHideToolbar->setOn(m_cfg->readBoolEntry("showtoolbar",true)); |
75 | m_aAutoRotate->setEnabled(!m_aUnscaled->isOn()); | 77 | m_aAutoRotate->setEnabled(!m_aUnscaled->isOn()); |
76 | odebug << "mainwindow constructor done" << oendl; | 78 | odebug << "mainwindow constructor done" << oendl; |
77 | } | 79 | } |
78 | 80 | ||
79 | PMainWindow::~PMainWindow() { | 81 | PMainWindow::~PMainWindow() { |
80 | } | 82 | } |
81 | 83 | ||
82 | void PMainWindow::slotToggleZoomer() | 84 | void PMainWindow::slotToggleZoomer() |
83 | { | 85 | { |
84 | m_aZoomer->setOn(!m_aZoomer->isOn()); | 86 | m_aZoomer->setOn(!m_aZoomer->isOn()); |
85 | } | 87 | } |
86 | 88 | ||
87 | void PMainWindow::slotZoomerToggled(bool how) | 89 | void PMainWindow::slotZoomerToggled(bool how) |
88 | { | 90 | { |
89 | if (m_disp) { | 91 | if (m_disp) { |
90 | m_disp->setShowZoomer(how); | 92 | m_disp->setShowZoomer(how); |
91 | } | 93 | } |
92 | if (autoSave) { | 94 | if (autoSave) { |
93 | m_cfg->writeEntry("zoomeron",how); | 95 | m_cfg->writeEntry("zoomeron",how); |
94 | } | 96 | } |
95 | } | 97 | } |
96 | 98 | ||
97 | void PMainWindow::slotToggleAutorotate() | 99 | void PMainWindow::slotToggleAutorotate() |
98 | { | 100 | { |
99 | if (!m_aAutoRotate->isEnabled()) return; | 101 | if (!m_aAutoRotate->isEnabled()) return; |
100 | m_aAutoRotate->setOn(!m_aAutoRotate->isOn()); | 102 | m_aAutoRotate->setOn(!m_aAutoRotate->isOn()); |
101 | } | 103 | } |
102 | 104 | ||
103 | void PMainWindow::slotToggleAutoscale() | 105 | void PMainWindow::slotToggleAutoscale() |
104 | { | 106 | { |
105 | m_aUnscaled->setOn(!m_aUnscaled->isOn()); | 107 | m_aUnscaled->setOn(!m_aUnscaled->isOn()); |
106 | } | 108 | } |
107 | 109 | ||
108 | void PMainWindow::slotRotateToggled(bool how) | 110 | void PMainWindow::slotRotateToggled(bool how) |
109 | { | 111 | { |
110 | if (autoSave) { | 112 | if (autoSave) { |
111 | m_cfg->writeEntry("autorotate",how); | 113 | m_cfg->writeEntry("autorotate",how); |
112 | } | 114 | } |
113 | if (m_disp) { | 115 | if (m_disp) { |
114 | m_disp->setAutoScaleRotate(!m_aUnscaled->isOn(),how); | 116 | m_disp->setAutoScaleRotate(!m_aUnscaled->isOn(),how); |
115 | } | 117 | } |
116 | } | 118 | } |
117 | 119 | ||
118 | void PMainWindow::slotScaleToggled(bool how) | 120 | void PMainWindow::slotScaleToggled(bool how) |
119 | { | 121 | { |
120 | if (autoSave) { | 122 | if (autoSave) { |
121 | m_cfg->writeEntry("unscaled",how); | 123 | m_cfg->writeEntry("unscaled",how); |
122 | } | 124 | } |
123 | odebug << "Unscaled: " << m_aUnscaled->isOn() << oendl; | 125 | odebug << "Unscaled: " << m_aUnscaled->isOn() << oendl; |
124 | odebug << "How: " << how << oendl; | 126 | odebug << "How: " << how << oendl; |
125 | if (how) { | 127 | if (how) { |
126 | m_aAutoRotate->setOn(false); | 128 | m_aAutoRotate->setOn(false); |
127 | } | 129 | } |
128 | if (m_disp) { | 130 | if (m_disp) { |
129 | m_disp->setAutoScaleRotate(!m_aUnscaled->isOn(),m_aAutoRotate->isOn()); | 131 | m_disp->setAutoScaleRotate(!m_aUnscaled->isOn(),m_aAutoRotate->isOn()); |
130 | } | 132 | } |
131 | m_aAutoRotate->setEnabled(!how); | 133 | m_aAutoRotate->setEnabled(!how); |
132 | odebug << "Autorotate: " << m_aAutoRotate->isOn() << oendl; | 134 | odebug << "Autorotate: " << m_aAutoRotate->isOn() << oendl; |
133 | } | 135 | } |
134 | 136 | ||
135 | void PMainWindow::slotConfig() { | 137 | void PMainWindow::slotConfig() { |
136 | /* | 138 | /* |
137 | * have a tab with the possible views | 139 | * have a tab with the possible views |
138 | * a tab for globals image cache size.. scaled loading | 140 | * a tab for globals image cache size.. scaled loading |
139 | * and one tab for the KeyConfigs | 141 | * and one tab for the KeyConfigs |
140 | */ | 142 | */ |
141 | QDialog dlg(this, 0, true); | 143 | QDialog dlg(this, 0, true); |
142 | dlg.setCaption( tr("Opie Eye - Config" ) ); | 144 | dlg.setCaption( tr("Opie Eye - Config" ) ); |
143 | 145 | ||
144 | QHBoxLayout *lay = new QHBoxLayout(&dlg); | 146 | QHBoxLayout *lay = new QHBoxLayout(&dlg); |
145 | Opie::Ui::OTabWidget *wid = new Opie::Ui::OTabWidget(&dlg ); | 147 | Opie::Ui::OTabWidget *wid = new Opie::Ui::OTabWidget(&dlg ); |
146 | lay->addWidget( wid ); | 148 | lay->addWidget( wid ); |
147 | 149 | ||
148 | BaseSetup*bSetup = new BaseSetup(m_cfg,wid); | 150 | BaseSetup*bSetup = new BaseSetup(m_cfg,wid); |
149 | wid->addTab(bSetup,"SettingsIcon","Basics setup"); | 151 | wid->addTab(bSetup,"SettingsIcon","Basics setup"); |
150 | 152 | ||
151 | ViewMap *vM = viewMap(); | 153 | ViewMap *vM = viewMap(); |
152 | ViewMap::Iterator _it = vM->begin(); | 154 | ViewMap::Iterator _it = vM->begin(); |
153 | QMap<PDirView*, QWidget*> lst; | 155 | QMap<PDirView*, QWidget*> lst; |
154 | 156 | ||
155 | for( ; _it != vM->end(); ++_it ) { | 157 | for( ; _it != vM->end(); ++_it ) { |
156 | PDirView *view = (_it.data())(*m_cfg); | 158 | PDirView *view = (_it.data())(*m_cfg); |
157 | PInterfaceInfo *inf = view->interfaceInfo(); | 159 | PInterfaceInfo *inf = view->interfaceInfo(); |
158 | QWidget *_wid = inf->configWidget( *m_cfg ); | 160 | QWidget *_wid = inf->configWidget( *m_cfg ); |
159 | if (!_wid) continue; | 161 | if (!_wid) continue; |
160 | _wid->reparent(wid, QPoint() ); | 162 | _wid->reparent(wid, QPoint() ); |
161 | lst.insert( view, _wid ); | 163 | lst.insert( view, _wid ); |
162 | wid->addTab( _wid, "fileopen", inf->name() ); | 164 | wid->addTab( _wid, "fileopen", inf->name() ); |
163 | } | 165 | } |
164 | 166 | ||
165 | /* | 167 | /* |
166 | * Add the KeyConfigWidget | 168 | * Add the KeyConfigWidget |
167 | */ | 169 | */ |
168 | Opie::Ui::OKeyConfigWidget* keyWid = new Opie::Ui::OKeyConfigWidget( wid, "key config" ); | 170 | Opie::Ui::OKeyConfigWidget* keyWid = new Opie::Ui::OKeyConfigWidget( wid, "key config" ); |
169 | keyWid->setChangeMode( Opie::Ui::OKeyConfigWidget::Queue ); | 171 | keyWid->setChangeMode( Opie::Ui::OKeyConfigWidget::Queue ); |
170 | keyWid->insert( tr("Browser Keyboard Actions"), m_view->manager() ); | 172 | keyWid->insert( tr("Browser Keyboard Actions"), m_view->manager() ); |
171 | QWidget*w = m_stack->visibleWidget(); | 173 | QWidget*w = m_stack->visibleWidget(); |
172 | 174 | ||
173 | bool reminfo = false; | 175 | bool reminfo = false; |
174 | if ( !m_info ) { | 176 | if ( !m_info ) { |
175 | reminfo = true; | 177 | reminfo = true; |
176 | initInfo(); | 178 | initInfo(); |
177 | m_info->hide(); | 179 | m_info->hide(); |
178 | } | 180 | } |
179 | keyWid->insert( tr("Imageinfo Keyboard Actions"), m_info->manager() ); | 181 | keyWid->insert( tr("Imageinfo Keyboard Actions"), m_info->manager() ); |
180 | 182 | ||
181 | bool remdisp = false; | 183 | bool remdisp = false; |
182 | if ( !m_disp ) { | 184 | if ( !m_disp ) { |
183 | remdisp = true; | 185 | remdisp = true; |
184 | initDisp(); | 186 | initDisp(); |
185 | m_disp->hide(); | 187 | m_disp->hide(); |
186 | } | 188 | } |
187 | keyWid->insert( tr("Imageview Keyboard Actions"), m_disp->manager() ); | 189 | keyWid->insert( tr("Imageview Keyboard Actions"), m_disp->manager() ); |
188 | 190 | ||
189 | keyWid->load(); | 191 | keyWid->load(); |
190 | wid->addTab( keyWid, QString::fromLatin1("AppsIcon" ), tr("Keyboard Configuration") ); | 192 | wid->addTab( keyWid, QString::fromLatin1("AppsIcon" ), tr("Keyboard Configuration") ); |
191 | wid->setCurrentTab(0); | 193 | wid->setCurrentTab(0); |
192 | bool act = ( QPEApplication::execDialog( &dlg ) == QDialog::Accepted ); | 194 | bool act = ( QPEApplication::execDialog( &dlg ) == QDialog::Accepted ); |
193 | 195 | ||
194 | /* | 196 | /* |
195 | * clean up | 197 | * clean up |
196 | *apply changes | 198 | *apply changes |
197 | */ | 199 | */ |
198 | 200 | ||
199 | QMap<PDirView*, QWidget*>::Iterator it; | 201 | QMap<PDirView*, QWidget*>::Iterator it; |
200 | for ( it = lst.begin(); it != lst.end(); ++it ) { | 202 | for ( it = lst.begin(); it != lst.end(); ++it ) { |
201 | if ( act ) | 203 | if ( act ) |
202 | it.key()->interfaceInfo()->writeConfig(it.data(), *m_cfg); | 204 | it.key()->interfaceInfo()->writeConfig(it.data(), *m_cfg); |
203 | delete it.key(); | 205 | delete it.key(); |
204 | } | 206 | } |
205 | 207 | ||
206 | 208 | ||
207 | if ( act ) { | 209 | if ( act ) { |
208 | keyWid->save(); | 210 | keyWid->save(); |
209 | m_disp->manager()->save(); | 211 | m_disp->manager()->save(); |
210 | m_info->manager()->save(); | 212 | m_info->manager()->save(); |
211 | m_view->manager()->save(); | 213 | m_view->manager()->save(); |
212 | bSetup->save_values(); | 214 | bSetup->save_values(); |
213 | m_view->resetView(); | 215 | m_view->resetView(); |
214 | readConfig(); | 216 | readConfig(); |
215 | } | 217 | } |
216 | delete keyWid; | 218 | delete keyWid; |
217 | 219 | ||
218 | m_stack->raiseWidget(w); | 220 | m_stack->raiseWidget(w); |
219 | if (remdisp) { | 221 | if (remdisp) { |
220 | m_disp->hide(); | 222 | m_disp->hide(); |
221 | } | 223 | } |
222 | if (reminfo) { | 224 | if (reminfo) { |
223 | m_info->hide(); | 225 | m_info->hide(); |
224 | } | 226 | } |
225 | } | 227 | } |
226 | 228 | ||
227 | /* | 229 | /* |
228 | * create a new image info component | 230 | * create a new image info component |
229 | * and detach the current one | 231 | * and detach the current one |
230 | * we will make the other delete on exit | 232 | * we will make the other delete on exit |
231 | */ | 233 | */ |
232 | template<class T> | 234 | template<class T> |
233 | void PMainWindow::initT( const char* name, T** ptr, int id) { | 235 | void PMainWindow::initT( const char* name, T** ptr, int id) { |
234 | if ( *ptr ) { | 236 | if ( *ptr ) { |
235 | (*ptr)->disconnect(this, SLOT(slotReturn())); | 237 | (*ptr)->disconnect(this, SLOT(slotReturn())); |
236 | (*ptr)->setDestructiveClose(); | 238 | (*ptr)->setDestructiveClose(); |
237 | m_stack->removeWidget( *ptr ); | 239 | m_stack->removeWidget( *ptr ); |
238 | } | 240 | } |
239 | *ptr = new T(m_cfg, m_stack, name ); | 241 | *ptr = new T(m_cfg, m_stack, name ); |
240 | m_stack->addWidget( *ptr, id ); | 242 | m_stack->addWidget( *ptr, id ); |
241 | 243 | ||
242 | connect(*ptr, SIGNAL(sig_return()), | 244 | connect(*ptr, SIGNAL(sig_return()), |
243 | this,SLOT(slotReturn())); | 245 | this,SLOT(slotReturn())); |
244 | 246 | ||
245 | } | 247 | } |
246 | 248 | ||
247 | void PMainWindow::initInfo() { | 249 | void PMainWindow::initInfo() { |
248 | initT<imageinfo>( "Image Info", &m_info, ImageInfo ); | 250 | initT<imageinfo>( "Image Info", &m_info, ImageInfo ); |
249 | connect(m_info,SIGNAL(dispImage(const QString&)),this,SLOT(slotDisplay(const QString&))); | 251 | connect(m_info,SIGNAL(dispImage(const QString&)),this,SLOT(slotDisplay(const QString&))); |
250 | } | 252 | } |
251 | 253 | ||
252 | void PMainWindow::initDisp() { | 254 | void PMainWindow::initDisp() { |
253 | initT<ImageView>( "Image ScrollView", &m_disp, ImageDisplay ); | 255 | initT<ImageView>( "Image ScrollView", &m_disp, ImageDisplay ); |
254 | if (m_disp) { | 256 | if (m_disp) { |
255 | if (m_stack->mode() != Opie::Ui::OWidgetStack::SmallScreen) { | 257 | if (m_stack->mode() != Opie::Ui::OWidgetStack::SmallScreen) { |
256 | m_disp->setMinimumSize(QApplication::desktop()->size()/2); | 258 | m_disp->setMinimumSize(QApplication::desktop()->size()/2); |
257 | } | 259 | } |
258 | m_disp->setMenuActions(m_hGroup,m_gPrevNext,m_gDisplayType); | 260 | m_disp->setMenuActions(m_hGroup,m_gPrevNext,m_gDisplayType); |
259 | m_disp->setAutoScale(!m_aUnscaled->isOn()); | 261 | m_disp->setAutoScale(!m_aUnscaled->isOn()); |
260 | m_disp->setAutoRotate(m_aAutoRotate->isOn()); | 262 | m_disp->setAutoRotate(m_aAutoRotate->isOn()); |
261 | m_disp->setShowZoomer(m_aZoomer->isOn()); | 263 | m_disp->setShowZoomer(m_aZoomer->isOn()); |
262 | m_disp->setBackgroundColor(white); | 264 | m_disp->setBackgroundColor(white); |
263 | connect(m_disp,SIGNAL(dispImageInfo(const QString&)),this,SLOT(slotShowInfo(const QString&))); | 265 | connect(m_disp,SIGNAL(dispImageInfo(const QString&)),this,SLOT(slotShowInfo(const QString&))); |
264 | connect(m_disp,SIGNAL(dispNext()),m_view,SLOT(slotShowNext())); | 266 | connect(m_disp,SIGNAL(dispNext()),m_view,SLOT(slotShowNext())); |
265 | connect(m_disp,SIGNAL(dispPrev()),m_view,SLOT(slotShowPrev())); | 267 | connect(m_disp,SIGNAL(dispPrev()),m_view,SLOT(slotShowPrev())); |
266 | connect(m_disp,SIGNAL(toggleFullScreen()),this,SLOT(slotToggleFullScreen())); | 268 | connect(m_disp,SIGNAL(toggleFullScreen()),this,SLOT(slotToggleFullScreen())); |
267 | connect(m_disp,SIGNAL(hideMe()),this,SLOT(raiseIconView())); | 269 | connect(m_disp,SIGNAL(hideMe()),this,SLOT(raiseIconView())); |
268 | connect(m_disp,SIGNAL(toggleZoomer()),this,SLOT(slotToggleZoomer())); | 270 | connect(m_disp,SIGNAL(toggleZoomer()),this,SLOT(slotToggleZoomer())); |
269 | connect(m_disp,SIGNAL(toggleAutoscale()),this,SLOT(slotToggleAutoscale())); | 271 | connect(m_disp,SIGNAL(toggleAutoscale()),this,SLOT(slotToggleAutoscale())); |
270 | connect(m_disp,SIGNAL(toggleAutorotate()),this,SLOT(slotToggleAutorotate())); | 272 | connect(m_disp,SIGNAL(toggleAutorotate()),this,SLOT(slotToggleAutorotate())); |
271 | connect(m_view,SIGNAL(sig_startslide(int)),m_disp,SLOT(startSlide(int))); | 273 | connect(m_view,SIGNAL(sig_startslide(int)),m_disp,SLOT(startSlide(int))); |
272 | slotFullScreenToggled(m_aFullScreen->isOn()); | 274 | slotFullScreenToggled(m_aFullScreen->isOn()); |
273 | } | 275 | } |
274 | } | 276 | } |
275 | 277 | ||
276 | void PMainWindow::slotToggleFullScreen() | 278 | void PMainWindow::slotToggleFullScreen() |
277 | { | 279 | { |
278 | bool current = !m_aFullScreen->isOn(); | 280 | bool current = !m_aFullScreen->isOn(); |
279 | m_aFullScreen->setOn(current); | 281 | m_aFullScreen->setOn(current); |
280 | } | 282 | } |
281 | 283 | ||
282 | void PMainWindow::slotFullScreenButton(bool current) | 284 | void PMainWindow::slotFullScreenButton(bool current) |
283 | { | 285 | { |
284 | if (autoSave) { | 286 | if (autoSave) { |
285 | m_cfg->writeEntry("fullscreen",current); | 287 | m_cfg->writeEntry("fullscreen",current); |
286 | } | 288 | } |
287 | if (!m_disp) return; | 289 | if (!m_disp) return; |
288 | if (m_disp->isVisible()) { | 290 | if (m_disp->isVisible()) { |
289 | setupViewWindow(current, true); | 291 | setupViewWindow(current, true); |
290 | } | 292 | } |
291 | } | 293 | } |
292 | 294 | ||
293 | void PMainWindow::setupViewWindow(bool current, bool forceDisplay) | 295 | void PMainWindow::setupViewWindow(bool current, bool forceDisplay) |
294 | { | 296 | { |
295 | if (!m_disp) return; | 297 | if (!m_disp) return; |
296 | if (current) { | 298 | if (current) { |
297 | m_disp->setBackgroundColor(black); | 299 | m_disp->setBackgroundColor(black); |
298 | m_disp->reparent(0, WStyle_Customize | WStyle_NoBorder, QPoint(0,0)); | 300 | m_disp->reparent(0, WStyle_Customize | WStyle_NoBorder, QPoint(0,0)); |
299 | m_disp->setVScrollBarMode(QScrollView::AlwaysOff); | 301 | m_disp->setVScrollBarMode(QScrollView::AlwaysOff); |
300 | m_disp->setHScrollBarMode(QScrollView::AlwaysOff); | 302 | m_disp->setHScrollBarMode(QScrollView::AlwaysOff); |
301 | m_disp->resize(qApp->desktop()->width(), qApp->desktop()->height()); | 303 | m_disp->resize(qApp->desktop()->width(), qApp->desktop()->height()); |
302 | } else { | 304 | } else { |
303 | setUpdatesEnabled(false); | 305 | setUpdatesEnabled(false); |
304 | if (m_stack->mode() != Opie::Ui::OWidgetStack::SmallScreen) { | 306 | if (m_stack->mode() != Opie::Ui::OWidgetStack::SmallScreen) { |
305 | m_disp->setMinimumSize(QApplication::desktop()->size()/2); | 307 | m_disp->setMinimumSize(QApplication::desktop()->size()/2); |
306 | } else { | 308 | } else { |
307 | m_disp->setMinimumSize(10,10); | 309 | m_disp->setMinimumSize(10,10); |
308 | } | 310 | } |
309 | if (m_stack->mode() != Opie::Ui::OWidgetStack::SmallScreen) { | 311 | if (m_stack->mode() != Opie::Ui::OWidgetStack::SmallScreen) { |
310 | m_disp->reparent(0,QPoint(50,50)); | 312 | m_disp->reparent(0,QPoint(50,50)); |
311 | } else { | 313 | } else { |
312 | m_disp->reparent(0,QPoint(0,0)); | 314 | m_disp->reparent(0,QPoint(0,0)); |
313 | } | 315 | } |
314 | m_disp->setBackgroundColor(white); | 316 | m_disp->setBackgroundColor(white); |
315 | m_stack->addWidget(m_disp,ImageDisplay); | 317 | m_stack->addWidget(m_disp,ImageDisplay); |
316 | m_disp->setVScrollBarMode(QScrollView::Auto); | 318 | m_disp->setVScrollBarMode(QScrollView::Auto); |
317 | m_disp->setHScrollBarMode(QScrollView::Auto); | 319 | m_disp->setHScrollBarMode(QScrollView::Auto); |
318 | if (forceDisplay || m_disp->isVisible()) | 320 | if (forceDisplay || m_disp->isVisible()) |
319 | m_stack->raiseWidget(m_disp); | 321 | m_stack->raiseWidget(m_disp); |
320 | if (m_stack->mode() != Opie::Ui::OWidgetStack::SmallScreen) { | 322 | if (m_stack->mode() != Opie::Ui::OWidgetStack::SmallScreen) { |
321 | m_disp->resize(m_disp->minimumSize()); | 323 | m_disp->resize(m_disp->minimumSize()); |
322 | } | 324 | } |
323 | setUpdatesEnabled(true); | 325 | setUpdatesEnabled(true); |
324 | } | 326 | } |
325 | m_disp->setFullScreen(current,forceDisplay); | 327 | m_disp->setFullScreen(current,forceDisplay); |
326 | } | 328 | } |
327 | 329 | ||
328 | void PMainWindow::slotFullScreenToggled(bool current) | 330 | void PMainWindow::slotFullScreenToggled(bool current) |
329 | { | 331 | { |
330 | setupViewWindow(current,true); | 332 | setupViewWindow(current,true); |
331 | } | 333 | } |
332 | 334 | ||
333 | /** | 335 | /** |
334 | * With big Screen the plan could be to 'detach' the image | 336 | * With big Screen the plan could be to 'detach' the image |
335 | * window if visible and to create a ne wone | 337 | * window if visible and to create a ne wone |
336 | * init* already supports it but I make no use of it for | 338 | * init* already supports it but I make no use of it for |
337 | * now. We set filename and raise | 339 | * now. We set filename and raise |
338 | * | 340 | * |
339 | * ### FIXME and talk to alwin | 341 | * ### FIXME and talk to alwin |
340 | */ | 342 | */ |
341 | void PMainWindow::slotShowInfo( const QString& inf ) { | 343 | void PMainWindow::slotShowInfo( const QString& inf ) { |
342 | if (m_disp && m_disp->fullScreen() && m_disp->isVisible()) { | 344 | if (m_disp && m_disp->fullScreen() && m_disp->isVisible()) { |
343 | return; | 345 | return; |
344 | } | 346 | } |
345 | if ( !m_info ) { | 347 | if ( !m_info ) { |
346 | initInfo(); | 348 | initInfo(); |
347 | } | 349 | } |
348 | m_info->setPath( inf ); | 350 | m_info->setPath( inf ); |
349 | if (m_stack->mode() == Opie::Ui::OWidgetStack::SmallScreen) { | 351 | if (m_stack->mode() == Opie::Ui::OWidgetStack::SmallScreen) { |
350 | m_aNext->removeFrom(toolBar); | 352 | m_aNext->removeFrom(toolBar); |
351 | m_aPrevious->removeFrom(toolBar); | 353 | m_aPrevious->removeFrom(toolBar); |
352 | m_aNext->setEnabled(false); | 354 | m_aNext->setEnabled(false); |
353 | m_aPrevious->setEnabled(false); | 355 | m_aPrevious->setEnabled(false); |
354 | m_aDirUp->setEnabled(false); | 356 | m_aDirUp->setEnabled(false); |
355 | m_aShowInfo->setEnabled(false); | 357 | m_aShowInfo->setEnabled(false); |
356 | m_aViewfile->setEnabled(true); | 358 | m_aViewfile->setEnabled(true); |
357 | m_aStartSlide->setEnabled(false); | 359 | m_aStartSlide->setEnabled(false); |
358 | fsButton->hide(); | 360 | fsButton->hide(); |
359 | } | 361 | } |
360 | m_stack->raiseWidget( ImageInfo ); | 362 | m_stack->raiseWidget( ImageInfo ); |
361 | } | 363 | } |
362 | 364 | ||
363 | void PMainWindow::slotDisplay( const QString& inf ) { | 365 | void PMainWindow::slotDisplay( const QString& inf ) { |
364 | bool nwindow = false; | 366 | bool nwindow = false; |
365 | if ( !m_disp ) { | 367 | if ( !m_disp ) { |
366 | nwindow = true; | 368 | nwindow = true; |
367 | initDisp(); | 369 | initDisp(); |
368 | } | 370 | } |
369 | m_disp->setImage( inf ); | 371 | m_disp->setImage( inf ); |
370 | if (m_stack->mode() == Opie::Ui::OWidgetStack::SmallScreen) { | 372 | if (m_stack->mode() == Opie::Ui::OWidgetStack::SmallScreen) { |
371 | if (m_gPrevNext->isEnabled()==false) { | 373 | if (m_gPrevNext->isEnabled()==false) { |
372 | m_gPrevNext->addTo(toolBar); | 374 | m_gPrevNext->addTo(toolBar); |
373 | m_gPrevNext->setEnabled(true); | 375 | m_gPrevNext->setEnabled(true); |
374 | 376 | ||
375 | m_aDirUp->setEnabled(false); | 377 | m_aDirUp->setEnabled(false); |
376 | m_aShowInfo->setEnabled(true); | 378 | m_aShowInfo->setEnabled(true); |
377 | m_aViewfile->setEnabled(false); | 379 | m_aViewfile->setEnabled(false); |
378 | m_aStartSlide->setEnabled(false); | 380 | m_aStartSlide->setEnabled(false); |
379 | fsButton->hide(); | 381 | fsButton->hide(); |
380 | } | 382 | } |
381 | } | 383 | } |
382 | if (!nwindow && m_disp->fullScreen()!=m_aFullScreen->isOn()) { | 384 | if (!nwindow && m_disp->fullScreen()!=m_aFullScreen->isOn()) { |
383 | slotFullScreenToggled(m_aFullScreen->isOn()); | 385 | slotFullScreenToggled(m_aFullScreen->isOn()); |
384 | } | 386 | } |
385 | if (m_disp->fullScreen()) { | 387 | if (m_disp->fullScreen()) { |
386 | qwsDisplay()->requestFocus( m_disp->winId(), TRUE); | 388 | qwsDisplay()->requestFocus( m_disp->winId(), TRUE); |
387 | } else { | 389 | } else { |
388 | m_stack->raiseWidget( ImageDisplay ); | 390 | m_stack->raiseWidget( ImageDisplay ); |
389 | } | 391 | } |
390 | } | 392 | } |
391 | 393 | ||
392 | void PMainWindow::raiseIconView() { | 394 | void PMainWindow::raiseIconView() { |
393 | setUpdatesEnabled(false); | 395 | setUpdatesEnabled(false); |
394 | if (m_stack->mode() == Opie::Ui::OWidgetStack::SmallScreen) { | 396 | if (m_stack->mode() == Opie::Ui::OWidgetStack::SmallScreen) { |
395 | m_gPrevNext->removeFrom(toolBar); | 397 | m_gPrevNext->removeFrom(toolBar); |
396 | m_gPrevNext->setEnabled(false); | 398 | m_gPrevNext->setEnabled(false); |
397 | m_aDirUp->setEnabled(true); | 399 | m_aDirUp->setEnabled(true); |
398 | m_aShowInfo->setEnabled(true); | 400 | m_aShowInfo->setEnabled(true); |
399 | m_aViewfile->setEnabled(true); | 401 | m_aViewfile->setEnabled(true); |
400 | m_aStartSlide->setEnabled(true); | 402 | m_aStartSlide->setEnabled(true); |
401 | fsButton->show(); | 403 | fsButton->show(); |
402 | } | 404 | } |
403 | if (m_disp && m_disp->fullScreen() && m_disp->isVisible()) { | 405 | if (m_disp && m_disp->fullScreen() && m_disp->isVisible()) { |
404 | m_disp->stopSlide(); | 406 | m_disp->stopSlide(); |
405 | m_disp->hide(); | 407 | m_disp->hide(); |
406 | } | 408 | } |
407 | m_stack->raiseWidget( IconView ); | 409 | m_stack->raiseWidget( IconView ); |
408 | setUpdatesEnabled(true); | 410 | setUpdatesEnabled(true); |
409 | repaint(); | 411 | repaint(); |
410 | } | 412 | } |
411 | 413 | ||
412 | void PMainWindow::slotReturn() { | 414 | void PMainWindow::slotReturn() { |
413 | raiseIconView(); | 415 | raiseIconView(); |
414 | } | 416 | } |
415 | 417 | ||
416 | 418 | ||
417 | void PMainWindow::closeEvent( QCloseEvent* ev ) { | 419 | void PMainWindow::closeEvent( QCloseEvent* ev ) { |
418 | /* | 420 | /* |
419 | * return from view | 421 | * return from view |
420 | * or properly quit | 422 | * or properly quit |
421 | */ | 423 | */ |
422 | if ( m_stack->visibleWidget() == m_info || | 424 | if (!m_setDocCalled) { |
423 | m_stack->visibleWidget() == m_disp ) { | 425 | if ( m_stack->visibleWidget() == m_info || |
424 | ev->ignore(); | 426 | m_stack->visibleWidget() == m_disp ) { |
425 | raiseIconView(); | 427 | ev->ignore(); |
426 | return; | 428 | raiseIconView(); |
429 | return; | ||
430 | } | ||
427 | } | 431 | } |
428 | if (m_disp && m_disp->fullScreen()) { | 432 | if (m_disp && m_disp->fullScreen()) { |
429 | /* otherwise opie-eye crashes in bigscreen mode! */ | 433 | /* otherwise opie-eye crashes in bigscreen mode! */ |
430 | m_disp->reparent(0,QPoint(0,0)); | 434 | m_disp->reparent(0,QPoint(0,0)); |
431 | m_stack->addWidget(m_disp,ImageDisplay); | 435 | m_stack->addWidget(m_disp,ImageDisplay); |
432 | } | 436 | } |
433 | ev->accept(); | 437 | ev->accept(); |
434 | QTimer::singleShot(0, qApp, SLOT(closeAllWindows())); | 438 | QTimer::singleShot(0, qApp, SLOT(closeAllWindows())); |
435 | } | 439 | } |
436 | 440 | ||
437 | void PMainWindow::setDocument( const QString& showImg ) | 441 | void PMainWindow::setDocument( const QString& showImg ) |
438 | { | 442 | { |
439 | bool first_start = m_disp==0; | ||
440 | |||
441 | QString file = showImg; | 443 | QString file = showImg; |
442 | DocLnk lnk(showImg); | 444 | DocLnk lnk(showImg); |
443 | if (lnk.isValid() ) | 445 | if (lnk.isValid() ) |
444 | file = lnk.file(); | 446 | file = lnk.file(); |
445 | slotDisplay( file ); | 447 | slotDisplay( file ); |
446 | if (first_start && m_aFullScreen->isOn()) { | 448 | #if 0 |
449 | if (!m_polishDone) { | ||
447 | QTimer::singleShot(0,this,SLOT(check_view_fullscreen())); | 450 | QTimer::singleShot(0,this,SLOT(check_view_fullscreen())); |
448 | } | 451 | } |
452 | #endif | ||
449 | } | 453 | } |
450 | 454 | ||
451 | void PMainWindow::check_view_fullscreen() | 455 | void PMainWindow::check_view_fullscreen() |
452 | { | 456 | { |
453 | if (!m_view) return; | 457 | if (!m_view) return; |
454 | if (!m_view->hasFocus()&&m_aFullScreen->isOn()) { | 458 | if (!m_view->hasFocus()&&m_aFullScreen->isOn()) { |
455 | qwsDisplay()->requestFocus( m_disp->winId(), TRUE); | 459 | qwsDisplay()->requestFocus( m_disp->winId(), TRUE); |
456 | } | 460 | } |
457 | } | 461 | } |
458 | 462 | ||
459 | void PMainWindow::slotSelectDir(int id) | 463 | void PMainWindow::slotSelectDir(int id) |
460 | { | 464 | { |
461 | emit changeDir( m_dev[fsMenu->text(id )] ); | 465 | emit changeDir( m_dev[fsMenu->text(id )] ); |
462 | } | 466 | } |
463 | 467 | ||
464 | void PMainWindow::dirChanged() | 468 | void PMainWindow::dirChanged() |
465 | { | 469 | { |
466 | fsMenu->clear(); | 470 | fsMenu->clear(); |
467 | m_dev.clear(); | 471 | m_dev.clear(); |
468 | 472 | ||
469 | /* home dir, too */ | 473 | /* home dir, too */ |
470 | QString f = getenv( "HOME" ); | 474 | QString f = getenv( "HOME" ); |
471 | if (!f.isEmpty()) { | 475 | if (!f.isEmpty()) { |
472 | m_dev.insert("Home directory",f); | 476 | m_dev.insert("Home directory",f); |
473 | fsMenu->insertItem("Home directory"); | 477 | fsMenu->insertItem("Home directory"); |
474 | } | 478 | } |
475 | const QList<FileSystem> &fs = m_storage->fileSystems(); | 479 | const QList<FileSystem> &fs = m_storage->fileSystems(); |
476 | QListIterator<FileSystem> it(fs ); | 480 | QListIterator<FileSystem> it(fs ); |
477 | for ( ; it.current(); ++it ) { | 481 | for ( ; it.current(); ++it ) { |
478 | const QString disk = (*it)->name(); | 482 | const QString disk = (*it)->name(); |
479 | const QString path = (*it)->path(); | 483 | const QString path = (*it)->path(); |
480 | m_dev.insert( disk, path ); | 484 | m_dev.insert( disk, path ); |
481 | fsMenu->insertItem( disk ); | 485 | fsMenu->insertItem( disk ); |
482 | } | 486 | } |
483 | } | 487 | } |
484 | 488 | ||
485 | void PMainWindow::showToolbar(bool how) | 489 | void PMainWindow::showToolbar(bool how) |
486 | { | 490 | { |
487 | if (!how) toolBar->hide(); | 491 | if (!how) toolBar->hide(); |
488 | else toolBar->show(); | 492 | else toolBar->show(); |
489 | if (autoSave) { | 493 | if (autoSave) { |
490 | m_cfg->writeEntry("showtoolbar",how); | 494 | m_cfg->writeEntry("showtoolbar",how); |
491 | } | 495 | } |
492 | } | 496 | } |
493 | 497 | ||
494 | void PMainWindow::setupActions() | 498 | void PMainWindow::setupActions() |
495 | { | 499 | { |
496 | m_aDirUp = new QAction( tr( "Go dir up" ), Resource::loadIconSet( "up" ), 0, 0, this, 0, true ); | 500 | m_aDirUp = new QAction( tr( "Go dir up" ), Resource::loadIconSet( "up" ), 0, 0, this, 0, true ); |
497 | m_aDirUp->setToggleAction(false); | 501 | m_aDirUp->setToggleAction(false); |
498 | connect(m_aDirUp,SIGNAL(activated()),m_view,SLOT(slotDirUp())); | 502 | connect(m_aDirUp,SIGNAL(activated()),m_view,SLOT(slotDirUp())); |
499 | 503 | ||
500 | if ( Ir::supported() ) { | 504 | if ( Ir::supported() ) { |
501 | m_aBeam = new QAction( tr( "Beam file" ), Resource::loadIconSet( "beam" ),0, 0, this, 0, true ); | 505 | m_aBeam = new QAction( tr( "Beam file" ), Resource::loadIconSet( "beam" ),0, 0, this, 0, true ); |
502 | m_aBeam->setToggleAction(false); | 506 | m_aBeam->setToggleAction(false); |
503 | connect(m_aBeam,SIGNAL(activated()),m_view,SLOT(slotBeam())); | 507 | connect(m_aBeam,SIGNAL(activated()),m_view,SLOT(slotBeam())); |
504 | } else { | 508 | } else { |
505 | m_aBeam = 0; | 509 | m_aBeam = 0; |
506 | } | 510 | } |
507 | 511 | ||
508 | m_aShowInfo = new QAction( tr( "Show imageinfo" ), Resource::loadIconSet( "edit" ), 0, 0, this, 0, true ); | 512 | m_aShowInfo = new QAction( tr( "Show imageinfo" ), Resource::loadIconSet( "edit" ), 0, 0, this, 0, true ); |
509 | m_aShowInfo->setToggleAction(false); | 513 | m_aShowInfo->setToggleAction(false); |
510 | connect(m_aShowInfo,SIGNAL(activated()),m_view,SLOT(slotImageInfo())); | 514 | connect(m_aShowInfo,SIGNAL(activated()),m_view,SLOT(slotImageInfo())); |
511 | 515 | ||
512 | m_aTrash = new QAction( tr( "Delete file" ), Resource::loadIconSet("trash"), 0, 0, this, 0, true ); | 516 | m_aTrash = new QAction( tr( "Delete file" ), Resource::loadIconSet("trash"), 0, 0, this, 0, true ); |
513 | m_aTrash->setToggleAction(false); | 517 | m_aTrash->setToggleAction(false); |
514 | connect(m_aTrash,SIGNAL(activated()),m_view,SLOT(slotTrash())); | 518 | connect(m_aTrash,SIGNAL(activated()),m_view,SLOT(slotTrash())); |
515 | 519 | ||
516 | m_aViewfile = new QAction( tr( "Display image" ), Resource::loadIconSet("mag"), 0, 0, this, 0, true ); | 520 | m_aViewfile = new QAction( tr( "Display image" ), Resource::loadIconSet("mag"), 0, 0, this, 0, true ); |
517 | m_aViewfile->setToggleAction(false); | 521 | m_aViewfile->setToggleAction(false); |
518 | connect(m_aViewfile,SIGNAL(activated()),m_view,SLOT(slotShowImage())); | 522 | connect(m_aViewfile,SIGNAL(activated()),m_view,SLOT(slotShowImage())); |
519 | 523 | ||
520 | m_aStartSlide = new QAction( tr( "Start slideshow" ), Resource::loadIconSet("play"),0, 0, this, 0, true ); | 524 | m_aStartSlide = new QAction( tr( "Start slideshow" ), Resource::loadIconSet("play"),0, 0, this, 0, true ); |
521 | m_aStartSlide->setToggleAction(false); | 525 | m_aStartSlide->setToggleAction(false); |
522 | connect(m_aStartSlide,SIGNAL(activated()),m_view,SLOT(slotStartSlide())); | 526 | connect(m_aStartSlide,SIGNAL(activated()),m_view,SLOT(slotStartSlide())); |
523 | 527 | ||
524 | m_aHideToolbar = new QAction( tr( "Show toolbar" ), Resource::loadIconSet( "UtilsIcon" ), 0, 0, this, 0, true ); | 528 | m_aHideToolbar = new QAction( tr( "Show toolbar" ), Resource::loadIconSet( "UtilsIcon" ), 0, 0, this, 0, true ); |
525 | m_aHideToolbar->setOn (true); | 529 | m_aHideToolbar->setOn (true); |
526 | connect(m_aHideToolbar,SIGNAL(toggled(bool)),this,SLOT(showToolbar(bool))); | 530 | connect(m_aHideToolbar,SIGNAL(toggled(bool)),this,SLOT(showToolbar(bool))); |
527 | 531 | ||
528 | m_aSetup = new QAction( tr( "Settings" ), Resource::loadIconSet("SettingsIcon"), 0, 0, this, 0, true ); | 532 | m_aSetup = new QAction( tr( "Settings" ), Resource::loadIconSet("SettingsIcon"), 0, 0, this, 0, true ); |
529 | m_aSetup->setToggleAction(false); | 533 | m_aSetup->setToggleAction(false); |
530 | connect(m_aSetup,SIGNAL(activated()),this,SLOT(slotConfig())); | 534 | connect(m_aSetup,SIGNAL(activated()),this,SLOT(slotConfig())); |
531 | 535 | ||
532 | m_gListViewMode = new QActionGroup(this,"Select listmode",true); | 536 | m_gListViewMode = new QActionGroup(this,"Select listmode",true); |
533 | connect(m_gListViewMode,SIGNAL(selected(QAction*)),this,SLOT(listviewselected(QAction*))); | 537 | connect(m_gListViewMode,SIGNAL(selected(QAction*)),this,SLOT(listviewselected(QAction*))); |
534 | 538 | ||
535 | m_aDirLong = new QAction( tr( "Thumbnail and Imageinfo" ),Resource::loadIconSet("opie-eye/opie-eye-thumb"), 0, 0, this, 0, true ); | 539 | m_aDirLong = new QAction( tr( "Thumbnail and Imageinfo" ),Resource::loadIconSet("opie-eye/opie-eye-thumb"), 0, 0, this, 0, true ); |
536 | m_aDirLong->setToggleAction(true); | 540 | m_aDirLong->setToggleAction(true); |
537 | m_aDirShort = new QAction( tr( "Thumbnail and name" ),Resource::loadIconSet("opie-eye/opie-eye-thumbonly"), 0, 0, this, 0, true ); | 541 | m_aDirShort = new QAction( tr( "Thumbnail and name" ),Resource::loadIconSet("opie-eye/opie-eye-thumbonly"), 0, 0, this, 0, true ); |
538 | m_aDirShort->setToggleAction(true); | 542 | m_aDirShort->setToggleAction(true); |
539 | m_aDirName = new QAction( tr( "Name only" ), Resource::loadIconSet("opie-eye/opie-eye-textview"),0, 0, this, 0, true ); | 543 | m_aDirName = new QAction( tr( "Name only" ), Resource::loadIconSet("opie-eye/opie-eye-textview"),0, 0, this, 0, true ); |
540 | m_aDirName->setToggleAction(true); | 544 | m_aDirName->setToggleAction(true); |
541 | int mode = m_cfg->readNumEntry("ListViewMode", 1); | 545 | int mode = m_cfg->readNumEntry("ListViewMode", 1); |
542 | if (mode < 1 || mode>3) mode = 1; | 546 | if (mode < 1 || mode>3) mode = 1; |
543 | switch (mode) { | 547 | switch (mode) { |
544 | case 3: | 548 | case 3: |
545 | m_aDirName->setOn(true); | 549 | m_aDirName->setOn(true); |
546 | break; | 550 | break; |
547 | case 2: | 551 | case 2: |
548 | m_aDirShort->setOn(true); | 552 | m_aDirShort->setOn(true); |
549 | break; | 553 | break; |
550 | case 1: | 554 | case 1: |
551 | default: | 555 | default: |
552 | m_aDirLong->setOn(true); | 556 | m_aDirLong->setOn(true); |
553 | } | 557 | } |
554 | m_gListViewMode->insert(m_aDirLong); | 558 | m_gListViewMode->insert(m_aDirLong); |
555 | m_gListViewMode->insert(m_aDirShort); | 559 | m_gListViewMode->insert(m_aDirShort); |
556 | m_gListViewMode->insert(m_aDirName); | 560 | m_gListViewMode->insert(m_aDirName); |
557 | 561 | ||
558 | m_gPrevNext = new QActionGroup(this,"imageprevnext",false); | 562 | m_gPrevNext = new QActionGroup(this,"imageprevnext",false); |
559 | m_aNext = new QAction( tr( "Next image" ), Resource::loadIconSet("forward"), 0, 0, this, 0, true ); | 563 | m_aNext = new QAction( tr( "Next image" ), Resource::loadIconSet("forward"), 0, 0, this, 0, true ); |
560 | m_aNext->setToggleAction(false); | 564 | m_aNext->setToggleAction(false); |
561 | connect(m_aNext,SIGNAL(activated()),m_view,SLOT(slotShowNext())); | 565 | connect(m_aNext,SIGNAL(activated()),m_view,SLOT(slotShowNext())); |
562 | m_aPrevious = new QAction( tr( "Previous image" ), Resource::loadIconSet("back"), 0, 0, this, 0, true ); | 566 | m_aPrevious = new QAction( tr( "Previous image" ), Resource::loadIconSet("back"), 0, 0, this, 0, true ); |
563 | m_aPrevious->setToggleAction(false); | 567 | m_aPrevious->setToggleAction(false); |
564 | connect(m_aPrevious,SIGNAL(activated()),m_view,SLOT(slotShowPrev())); | 568 | connect(m_aPrevious,SIGNAL(activated()),m_view,SLOT(slotShowPrev())); |
565 | m_gPrevNext->insert(m_aPrevious); | 569 | m_gPrevNext->insert(m_aPrevious); |
566 | m_gPrevNext->insert(m_aNext); | 570 | m_gPrevNext->insert(m_aNext); |
567 | 571 | ||
568 | m_aFullScreen = new QAction( tr( "Show images fullscreen" ), | 572 | m_aFullScreen = new QAction( tr( "Show images fullscreen" ), |
569 | Resource::loadIconSet("fullscreen"), 0, 0, this, 0, true ); | 573 | Resource::loadIconSet("fullscreen"), 0, 0, this, 0, true ); |
570 | m_aFullScreen->setToggleAction(true); | 574 | m_aFullScreen->setToggleAction(true); |
571 | if (autoSave) { | 575 | if (autoSave) { |
572 | m_aFullScreen->setOn(m_cfg->readBoolEntry("fullscreen",false)); | 576 | m_aFullScreen->setOn(m_cfg->readBoolEntry("fullscreen",false)); |
573 | } else { | 577 | } else { |
574 | m_aFullScreen->setOn(false); | 578 | m_aFullScreen->setOn(false); |
575 | } | 579 | } |
576 | connect(m_aFullScreen,SIGNAL(toggled(bool)),this,SLOT(slotFullScreenButton(bool))); | 580 | connect(m_aFullScreen,SIGNAL(toggled(bool)),this,SLOT(slotFullScreenButton(bool))); |
577 | 581 | ||
578 | m_gDisplayType = new QActionGroup(this,"imagedisplaytype",false); | 582 | m_gDisplayType = new QActionGroup(this,"imagedisplaytype",false); |
579 | m_aAutoRotate = new QAction( tr( "Auto rotate images" ), Resource::loadIconSet( "rotate" ), 0, 0, this, 0, true ); | 583 | m_aAutoRotate = new QAction( tr( "Auto rotate images" ), Resource::loadIconSet( "rotate" ), 0, 0, this, 0, true ); |
580 | m_aAutoRotate->setToggleAction(true); | 584 | m_aAutoRotate->setToggleAction(true); |
581 | 585 | ||
582 | if (m_stack->mode() == Opie::Ui::OWidgetStack::SmallScreen) { | 586 | if (m_stack->mode() == Opie::Ui::OWidgetStack::SmallScreen) { |
583 | m_aAutoRotate->setOn(true); | 587 | m_aAutoRotate->setOn(true); |
584 | } else { | 588 | } else { |
585 | m_aAutoRotate->setOn(false); | 589 | m_aAutoRotate->setOn(false); |
586 | } | 590 | } |
587 | if (autoSave) { | 591 | if (autoSave) { |
588 | m_aAutoRotate->setOn(m_cfg->readBoolEntry("autorotate",m_aAutoRotate->isOn())); | 592 | m_aAutoRotate->setOn(m_cfg->readBoolEntry("autorotate",m_aAutoRotate->isOn())); |
589 | } | 593 | } |
590 | connect(m_aAutoRotate,SIGNAL(toggled(bool)),this,SLOT(slotRotateToggled(bool))); | 594 | connect(m_aAutoRotate,SIGNAL(toggled(bool)),this,SLOT(slotRotateToggled(bool))); |
591 | 595 | ||
592 | m_aUnscaled = new QAction( tr( "Show images unscaled" ), Resource::loadIconSet( "1to1" ), 0, 0, this, 0, true ); | 596 | m_aUnscaled = new QAction( tr( "Show images unscaled" ), Resource::loadIconSet( "1to1" ), 0, 0, this, 0, true ); |
593 | m_aUnscaled->setToggleAction(true); | 597 | m_aUnscaled->setToggleAction(true); |
594 | connect(m_aUnscaled,SIGNAL(toggled(bool)),this,SLOT(slotScaleToggled(bool))); | 598 | connect(m_aUnscaled,SIGNAL(toggled(bool)),this,SLOT(slotScaleToggled(bool))); |
595 | if (autoSave) { | 599 | if (autoSave) { |
596 | m_aUnscaled->setOn(m_cfg->readBoolEntry("unscaled",false)); | 600 | m_aUnscaled->setOn(m_cfg->readBoolEntry("unscaled",false)); |
597 | } else { | 601 | } else { |
598 | m_aUnscaled->setOn(false); | 602 | m_aUnscaled->setOn(false); |
599 | } | 603 | } |
600 | 604 | ||
601 | m_aZoomer = new QAction( tr( "Show zoomer window when unscaled" ), Resource::loadIconSet( "mag" ), 0, 0, this, 0, true ); | 605 | m_aZoomer = new QAction( tr( "Show zoomer window when unscaled" ), Resource::loadIconSet( "mag" ), 0, 0, this, 0, true ); |
602 | m_aZoomer->setToggleAction(true); | 606 | m_aZoomer->setToggleAction(true); |
603 | if (autoSave) { | 607 | if (autoSave) { |
604 | m_aZoomer->setOn(m_cfg->readBoolEntry("zoomeron",true)); | 608 | m_aZoomer->setOn(m_cfg->readBoolEntry("zoomeron",true)); |
605 | } else { | 609 | } else { |
606 | m_aZoomer->setOn (true); | 610 | m_aZoomer->setOn (true); |
607 | } | 611 | } |
608 | connect(m_aZoomer,SIGNAL(toggled(bool)),this,SLOT(slotZoomerToggled(bool))); | 612 | connect(m_aZoomer,SIGNAL(toggled(bool)),this,SLOT(slotZoomerToggled(bool))); |
609 | m_gDisplayType->insert(m_aAutoRotate); | 613 | m_gDisplayType->insert(m_aAutoRotate); |
610 | m_gDisplayType->insert(m_aUnscaled); | 614 | m_gDisplayType->insert(m_aUnscaled); |
611 | m_gDisplayType->insert(m_aZoomer); | 615 | m_gDisplayType->insert(m_aZoomer); |
612 | 616 | ||
613 | m_hGroup = new QActionGroup(this,"actioncollection",false); | 617 | m_hGroup = new QActionGroup(this,"actioncollection",false); |
614 | m_hGroup->insert(m_aFullScreen); | 618 | m_hGroup->insert(m_aFullScreen); |
615 | } | 619 | } |
616 | 620 | ||
617 | void PMainWindow::setupToolbar() | 621 | void PMainWindow::setupToolbar() |
618 | { | 622 | { |
619 | toolBar = new QToolBar( this ); | 623 | toolBar = new QToolBar( this ); |
620 | addToolBar(toolBar); | 624 | addToolBar(toolBar); |
621 | toolBar->setHorizontalStretchable( true ); | 625 | toolBar->setHorizontalStretchable( true ); |
622 | setToolBarsMovable( false ); | 626 | setToolBarsMovable( false ); |
623 | m_aDirUp->addTo( toolBar ); | 627 | m_aDirUp->addTo( toolBar ); |
624 | 628 | ||
625 | fsButton = new PFileSystem( toolBar ); | 629 | fsButton = new PFileSystem( toolBar ); |
626 | connect( fsButton, SIGNAL( changeDir( const QString& ) ), | 630 | connect( fsButton, SIGNAL( changeDir( const QString& ) ), |
627 | m_view, SLOT(slotChangeDir( const QString& ) ) ); | 631 | m_view, SLOT(slotChangeDir( const QString& ) ) ); |
628 | connect( this, SIGNAL( changeDir( const QString& ) ), | 632 | connect( this, SIGNAL( changeDir( const QString& ) ), |
629 | m_view, SLOT(slotChangeDir( const QString& ) ) ); | 633 | m_view, SLOT(slotChangeDir( const QString& ) ) ); |
630 | 634 | ||
631 | if (m_aBeam) { | 635 | if (m_aBeam) { |
632 | m_aBeam->addTo( toolBar ); | 636 | m_aBeam->addTo( toolBar ); |
633 | } | 637 | } |
634 | m_aShowInfo->addTo(toolBar); | 638 | m_aShowInfo->addTo(toolBar); |
635 | m_aTrash->addTo(toolBar); | 639 | m_aTrash->addTo(toolBar); |
636 | // m_aSetup->addTo(toolBar); | 640 | // m_aSetup->addTo(toolBar); |
637 | 641 | ||
638 | m_gDisplayType->addTo(toolBar); | 642 | m_gDisplayType->addTo(toolBar); |
639 | 643 | ||
640 | if (m_stack->mode() != Opie::Ui::OWidgetStack::SmallScreen) { | 644 | if (m_stack->mode() != Opie::Ui::OWidgetStack::SmallScreen) { |
641 | m_gPrevNext->addTo(toolBar); | 645 | m_gPrevNext->addTo(toolBar); |
642 | } else { | 646 | } else { |
643 | m_gPrevNext->setEnabled(false); | 647 | m_gPrevNext->setEnabled(false); |
644 | } | 648 | } |
645 | } | 649 | } |
646 | 650 | ||
647 | void PMainWindow::setupMenu() | 651 | void PMainWindow::setupMenu() |
648 | { | 652 | { |
649 | fileMenu = new QPopupMenu( menuBar() ); | 653 | fileMenu = new QPopupMenu( menuBar() ); |
650 | menuBar()->insertItem( tr( "File" ), fileMenu ); | 654 | menuBar()->insertItem( tr( "File" ), fileMenu ); |
651 | dispMenu = new QPopupMenu( menuBar() ); | 655 | dispMenu = new QPopupMenu( menuBar() ); |
652 | menuBar()->insertItem( tr( "Show" ), dispMenu ); | 656 | menuBar()->insertItem( tr( "Show" ), dispMenu ); |
653 | settingsMenu = new QPopupMenu( menuBar() ); | 657 | settingsMenu = new QPopupMenu( menuBar() ); |
654 | menuBar()->insertItem( tr( "Settings" ), settingsMenu ); | 658 | menuBar()->insertItem( tr( "Settings" ), settingsMenu ); |
655 | 659 | ||
656 | m_aViewfile->addTo(fileMenu); | 660 | m_aViewfile->addTo(fileMenu); |
657 | m_aShowInfo->addTo(fileMenu); | 661 | m_aShowInfo->addTo(fileMenu); |
658 | m_aStartSlide->addTo(fileMenu); | 662 | m_aStartSlide->addTo(fileMenu); |
659 | 663 | ||
660 | fileMenu->insertSeparator(); | 664 | fileMenu->insertSeparator(); |
661 | m_aDirUp->addTo( fileMenu ); | 665 | m_aDirUp->addTo( fileMenu ); |
662 | 666 | ||
663 | fsMenu = new QPopupMenu(fileMenu); | 667 | fsMenu = new QPopupMenu(fileMenu); |
664 | fileMenu->insertItem(Resource::loadIconSet( "cardmon/pcmcia" ),tr("Select filesystem"),fsMenu); | 668 | fileMenu->insertItem(Resource::loadIconSet( "cardmon/pcmcia" ),tr("Select filesystem"),fsMenu); |
665 | connect( fsMenu, SIGNAL( activated( int ) ), this, SLOT(slotSelectDir( int ) ) ); | 669 | connect( fsMenu, SIGNAL( activated( int ) ), this, SLOT(slotSelectDir( int ) ) ); |
666 | dirChanged(); | 670 | dirChanged(); |
667 | 671 | ||
668 | if ( m_aBeam ) { | 672 | if ( m_aBeam ) { |
669 | fileMenu->insertSeparator(); | 673 | fileMenu->insertSeparator(); |
670 | m_aBeam->addTo( fileMenu ); | 674 | m_aBeam->addTo( fileMenu ); |
671 | } | 675 | } |
672 | fileMenu->insertSeparator(); | 676 | fileMenu->insertSeparator(); |
673 | m_aTrash->addTo(fileMenu); | 677 | m_aTrash->addTo(fileMenu); |
674 | 678 | ||
675 | listviewMenu = new QPopupMenu(dispMenu); | 679 | listviewMenu = new QPopupMenu(dispMenu); |
676 | dispMenu->insertItem(Resource::loadIconSet("opie-eye/opie-eye-thumb"),tr("Listview mode"),listviewMenu); | 680 | dispMenu->insertItem(Resource::loadIconSet("opie-eye/opie-eye-thumb"),tr("Listview mode"),listviewMenu); |
677 | m_gListViewMode->addTo(listviewMenu); | 681 | m_gListViewMode->addTo(listviewMenu); |
678 | dispMenu->insertSeparator(); | 682 | dispMenu->insertSeparator(); |
679 | m_aFullScreen->addTo(dispMenu); | 683 | m_aFullScreen->addTo(dispMenu); |
680 | m_gDisplayType->addTo(dispMenu); | 684 | m_gDisplayType->addTo(dispMenu); |
681 | dispMenu->insertSeparator(); | 685 | dispMenu->insertSeparator(); |
682 | m_gPrevNext->addTo(dispMenu); | 686 | m_gPrevNext->addTo(dispMenu); |
683 | 687 | ||
684 | m_aSetup->addTo(settingsMenu); | 688 | m_aSetup->addTo(settingsMenu); |
685 | m_aHideToolbar->addTo(settingsMenu); | 689 | m_aHideToolbar->addTo(settingsMenu); |
686 | } | 690 | } |
687 | 691 | ||
688 | void PMainWindow::listviewselected(QAction*which) | 692 | void PMainWindow::listviewselected(QAction*which) |
689 | { | 693 | { |
690 | if (!which || which->isOn()==false) return; | 694 | if (!which || which->isOn()==false) return; |
691 | int val = 1; | 695 | int val = 1; |
692 | // QString name; | ||
693 | 696 | ||
694 | if (which==m_aDirName) { | 697 | if (which==m_aDirName) { |
695 | val = 3; | 698 | val = 3; |
696 | // name = "opie-eye/opie-eye-textview"; | ||
697 | } else if (which==m_aDirShort) { | 699 | } else if (which==m_aDirShort) { |
698 | val = 2; | 700 | val = 2; |
699 | // name = "opie-eye/opie-eye-thumbonly"; | ||
700 | } else if (which==m_aDirLong) { | 701 | } else if (which==m_aDirLong) { |
701 | val = 1; | 702 | val = 1; |
702 | // name = "opie-eye/opie-eye-thumb"; | ||
703 | } | 703 | } |
704 | emit changeListMode(val); | 704 | emit changeListMode(val); |
705 | } | 705 | } |
706 | 706 | ||
707 | void PMainWindow::readConfig() | 707 | void PMainWindow::readConfig() |
708 | { | 708 | { |
709 | autoSave =m_cfg->readBoolEntry("savestatus",true); | 709 | autoSave =m_cfg->readBoolEntry("savestatus",true); |
710 | } | 710 | } |
711 | |||
712 | void PMainWindow::polish() | ||
713 | { | ||
714 | if (m_disp) { | ||
715 | odebug << "======================\n" | ||
716 | << "Called via setdocument\n" | ||
717 | << "======================" << oendl; | ||
718 | m_setDocCalled = true; | ||
719 | m_view->setDoccalled(true); | ||
720 | m_disp->setCloseIfHide(true); | ||
721 | } else { | ||
722 | m_setDocCalled = false; | ||
723 | m_view->setDoccalled(false); | ||
724 | } | ||
725 | m_polishDone = true; | ||
726 | QMainWindow::polish(); | ||
727 | if (m_setDocCalled) { | ||
728 | if (m_aFullScreen->isOn()) { | ||
729 | QTimer::singleShot(0,this,SLOT(check_view_fullscreen())); | ||
730 | } else if (m_stack->mode() != Opie::Ui::OWidgetStack::SmallScreen) { | ||
731 | } | ||
732 | } | ||
733 | } | ||
diff --git a/noncore/graphics/opie-eye/gui/mainwindow.h b/noncore/graphics/opie-eye/gui/mainwindow.h index 465e352..2f54090 100644 --- a/noncore/graphics/opie-eye/gui/mainwindow.h +++ b/noncore/graphics/opie-eye/gui/mainwindow.h | |||
@@ -1,107 +1,110 @@ | |||
1 | /* | 1 | /* |
2 | * GPLv2 zecke@handhelds.org | 2 | * GPLv2 zecke@handhelds.org |
3 | * No WArranty... | 3 | * No WArranty... |
4 | */ | 4 | */ |
5 | 5 | ||
6 | #ifndef PHUNK_MAIN_WINDOW_H | 6 | #ifndef PHUNK_MAIN_WINDOW_H |
7 | #define PHUNK_MAIN_WINDOW_H | 7 | #define PHUNK_MAIN_WINDOW_H |
8 | 8 | ||
9 | #include <opie2/oconfig.h> | 9 | #include <opie2/oconfig.h> |
10 | 10 | ||
11 | #include <qmainwindow.h> | 11 | #include <qmainwindow.h> |
12 | 12 | ||
13 | 13 | ||
14 | 14 | ||
15 | namespace Opie { | 15 | namespace Opie { |
16 | namespace Ui{ | 16 | namespace Ui{ |
17 | class OWidgetStack; | 17 | class OWidgetStack; |
18 | } | 18 | } |
19 | namespace Core{ | 19 | namespace Core{ |
20 | class OKeyConfigManager; | 20 | class OKeyConfigManager; |
21 | } | 21 | } |
22 | } | 22 | } |
23 | 23 | ||
24 | class ImageView; | 24 | class ImageView; |
25 | class ImageWidget; | 25 | class ImageWidget; |
26 | class PIconView; | 26 | class PIconView; |
27 | class imageinfo; | 27 | class imageinfo; |
28 | class QMenuBar; | 28 | class QMenuBar; |
29 | class QToolBar; | 29 | class QToolBar; |
30 | class QPopupMenu; | 30 | class QPopupMenu; |
31 | class QAction; | 31 | class QAction; |
32 | class QActionGroup; | 32 | class QActionGroup; |
33 | class StorageInfo; | 33 | class StorageInfo; |
34 | 34 | ||
35 | class PMainWindow : public QMainWindow { | 35 | class PMainWindow : public QMainWindow { |
36 | Q_OBJECT | 36 | Q_OBJECT |
37 | enum Views { IconView, ImageInfo, ImageDisplay }; | 37 | enum Views { IconView, ImageInfo, ImageDisplay }; |
38 | public: | 38 | public: |
39 | static QString appName() { return QString::fromLatin1("opie-eye" ); } | 39 | static QString appName() { return QString::fromLatin1("opie-eye" ); } |
40 | PMainWindow(QWidget*, const char*, WFlags ); | 40 | PMainWindow(QWidget*, const char*, WFlags ); |
41 | ~PMainWindow(); | 41 | ~PMainWindow(); |
42 | 42 | ||
43 | signals: | 43 | signals: |
44 | void configChanged(); | 44 | void configChanged(); |
45 | void changeDir( const QString& ); | 45 | void changeDir( const QString& ); |
46 | void changeListMode(int); | 46 | void changeListMode(int); |
47 | 47 | ||
48 | public slots: | 48 | public slots: |
49 | void slotShowInfo( const QString& inf ); | 49 | void slotShowInfo( const QString& inf ); |
50 | void slotDisplay( const QString& inf ); | 50 | void slotDisplay( const QString& inf ); |
51 | void slotReturn(); | 51 | void slotReturn(); |
52 | void slotRotateToggled(bool); | 52 | void slotRotateToggled(bool); |
53 | void slotScaleToggled(bool); | 53 | void slotScaleToggled(bool); |
54 | void slotZoomerToggled(bool); | 54 | void slotZoomerToggled(bool); |
55 | void slotToggleZoomer(); | 55 | void slotToggleZoomer(); |
56 | void slotToggleAutorotate(); | 56 | void slotToggleAutorotate(); |
57 | void slotToggleAutoscale(); | 57 | void slotToggleAutoscale(); |
58 | void setDocument( const QString& ); | 58 | void setDocument( const QString& ); |
59 | virtual void slotToggleFullScreen(); | 59 | virtual void slotToggleFullScreen(); |
60 | virtual void slotFullScreenToggled(bool); | 60 | virtual void slotFullScreenToggled(bool); |
61 | virtual void polish(); | ||
61 | 62 | ||
62 | protected slots: | 63 | protected slots: |
63 | void raiseIconView(); | 64 | void raiseIconView(); |
64 | void closeEvent( QCloseEvent* ); | 65 | void closeEvent( QCloseEvent* ); |
65 | void showToolbar(bool); | 66 | void showToolbar(bool); |
66 | void listviewselected(QAction*); | 67 | void listviewselected(QAction*); |
67 | void slotFullScreenButton(bool); | 68 | void slotFullScreenButton(bool); |
68 | void check_view_fullscreen(); | 69 | void check_view_fullscreen(); |
69 | 70 | ||
70 | private: | 71 | private: |
71 | template<class T> void initT( const char* name, T**, int ); | 72 | template<class T> void initT( const char* name, T**, int ); |
72 | void initInfo(); | 73 | void initInfo(); |
73 | void initDisp(); | 74 | void initDisp(); |
74 | void setupViewWindow(bool full, bool forceDisplay); | 75 | void setupViewWindow(bool full, bool forceDisplay); |
75 | 76 | ||
76 | private: | 77 | private: |
77 | Opie::Core::OConfig *m_cfg; | 78 | Opie::Core::OConfig *m_cfg; |
78 | Opie::Ui::OWidgetStack *m_stack; | 79 | Opie::Ui::OWidgetStack *m_stack; |
79 | PIconView* m_view; | 80 | PIconView* m_view; |
80 | imageinfo *m_info; | 81 | imageinfo *m_info; |
81 | ImageView *m_disp; | 82 | ImageView *m_disp; |
82 | bool autoSave; | 83 | bool autoSave; |
84 | bool m_setDocCalled:1; | ||
85 | bool m_polishDone:1; | ||
83 | QToolButton*fsButton; | 86 | QToolButton*fsButton; |
84 | QToolBar *toolBar; | 87 | QToolBar *toolBar; |
85 | QPopupMenu *fileMenu,*dispMenu,*fsMenu,*listviewMenu,*settingsMenu; | 88 | QPopupMenu *fileMenu,*dispMenu,*fsMenu,*listviewMenu,*settingsMenu; |
86 | QAction*m_aShowInfo,*m_aBeam,*m_aTrash,*m_aViewfile,*m_aDirUp,*m_aStartSlide; | 89 | QAction*m_aShowInfo,*m_aBeam,*m_aTrash,*m_aViewfile,*m_aDirUp,*m_aStartSlide; |
87 | QAction*m_aHideToolbar,*m_aSetup,*m_aDirName,*m_aDirShort,*m_aDirLong; | 90 | QAction*m_aHideToolbar,*m_aSetup,*m_aDirName,*m_aDirShort,*m_aDirLong; |
88 | QActionGroup *m_gListViewMode,*m_gDisplayType,*m_gPrevNext,*m_hGroup; | 91 | QActionGroup *m_gListViewMode,*m_gDisplayType,*m_gPrevNext,*m_hGroup; |
89 | QAction *m_aNext,*m_aPrevious,*m_aFullScreen; | 92 | QAction *m_aNext,*m_aPrevious,*m_aFullScreen; |
90 | QAction *m_aAutoRotate,*m_aUnscaled,*m_aZoomer; | 93 | QAction *m_aAutoRotate,*m_aUnscaled,*m_aZoomer; |
91 | 94 | ||
92 | /* init funs */ | 95 | /* init funs */ |
93 | void readConfig(); | 96 | void readConfig(); |
94 | void setupActions(); | 97 | void setupActions(); |
95 | void setupToolbar(); | 98 | void setupToolbar(); |
96 | void setupMenu(); | 99 | void setupMenu(); |
97 | /* for the device submenu - ToDo: Merge with the special button */ | 100 | /* for the device submenu - ToDo: Merge with the special button */ |
98 | StorageInfo *m_storage; | 101 | StorageInfo *m_storage; |
99 | QMap<QString, QString> m_dev; | 102 | QMap<QString, QString> m_dev; |
100 | 103 | ||
101 | private slots: | 104 | private slots: |
102 | void slotConfig(); | 105 | void slotConfig(); |
103 | void slotSelectDir(int); | 106 | void slotSelectDir(int); |
104 | void dirChanged(); | 107 | void dirChanged(); |
105 | }; | 108 | }; |
106 | 109 | ||
107 | #endif | 110 | #endif |
diff --git a/noncore/graphics/opie-eye/impl/doc/doc_lister.cpp b/noncore/graphics/opie-eye/impl/doc/doc_lister.cpp index f5c711a..8bcf01d 100644 --- a/noncore/graphics/opie-eye/impl/doc/doc_lister.cpp +++ b/noncore/graphics/opie-eye/impl/doc/doc_lister.cpp | |||
@@ -1,188 +1,201 @@ | |||
1 | /* | 1 | /* |
2 | * GPLv2 zecke@handhelds.org | 2 | * GPLv2 zecke@handhelds.org |
3 | */ | 3 | */ |
4 | 4 | ||
5 | #include "doc_lister.h" | 5 | #include "doc_lister.h" |
6 | 6 | ||
7 | #include <lib/slavemaster.h> | 7 | #include <lib/slavemaster.h> |
8 | 8 | ||
9 | /* OPIE */ | 9 | /* OPIE */ |
10 | #include <opie2/odebug.h> | 10 | #include <opie2/odebug.h> |
11 | #include <qpe/config.h> | 11 | #include <qpe/config.h> |
12 | #include <qpe/qpeapplication.h> | 12 | #include <qpe/qpeapplication.h> |
13 | #include <qpe/applnk.h> | 13 | #include <qpe/applnk.h> |
14 | #include <opie2/oglobal.h> | ||
14 | 15 | ||
15 | #include <qtopia/private/categories.h> | 16 | #include <qtopia/private/categories.h> |
16 | #include <qtopia/categoryselect.h> | 17 | #include <qtopia/categoryselect.h> |
17 | 18 | ||
18 | using namespace Opie::Core; | 19 | using namespace Opie::Core; |
19 | 20 | ||
20 | /* QT */ | 21 | /* QT */ |
21 | #include <qdir.h> | 22 | #include <qdir.h> |
22 | #include <qfileinfo.h> | 23 | #include <qfileinfo.h> |
24 | #include <qtopia/qcopenvelope_qws.h> | ||
23 | 25 | ||
24 | Doc_DirLister::Doc_DirLister() | 26 | Doc_DirLister::Doc_DirLister() |
25 | : PDirLister( "doc_dir_lister" ) | 27 | : PDirLister( "doc_dir_lister" ) |
26 | { | 28 | { |
27 | /* connect the signals */ | 29 | /* connect the signals */ |
28 | m_catFilter = 0; | 30 | m_catFilter = 0; |
29 | SlaveMaster* master = SlaveMaster::self(); | 31 | SlaveMaster* master = SlaveMaster::self(); |
30 | connect( master, SIGNAL(sig_start()), this, SIGNAL(sig_start()) ); | 32 | connect( master, SIGNAL(sig_start()), this, SIGNAL(sig_start()) ); |
31 | connect( master, SIGNAL(sig_end()), this, SIGNAL(sig_end()) ); | 33 | connect( master, SIGNAL(sig_end()), this, SIGNAL(sig_end()) ); |
32 | connect( master, SIGNAL(sig_thumbInfo(const QString&, const QString&)), | 34 | connect( master, SIGNAL(sig_thumbInfo(const QString&, const QString&)), |
33 | this, SLOT(slotThumbInfo(const QString&, const QString&)) ); | 35 | this, SLOT(slotThumbInfo(const QString&, const QString&)) ); |
34 | connect( master, SIGNAL(sig_fullInfo(const QString&, const QString&)), | 36 | connect( master, SIGNAL(sig_fullInfo(const QString&, const QString&)), |
35 | this, SLOT(slotFullInfo(const QString&, const QString&)) ); | 37 | this, SLOT(slotFullInfo(const QString&, const QString&)) ); |
36 | connect( master, SIGNAL(sig_thumbNail(const QString&, const QPixmap&)), | 38 | connect( master, SIGNAL(sig_thumbNail(const QString&, const QPixmap&)), |
37 | this, SLOT(slotThumbNail(const QString&, const QPixmap&)) ); | 39 | this, SLOT(slotThumbNail(const QString&, const QPixmap&)) ); |
38 | |||
39 | m_namemap.clear(); | ||
40 | m_filemap.clear(); | ||
41 | m_docreads = false; | 40 | m_docreads = false; |
41 | syschannel = new QCopChannel("QPE/System", this); | ||
42 | connect(syschannel, SIGNAL(received(const QCString&,const QByteArray&)), | ||
43 | this, SLOT(systemMsg(const QCString&,const QByteArray&)) ); | ||
44 | } | ||
45 | |||
46 | Doc_DirLister::~Doc_DirLister() | ||
47 | { | ||
42 | } | 48 | } |
43 | 49 | ||
44 | QString Doc_DirLister::defaultPath()const { | 50 | QString Doc_DirLister::defaultPath()const { |
45 | return QString::null; | 51 | return QString::null; |
46 | } | 52 | } |
47 | 53 | ||
48 | bool Doc_DirLister::matchCat(const AppLnk* app) | 54 | bool Doc_DirLister::matchCat(const AppLnk* app)const |
49 | { | 55 | { |
50 | if (!app) return false; | 56 | if (!app) return false; |
51 | if (m_catFilter==0 || app->categories().contains(m_catFilter) || m_catFilter == -1 && app->categories().count() == 0 ) { | 57 | if (m_catFilter==0 || app->categories().contains(m_catFilter) || m_catFilter == -1 && app->categories().count() == 0 ) { |
52 | return true; | 58 | return true; |
53 | } | 59 | } |
54 | return false; | 60 | return false; |
55 | } | 61 | } |
56 | 62 | ||
57 | QString Doc_DirLister::setStartPath(const QString&) { | 63 | QString Doc_DirLister::setStartPath(const QString&) { |
58 | static const QString Mtype_str("image/jpeg;image/gif;image/bmp;image/png"); | 64 | static const QString Mtype_str("image/jpeg;image/gif;image/bmp;image/png"); |
59 | if (m_namemap.isEmpty()) { | 65 | if (!m_docreads) { |
60 | if (!m_docreads) { | 66 | Global::findDocuments(&m_ds,Mtype_str); |
61 | Global::findDocuments(&m_ds,Mtype_str); | 67 | m_docreads = true; |
62 | m_docreads = true; | ||
63 | } | ||
64 | QListIterator<DocLnk> dit(m_ds.children()); | ||
65 | for( ; dit.current(); ++dit) { | ||
66 | if (!matchCat((*dit))) continue; | ||
67 | m_namemap[(*dit)->name()]=(*dit)->file(); | ||
68 | m_filemap[(*dit)->file()]=(*dit)->name(); | ||
69 | } | ||
70 | } | 68 | } |
71 | return QString::null; | 69 | return QString::null; |
72 | } | 70 | } |
73 | 71 | ||
74 | QString Doc_DirLister::currentPath()const { | 72 | QString Doc_DirLister::currentPath()const |
75 | return QString::null; | 73 | { |
74 | return QString::null; | ||
76 | } | 75 | } |
77 | 76 | ||
78 | 77 | ||
79 | QStringList Doc_DirLister::folders()const { | 78 | QStringList Doc_DirLister::folders()const { |
80 | return QStringList(); | 79 | return QStringList(); |
81 | } | 80 | } |
82 | 81 | ||
83 | QStringList Doc_DirLister::files()const { | 82 | QStringList Doc_DirLister::files()const { |
84 | QStringList out; | 83 | QStringList out; |
85 | QMap<QString,QString>::ConstIterator it; | 84 | QListIterator<DocLnk> dit(m_ds.children()); |
86 | for (it = m_namemap.begin();it != m_namemap.end();++it) { | 85 | for( ; dit.current(); ++dit) { |
87 | out.append(it.key()); | 86 | if (!matchCat((*dit))) continue; |
87 | QString s = (*dit)->name(); | ||
88 | s+=char(0); | ||
89 | s+=(*dit)->file(); | ||
90 | out.append(s); | ||
88 | } | 91 | } |
89 | return out; | 92 | return out; |
90 | } | 93 | } |
91 | 94 | ||
92 | void Doc_DirLister::deleteImage( const QString& ) | 95 | void Doc_DirLister::deleteImage( const QString& ) |
93 | { | 96 | { |
94 | } | 97 | } |
95 | 98 | ||
96 | void Doc_DirLister::thumbNail( const QString& str, int w, int h) { | 99 | void Doc_DirLister::thumbNail( const QString& str, int w, int h) |
97 | if (m_namemap.find(str)==m_namemap.end()) { | 100 | { |
98 | return; | 101 | SlaveMaster::self()->thumbNail( str, w, h ); |
99 | } | ||
100 | QString fname = m_namemap[str]; | ||
101 | SlaveMaster::self()->thumbNail( fname, w, h ); | ||
102 | } | 102 | } |
103 | 103 | ||
104 | QImage Doc_DirLister::image( const QString& str, Factor f, int m) { | 104 | QImage Doc_DirLister::image( const QString& str, Factor f, int m) |
105 | if (m_namemap.find(str)==m_namemap.end()) { | 105 | { |
106 | return QImage(); | 106 | return SlaveMaster::self()->image(str, f, m ); |
107 | } | ||
108 | QString fname = m_namemap[str]; | ||
109 | return SlaveMaster::self()->image( fname, f, m ); | ||
110 | } | 107 | } |
111 | 108 | ||
112 | void Doc_DirLister::imageInfo( const QString& str) { | 109 | void Doc_DirLister::imageInfo( const QString& str) { |
113 | if (m_namemap.find(str)==m_namemap.end()) { | 110 | SlaveMaster::self()->thumbInfo( str ); |
114 | return; | ||
115 | } | ||
116 | QString fname = m_namemap[str]; | ||
117 | SlaveMaster::self()->thumbInfo( fname ); | ||
118 | } | 111 | } |
119 | 112 | ||
120 | void Doc_DirLister::fullImageInfo( const QString& str) { | 113 | void Doc_DirLister::fullImageInfo( const QString& str) { |
121 | if (m_namemap.find(str)==m_namemap.end()) { | 114 | SlaveMaster::self()->imageInfo(str); |
122 | return; | ||
123 | } | ||
124 | QString fname = m_namemap[str]; | ||
125 | SlaveMaster::self()->imageInfo( fname ); | ||
126 | } | 115 | } |
127 | 116 | ||
128 | void Doc_DirLister::slotFullInfo(const QString&f, const QString&t) | 117 | void Doc_DirLister::slotFullInfo(const QString&f, const QString&t) |
129 | { | 118 | { |
130 | if (m_filemap.find(f)==m_filemap.end()) { | 119 | emit sig_fullInfo(f, t); |
131 | return; | ||
132 | } | ||
133 | QString name = m_filemap[f]; | ||
134 | emit sig_fullInfo(name, t); | ||
135 | } | 120 | } |
136 | 121 | ||
137 | void Doc_DirLister::slotThumbInfo(const QString&f, const QString&t) | 122 | void Doc_DirLister::slotThumbInfo(const QString&f, const QString&t) |
138 | { | 123 | { |
139 | if (m_filemap.find(f)==m_filemap.end()) { | 124 | emit sig_thumbInfo(f, t); |
140 | return; | ||
141 | } | ||
142 | QString name = m_filemap[f]; | ||
143 | emit sig_thumbInfo(name, t); | ||
144 | } | 125 | } |
145 | 126 | ||
146 | void Doc_DirLister::slotThumbNail(const QString&f, const QPixmap&p) | 127 | void Doc_DirLister::slotThumbNail(const QString&f, const QPixmap&p) |
147 | { | 128 | { |
148 | if (m_filemap.find(f)==m_filemap.end()) { | 129 | emit sig_thumbNail(f, p); |
149 | return; | ||
150 | } | ||
151 | QString name = m_filemap[f]; | ||
152 | emit sig_thumbNail(name, p); | ||
153 | } | 130 | } |
154 | 131 | ||
155 | QString Doc_DirLister::nameToFname(const QString&name)const | 132 | QString Doc_DirLister::nameToFname(const QString&name)const |
156 | { | 133 | { |
157 | if (m_namemap.find(name)==m_namemap.end()) { | 134 | return name; |
158 | return QString::null; | ||
159 | } | ||
160 | return m_namemap[name]; | ||
161 | } | 135 | } |
162 | 136 | ||
163 | QString Doc_DirLister::dirUp( const QString& p ) const{ | 137 | QString Doc_DirLister::dirUp( const QString& p ) const{ |
164 | return p; | 138 | return p; |
165 | } | 139 | } |
166 | 140 | ||
167 | QWidget* Doc_DirLister::widget(QWidget*parent) | 141 | QWidget* Doc_DirLister::widget(QWidget*parent) |
168 | { | 142 | { |
169 | CategorySelect * catmb = new CategorySelect(parent); | 143 | CategorySelect * catmb = new CategorySelect(parent); |
170 | Categories cats( 0 ); | 144 | Categories cats( 0 ); |
171 | cats.load( categoryFileName() ); | 145 | cats.load( categoryFileName() ); |
172 | QArray<int> vl( 0 ); | 146 | QArray<int> vl( 0 ); |
173 | catmb->setCategories( vl, "Document View", // No tr | 147 | catmb->setCategories( vl, "Document View", // No tr |
174 | "Document View" ); | 148 | "Document View" ); |
175 | catmb->setRemoveCategoryEdit( TRUE ); | 149 | catmb->setRemoveCategoryEdit( TRUE ); |
176 | catmb->setAllCategories( TRUE ); | 150 | catmb->setAllCategories( TRUE ); |
177 | connect(catmb, SIGNAL(signalSelected(int)), this, SLOT(showCategory(int))); | 151 | connect(catmb, SIGNAL(signalSelected(int)), this, SLOT(showCategory(int))); |
178 | catmb->setCurrentCategory(-2); | 152 | catmb->setCurrentCategory(-2); |
179 | return catmb; | 153 | return catmb; |
180 | } | 154 | } |
181 | 155 | ||
182 | void Doc_DirLister::showCategory(int which) | 156 | void Doc_DirLister::showCategory(int which) |
183 | { | 157 | { |
184 | m_catFilter = which==-2?0:which; | 158 | m_catFilter = which==-2?0:which; |
185 | m_namemap.clear(); | ||
186 | setStartPath(""); | 159 | setStartPath(""); |
187 | emit sig_reloadDir(); | 160 | emit sig_reloadDir(); |
188 | } | 161 | } |
162 | |||
163 | void Doc_DirLister::systemMsg(const QCString &msg, const QByteArray &data) | ||
164 | { | ||
165 | if ( msg != "linkChanged(QString)"||!m_docreads) { | ||
166 | return; | ||
167 | } | ||
168 | QString link; | ||
169 | QDataStream stream( data, IO_ReadOnly ); | ||
170 | stream >> link; | ||
171 | odebug << "Doc_DirLister systemMsg -> linkchanged( " << link << " )" << oendl; | ||
172 | if ( link.isNull() || OGlobal::isAppLnkFileName(link) ) { | ||
173 | return; | ||
174 | } | ||
175 | QListIterator<DocLnk> dit(m_ds.children()); | ||
176 | bool must_reload = false; | ||
177 | bool found = false; | ||
178 | while ( dit.current() ) { | ||
179 | DocLnk *doc = dit.current(); | ||
180 | ++dit; | ||
181 | if (doc->linkFile() == link) { | ||
182 | found = true; | ||
183 | DocLnk* dl = new DocLnk(link); | ||
184 | if (dl->fileKnown()) { | ||
185 | // changing | ||
186 | m_ds.add(dl); | ||
187 | } else { | ||
188 | delete dl; | ||
189 | } | ||
190 | if (matchCat(doc) || matchCat(dl)) { | ||
191 | must_reload = true; | ||
192 | } | ||
193 | m_ds.remove( doc ); // remove old link from docLnkSet | ||
194 | delete doc; | ||
195 | } | ||
196 | } | ||
197 | if (must_reload) { | ||
198 | setStartPath(""); | ||
199 | emit sig_reloadDir(); | ||
200 | } | ||
201 | } | ||
diff --git a/noncore/graphics/opie-eye/impl/doc/doc_lister.h b/noncore/graphics/opie-eye/impl/doc/doc_lister.h index 403241c..3f8825f 100644 --- a/noncore/graphics/opie-eye/impl/doc/doc_lister.h +++ b/noncore/graphics/opie-eye/impl/doc/doc_lister.h | |||
@@ -1,53 +1,55 @@ | |||
1 | /* | 1 | /* |
2 | * GPLv2 zecke@handhelds.org | 2 | * GPLv2 zecke@handhelds.org |
3 | */ | 3 | */ |
4 | 4 | ||
5 | #ifndef DOC_LISTER_INTERFACE_LISTER_H | 5 | #ifndef DOC_LISTER_INTERFACE_LISTER_H |
6 | #define DOC_LISTER_INTERFACE_LISTER_H | 6 | #define DOC_LISTER_INTERFACE_LISTER_H |
7 | 7 | ||
8 | #include <iface/dirlister.h> | 8 | #include <iface/dirlister.h> |
9 | 9 | ||
10 | #include <qpe/applnk.h> | 10 | #include <qpe/applnk.h> |
11 | 11 | ||
12 | #include <qstring.h> | 12 | #include <qstring.h> |
13 | #include <qmap.h> | 13 | #include <qmap.h> |
14 | 14 | ||
15 | class Config; | 15 | class Config; |
16 | class AppLnk; | 16 | class AppLnk; |
17 | class QCopChannel; | ||
17 | 18 | ||
18 | class Doc_DirLister : public PDirLister { | 19 | class Doc_DirLister : public PDirLister { |
19 | Q_OBJECT | 20 | Q_OBJECT |
20 | public: | 21 | public: |
21 | Doc_DirLister(); | 22 | Doc_DirLister(); |
22 | virtual ~Doc_DirLister(){} | 23 | virtual ~Doc_DirLister(); |
23 | 24 | ||
24 | QString defaultPath()const; | 25 | QString defaultPath()const; |
25 | QString setStartPath( const QString& ); | 26 | QString setStartPath( const QString& ); |
26 | QString currentPath()const; | 27 | QString currentPath()const; |
27 | QStringList folders()const; | 28 | QStringList folders()const; |
28 | QStringList files()const; | 29 | QStringList files()const; |
29 | 30 | ||
30 | void deleteImage( const QString& ); | 31 | void deleteImage( const QString& ); |
31 | void thumbNail( const QString&, int, int ); | 32 | void thumbNail( const QString&, int, int ); |
32 | QImage image( const QString&, Factor, int ); | 33 | QImage image( const QString&, Factor, int ); |
33 | void imageInfo( const QString& ); | 34 | void imageInfo( const QString& ); |
34 | void fullImageInfo( const QString& ); | 35 | void fullImageInfo( const QString& ); |
35 | virtual QString nameToFname(const QString&name)const; | 36 | virtual QString nameToFname(const QString&name)const; |
36 | QString dirUp( const QString& )const; | 37 | QString dirUp( const QString& )const; |
37 | QWidget* widget(QWidget*parent); | 38 | QWidget* widget(QWidget*parent); |
38 | 39 | ||
39 | private: | 40 | private: |
40 | QMap<QString,QString> m_namemap,m_filemap; | ||
41 | int m_catFilter; | 41 | int m_catFilter; |
42 | bool matchCat(const AppLnk* app); | 42 | bool matchCat(const AppLnk* app)const; |
43 | bool m_docreads; | 43 | bool m_docreads; |
44 | DocLnkSet m_ds; | 44 | DocLnkSet m_ds; |
45 | 45 | ||
46 | protected slots: | 46 | protected slots: |
47 | virtual void slotFullInfo(const QString&, const QString&); | 47 | virtual void slotFullInfo(const QString&, const QString&); |
48 | virtual void slotThumbInfo(const QString&, const QString&); | 48 | virtual void slotThumbInfo(const QString&, const QString&); |
49 | virtual void slotThumbNail(const QString&, const QPixmap&); | 49 | virtual void slotThumbNail(const QString&, const QPixmap&); |
50 | virtual void showCategory(int); | 50 | virtual void showCategory(int); |
51 | void systemMsg(const QCString &, const QByteArray &); | ||
52 | QCopChannel *syschannel; | ||
51 | }; | 53 | }; |
52 | 54 | ||
53 | #endif | 55 | #endif |