-rw-r--r-- | core/multimedia/opieplayer/playlistwidget.cpp | 37 |
1 files changed, 23 insertions, 14 deletions
diff --git a/core/multimedia/opieplayer/playlistwidget.cpp b/core/multimedia/opieplayer/playlistwidget.cpp index 4926287..b9b63c7 100644 --- a/core/multimedia/opieplayer/playlistwidget.cpp +++ b/core/multimedia/opieplayer/playlistwidget.cpp | |||
@@ -1060,298 +1060,307 @@ void PlayListWidget::populateVideoView() { | |||
1060 | if( Vdit.current()->file().find(path) != -1 ) storage=name; | 1060 | if( Vdit.current()->file().find(path) != -1 ) storage=name; |
1061 | } | 1061 | } |
1062 | 1062 | ||
1063 | QListViewItem * newItem; | 1063 | QListViewItem * newItem; |
1064 | if ( QFile( Vdit.current()->file()).exists() ) { | 1064 | if ( QFile( Vdit.current()->file()).exists() ) { |
1065 | newItem= /*(void)*/ new QListViewItem( videoView, Vdit.current()->name(), | 1065 | newItem= /*(void)*/ new QListViewItem( videoView, Vdit.current()->name(), |
1066 | QString::number( QFile( Vdit.current()->file()).size() ), storage); | 1066 | QString::number( QFile( Vdit.current()->file()).size() ), storage); |
1067 | newItem->setPixmap(0, Resource::loadPixmap( "opieplayer/videofile" )); | 1067 | newItem->setPixmap(0, Resource::loadPixmap( "opieplayer/videofile" )); |
1068 | } | 1068 | } |
1069 | } | 1069 | } |
1070 | } | 1070 | } |
1071 | 1071 | ||
1072 | void PlayListWidget::openFile() { | 1072 | void PlayListWidget::openFile() { |
1073 | QString filename, name; | 1073 | QString filename, name; |
1074 | InputDialog *fileDlg; | 1074 | InputDialog *fileDlg; |
1075 | fileDlg = new InputDialog(this,tr("Open file or URL"),TRUE, 0); | 1075 | fileDlg = new InputDialog(this,tr("Open file or URL"),TRUE, 0); |
1076 | fileDlg->exec(); | 1076 | fileDlg->exec(); |
1077 | if( fileDlg->result() == 1 ) { | 1077 | if( fileDlg->result() == 1 ) { |
1078 | filename = fileDlg->LineEdit1->text(); | 1078 | filename = fileDlg->LineEdit1->text(); |
1079 | // http://205.188.234.129:8030 | 1079 | // http://205.188.234.129:8030 |
1080 | // http://66.28.68.70:8000 | 1080 | // http://66.28.68.70:8000 |
1081 | // filename.replace(QRegExp("%20")," "); | 1081 | // filename.replace(QRegExp("%20")," "); |
1082 | if(filename.find(" ",0,TRUE) != -1 || filename.find("%20",0,TRUE) != -1) { | 1082 | if(filename.find(" ",0,TRUE) != -1 || filename.find("%20",0,TRUE) != -1) { |
1083 | QMessageBox::message("Note","Spaces in urls are not allowed."); | 1083 | QMessageBox::message("Note","Spaces in urls are not allowed."); |
1084 | return; | 1084 | return; |
1085 | } else { | 1085 | } else { |
1086 | qDebug("Selected filename is "+filename); | 1086 | qDebug("Selected filename is "+filename); |
1087 | if(filename.right(3) == "m3u") | 1087 | if(filename.right(3) == "m3u") |
1088 | readm3u( filename); | 1088 | readm3u( filename); |
1089 | else if(filename.right(3) == "pls") | 1089 | else if(filename.right(3) == "pls") |
1090 | readPls( filename); | 1090 | readPls( filename); |
1091 | else { | 1091 | else { |
1092 | DocLnk lnk; | 1092 | DocLnk lnk; |
1093 | 1093 | ||
1094 | lnk.setName(filename); //sets file name | 1094 | lnk.setName(filename); //sets file name |
1095 | if(filename.right(1) != "/" && filename.right(3) != "mp3" && filename.right(3) != "MP3") | 1095 | if(filename.right(1) != "/" && filename.right(3) != "mp3" && filename.right(3) != "MP3") |
1096 | filename += "/"; | 1096 | filename += "/"; |
1097 | lnk.setFile(filename); //sets File property | 1097 | lnk.setFile(filename); //sets File property |
1098 | 1098 | ||
1099 | lnk.setType("audio/x-mpegurl"); | 1099 | lnk.setType("audio/x-mpegurl"); |
1100 | lnk.setExec("opieplayer"); | 1100 | lnk.setExec("opieplayer"); |
1101 | lnk.setIcon("opieplayer/MPEGPlayer"); | 1101 | lnk.setIcon("opieplayer/MPEGPlayer"); |
1102 | 1102 | ||
1103 | if(!lnk.writeLink()) | 1103 | if(!lnk.writeLink()) |
1104 | qDebug("Writing doclink did not work"); | 1104 | qDebug("Writing doclink did not work"); |
1105 | d->selectedFiles->addToSelection( lnk); | 1105 | d->selectedFiles->addToSelection( lnk); |
1106 | // if(fileDlg2) | 1106 | // if(fileDlg2) |
1107 | // delete fileDlg2; | 1107 | // delete fileDlg2; |
1108 | } | 1108 | } |
1109 | } | 1109 | } |
1110 | } | 1110 | } |
1111 | if(fileDlg) | 1111 | if(fileDlg) |
1112 | delete fileDlg; | 1112 | delete fileDlg; |
1113 | } | 1113 | } |
1114 | 1114 | ||
1115 | void PlayListWidget::keyReleaseEvent( QKeyEvent *e) | 1115 | void PlayListWidget::keyReleaseEvent( QKeyEvent *e) |
1116 | { | 1116 | { |
1117 | switch ( e->key() ) { | 1117 | switch ( e->key() ) { |
1118 | ////////////////////////////// Zaurus keys | 1118 | ////////////////////////////// Zaurus keys |
1119 | case Key_F9: //activity | 1119 | case Key_F9: //activity |
1120 | // if(audioUI->isHidden()) | 1120 | // if(audioUI->isHidden()) |
1121 | // audioUI->showMaximized(); | 1121 | // audioUI->showMaximized(); |
1122 | break; | 1122 | break; |
1123 | case Key_F10: //contacts | 1123 | case Key_F10: //contacts |
1124 | // if( videoUI->isHidden()) | 1124 | // if( videoUI->isHidden()) |
1125 | // videoUI->showMaximized(); | 1125 | // videoUI->showMaximized(); |
1126 | break; | 1126 | break; |
1127 | case Key_F11: //menu | 1127 | case Key_F11: //menu |
1128 | break; | 1128 | break; |
1129 | case Key_F12: //home | 1129 | case Key_F12: //home |
1130 | // doBlank(); | 1130 | // doBlank(); |
1131 | break; | 1131 | break; |
1132 | case Key_F13: //mail | 1132 | case Key_F13: //mail |
1133 | // doUnblank(); | 1133 | // doUnblank(); |
1134 | break; | 1134 | break; |
1135 | case Key_Q: //add to playlist | 1135 | case Key_Q: //add to playlist |
1136 | qDebug("Add"); | 1136 | qDebug("Add"); |
1137 | addSelected(); | 1137 | addSelected(); |
1138 | break; | 1138 | break; |
1139 | case Key_R: //remove from playlist | 1139 | case Key_R: //remove from playlist |
1140 | removeSelected(); | 1140 | removeSelected(); |
1141 | break; | 1141 | break; |
1142 | // case Key_P: //play | 1142 | // case Key_P: //play |
1143 | // qDebug("Play"); | 1143 | // qDebug("Play"); |
1144 | // playSelected(); | 1144 | // playSelected(); |
1145 | // break; | 1145 | // break; |
1146 | case Key_Space: | 1146 | case Key_Space: |
1147 | qDebug("Play"); | 1147 | qDebug("Play"); |
1148 | // playSelected(); puh | 1148 | // playSelected(); puh |
1149 | break; | 1149 | break; |
1150 | case Key_1: | 1150 | case Key_1: |
1151 | tabWidget->setCurrentPage(0); | 1151 | tabWidget->setCurrentPage(0); |
1152 | break; | 1152 | break; |
1153 | case Key_2: | 1153 | case Key_2: |
1154 | tabWidget->setCurrentPage(1); | 1154 | tabWidget->setCurrentPage(1); |
1155 | break; | 1155 | break; |
1156 | case Key_3: | 1156 | case Key_3: |
1157 | tabWidget->setCurrentPage(2); | 1157 | tabWidget->setCurrentPage(2); |
1158 | break; | 1158 | break; |
1159 | case Key_4: | 1159 | case Key_4: |
1160 | tabWidget->setCurrentPage(3); | 1160 | tabWidget->setCurrentPage(3); |
1161 | break; | 1161 | break; |
1162 | case Key_Down: | ||
1163 | if ( !d->selectedFiles->next() ) | ||
1164 | d->selectedFiles->first(); | ||
1165 | |||
1166 | break; | ||
1167 | case Key_Up: | ||
1168 | if ( !d->selectedFiles->prev() ) | ||
1169 | d->selectedFiles->last(); | ||
1170 | |||
1171 | break; | ||
1172 | |||
1162 | } | 1173 | } |
1163 | } | 1174 | } |
1164 | 1175 | ||
1165 | void PlayListWidget::keyPressEvent( QKeyEvent *e) | 1176 | void PlayListWidget::keyPressEvent( QKeyEvent *e) |
1166 | { | 1177 | { |
1167 | // qDebug("Key press"); | 1178 | // qDebug("Key press"); |
1168 | // switch ( e->key() ) { | 1179 | // switch ( e->key() ) { |
1169 | // ////////////////////////////// Zaurus keys | 1180 | // ////////////////////////////// Zaurus keys |
1170 | // case Key_A: //add to playlist | 1181 | // case Key_A: //add to playlist |
1171 | // qDebug("Add"); | 1182 | // qDebug("Add"); |
1172 | // addSelected(); | 1183 | // addSelected(); |
1173 | // break; | 1184 | // break; |
1174 | // case Key_R: //remove from playlist | 1185 | // case Key_R: //remove from playlist |
1175 | // removeSelected(); | 1186 | // removeSelected(); |
1176 | // break; | 1187 | // break; |
1177 | // case Key_P: //play | 1188 | // case Key_P: //play |
1178 | // qDebug("Play"); | 1189 | // qDebug("Play"); |
1179 | // playSelected(); | 1190 | // playSelected(); |
1180 | // break; | 1191 | // break; |
1181 | // case Key_Space: | 1192 | // case Key_Space: |
1182 | // qDebug("Play"); | 1193 | // qDebug("Play"); |
1183 | // playSelected(); | 1194 | // playSelected(); |
1184 | // break; | 1195 | // break; |
1185 | // } | 1196 | // } |
1186 | } | 1197 | } |
1187 | 1198 | ||
1188 | void PlayListWidget::doBlank() { | 1199 | void PlayListWidget::doBlank() { |
1189 | qDebug("do blanking"); | 1200 | qDebug("do blanking"); |
1190 | fd=open("/dev/fb0",O_RDWR); | 1201 | fd=open("/dev/fb0",O_RDWR); |
1191 | if (fd != -1) { | 1202 | if (fd != -1) { |
1192 | ioctl(fd,FBIOBLANK,1); | 1203 | ioctl(fd,FBIOBLANK,1); |
1193 | // close(fd); | 1204 | // close(fd); |
1194 | } | 1205 | } |
1195 | } | 1206 | } |
1196 | 1207 | ||
1197 | void PlayListWidget::doUnblank() { | 1208 | void PlayListWidget::doUnblank() { |
1198 | // this crashes opieplayer with a segfault | 1209 | // this crashes opieplayer with a segfault |
1199 | // int fd; | 1210 | // int fd; |
1200 | // fd=open("/dev/fb0",O_RDWR); | 1211 | // fd=open("/dev/fb0",O_RDWR); |
1201 | qDebug("do unblanking"); | 1212 | qDebug("do unblanking"); |
1202 | if (fd != -1) { | 1213 | if (fd != -1) { |
1203 | ioctl(fd,FBIOBLANK,0); | 1214 | ioctl(fd,FBIOBLANK,0); |
1204 | close(fd); | 1215 | close(fd); |
1205 | } | 1216 | } |
1206 | QCopEnvelope h("QPE/System", "setBacklight(int)"); | 1217 | QCopEnvelope h("QPE/System", "setBacklight(int)"); |
1207 | h <<-3;// v[1]; // -3 Force on | 1218 | h <<-3;// v[1]; // -3 Force on |
1208 | } | 1219 | } |
1209 | 1220 | ||
1210 | void PlayListWidget::readm3u(const QString &filename) { | 1221 | void PlayListWidget::readm3u(const QString &filename) { |
1211 | 1222 | ||
1212 | qDebug("m3u filename is "+filename); | 1223 | qDebug("m3u filename is "+filename); |
1213 | QFile f(filename); | 1224 | QFile f(filename); |
1214 | 1225 | ||
1215 | if(f.open(IO_ReadOnly)) { | 1226 | if(f.open(IO_ReadOnly)) { |
1216 | QTextStream t(&f); | 1227 | QTextStream t(&f); |
1217 | QString s;//, first, second; | 1228 | QString s;//, first, second; |
1218 | int i=0; | 1229 | int i=0; |
1219 | while ( !t.atEnd()) { | 1230 | while ( !t.atEnd()) { |
1220 | // Lview->insertLine(t.readLine(),-1); | 1231 | // Lview->insertLine(t.readLine(),-1); |
1221 | s=t.readLine(); | 1232 | s=t.readLine(); |
1222 | if(s.find(" ",0,TRUE) != -1 || s.find("%20",0,TRUE) != -1) { | 1233 | if(s.find(" ",0,TRUE) != -1 || s.find("%20",0,TRUE) != -1) { |
1223 | QMessageBox::message("Note","Spaces in urls are not allowed."); | 1234 | QMessageBox::message("Note","Spaces in urls are not allowed."); |
1224 | } | 1235 | } |
1225 | else if(s.find("#",0,TRUE) == -1) { | 1236 | else if(s.find("#",0,TRUE) == -1) { |
1226 | if(s.find(" ",0,TRUE) == -1) { // not sure if this is neede since cf uses vfat | 1237 | if(s.find(" ",0,TRUE) == -1) { // not sure if this is neede since cf uses vfat |
1227 | if(s.left(2) == "E:" || s.left(2) == "P:") { | 1238 | if(s.left(2) == "E:" || s.left(2) == "P:") { |
1228 | s=s.right(s.length()-2); | 1239 | s=s.right(s.length()-2); |
1229 | DocLnk lnk( s ); | 1240 | DocLnk lnk( s ); |
1230 | QFileInfo f(s); | 1241 | QFileInfo f(s); |
1231 | QString name = f.baseName(); | 1242 | QString name = f.baseName(); |
1232 | name = name.right(name.length()-name.findRev("\\",-1,TRUE)-1); | 1243 | name = name.right(name.length()-name.findRev("\\",-1,TRUE)-1); |
1233 | lnk.setName( name); | 1244 | lnk.setName( name); |
1234 | s=s.replace( QRegExp("\\"),"/"); | 1245 | s=s.replace( QRegExp("\\"),"/"); |
1235 | lnk.setFile( s); | 1246 | lnk.setFile( s); |
1236 | lnk.writeLink(); | 1247 | lnk.writeLink(); |
1237 | // lnk.setIcon(opieplayer/MPEGPlayer); | 1248 | // lnk.setIcon(opieplayer/MPEGPlayer); |
1238 | qDebug("add "+name); | 1249 | qDebug("add "+name); |
1239 | d->selectedFiles->addToSelection( lnk); | 1250 | d->selectedFiles->addToSelection( lnk); |
1240 | } else { // is url | 1251 | } else { // is url |
1241 | 1252 | ||
1242 | s.replace(QRegExp("%20")," "); | 1253 | s.replace(QRegExp("%20")," "); |
1243 | DocLnk lnk( s); | 1254 | DocLnk lnk( s); |
1244 | QString name; | 1255 | QString name; |
1245 | if(name.left(4)=="http") | 1256 | if(name.left(4)=="http") |
1246 | name = s.right( s.length() - 7); | 1257 | name = s.right( s.length() - 7); |
1247 | else | 1258 | else |
1248 | name=s; | 1259 | name=s; |
1249 | // name = name.right(name.length()-name.findRev("\\",-1,TRUE)-1); | 1260 | // name = name.right(name.length()-name.findRev("\\",-1,TRUE)-1); |
1250 | lnk.setName(name); | 1261 | lnk.setName(name); |
1251 | if(s.at(s.length()-4) == '.') | 1262 | if(s.at(s.length()-4) == '.') |
1252 | lnk.setFile( s); | 1263 | lnk.setFile( s); |
1253 | else | 1264 | else |
1254 | lnk.setFile( s+"/"); | 1265 | lnk.setFile( s+"/"); |
1255 | // lnk.setFile( filename); | 1266 | // lnk.setFile( filename); |
1256 | // lnk.setComment( s+"/"); | 1267 | // lnk.setComment( s+"/"); |
1257 | lnk.setType("audio/x-mpegurl"); | 1268 | lnk.setType("audio/x-mpegurl"); |
1258 | lnk.writeLink(); | 1269 | lnk.writeLink(); |
1259 | // lnk.setIcon( "opieplayer/MPEGPlayer"); | 1270 | // lnk.setIcon( "opieplayer/MPEGPlayer"); |
1260 | // qDebug("add "+s); | 1271 | // qDebug("add "+s); |
1261 | d->selectedFiles->addToSelection( lnk); | 1272 | d->selectedFiles->addToSelection( lnk); |
1262 | } | 1273 | } |
1263 | i++; | 1274 | i++; |
1264 | } | 1275 | } |
1265 | } | 1276 | } |
1266 | } | 1277 | } |
1267 | } | 1278 | } |
1268 | f.close(); | 1279 | f.close(); |
1269 | } | 1280 | } |
1270 | 1281 | ||
1271 | void PlayListWidget::writem3u() { | 1282 | void PlayListWidget::writem3u() { |
1272 | 1283 | ||
1273 | InputDialog *fileDlg; | 1284 | InputDialog *fileDlg; |
1274 | fileDlg = new InputDialog(this,tr("Save m3u Playlist "),TRUE, 0); | 1285 | fileDlg = new InputDialog(this,tr("Save m3u Playlist "),TRUE, 0); |
1275 | fileDlg->exec(); | 1286 | fileDlg->exec(); |
1276 | QString filename,list; | 1287 | QString filename,list; |
1277 | if( fileDlg->result() == 1 ) { | 1288 | if( fileDlg->result() == 1 ) { |
1278 | filename = fileDlg->LineEdit1->text(); | 1289 | filename = fileDlg->LineEdit1->text(); |
1279 | qDebug(filename); | 1290 | qDebug(filename); |
1280 | int noOfFiles = 0; | 1291 | int noOfFiles = 0; |
1281 | d->selectedFiles->first(); | 1292 | d->selectedFiles->first(); |
1282 | do { | 1293 | do { |
1283 | // we dont check for existance because of url's | 1294 | // we dont check for existance because of url's |
1284 | // qDebug(d->selectedFiles->current()->file()); | 1295 | // qDebug(d->selectedFiles->current()->file()); |
1285 | list += d->selectedFiles->current()->file()+"\n"; | 1296 | list += d->selectedFiles->current()->file()+"\n"; |
1286 | noOfFiles++; | 1297 | noOfFiles++; |
1287 | } | 1298 | } |
1288 | while ( d->selectedFiles->next() ); | 1299 | while ( d->selectedFiles->next() ); |
1289 | qDebug(list); | 1300 | qDebug(list); |
1290 | if(filename.left(1) != "/") | 1301 | if(filename.left(1) != "/") |
1291 | filename=QPEApplication::documentDir()+"/"+filename; | 1302 | filename=QPEApplication::documentDir()+"/"+filename; |
1292 | if(filename.right(3) != "m3u") | 1303 | if(filename.right(3) != "m3u") |
1293 | filename=filename+".m3u"; | 1304 | filename=filename+".m3u"; |
1294 | 1305 | ||
1295 | QFile f(filename); | 1306 | QFile f(filename); |
1296 | f.open(IO_WriteOnly); | 1307 | f.open(IO_WriteOnly); |
1297 | f.writeBlock(list, list.length()); | 1308 | f.writeBlock(list, list.length()); |
1298 | f.close(); | 1309 | f.close(); |
1299 | } | 1310 | } |
1300 | if(fileDlg) delete fileDlg; | 1311 | if(fileDlg) delete fileDlg; |
1301 | } | 1312 | } |
1302 | 1313 | ||
1303 | void PlayListWidget::readPls(const QString &filename) { | 1314 | void PlayListWidget::readPls(const QString &filename) { |
1304 | 1315 | ||
1305 | qDebug("pls filename is "+filename); | 1316 | qDebug("pls filename is "+filename); |
1306 | QFile f(filename); | 1317 | QFile f(filename); |
1307 | 1318 | ||
1308 | if(f.open(IO_ReadOnly)) { | 1319 | if(f.open(IO_ReadOnly)) { |
1309 | QTextStream t(&f); | 1320 | QTextStream t(&f); |
1310 | QString s;//, first, second; | 1321 | QString s;//, first, second; |
1311 | int i=0; | 1322 | int i=0; |
1312 | while ( !t.atEnd()) { | 1323 | while ( !t.atEnd()) { |
1313 | s=t.readLine(); | 1324 | s=t.readLine(); |
1314 | if(s.left(4) == "File") { | 1325 | if(s.left(4) == "File") { |
1315 | s=s.right(s.length() - 6); | 1326 | s=s.right(s.length() - 6); |
1316 | s.replace(QRegExp("%20")," "); | 1327 | s.replace(QRegExp("%20")," "); |
1317 | qDebug("adding "+s+" to playlist"); | 1328 | qDebug("adding "+s+" to playlist"); |
1318 | // numberofentries=2 | 1329 | // numberofentries=2 |
1319 | // File1=http | 1330 | // File1=http |
1320 | // Title | 1331 | // Title |
1321 | // Length | 1332 | // Length |
1322 | // Version | 1333 | // Version |
1323 | // File2=http | 1334 | // File2=http |
1324 | 1335 | ||
1325 | s=s.replace( QRegExp("\\"),"/"); | 1336 | s=s.replace( QRegExp("\\"),"/"); |
1326 | DocLnk lnk( s ); | 1337 | DocLnk lnk( s ); |
1327 | QFileInfo f(s); | 1338 | QFileInfo f(s); |
1328 | QString name = f.baseName(); | 1339 | QString name = f.baseName(); |
1329 | if(name.left(4)=="http") | 1340 | if(name.left(4)=="http") |
1330 | name = s.right( s.length() - 7); | 1341 | name = s.right( s.length() - 7); |
1331 | else | 1342 | else |
1332 | name=s; | 1343 | name=s; |
1333 | name = name.right(name.length()-name.findRev("\\",-1,TRUE)-1); | 1344 | name = name.right(name.length()-name.findRev("\\",-1,TRUE)-1); |
1334 | // QFileInfo f(s); | 1345 | // QFileInfo f(s); |
1335 | // QString name = f.baseName(); | 1346 | // QString name = f.baseName(); |
1336 | // name = name.left(name.length()-4); | 1347 | // name = name.left(name.length()-4); |
1337 | // name = name.right(name.findRev("/",0,TRUE)); | 1348 | // name = name.right(name.findRev("/",0,TRUE)); |
1338 | lnk.setName( name); | 1349 | lnk.setName( name); |
1339 | if(s.at(s.length()-4) == '.') | 1350 | if(s.at(s.length()-4) == '.') // if this is probably a file |
1340 | lnk.setFile( s); | 1351 | lnk.setFile( s); |
1341 | else { | 1352 | else { //if its a url |
1342 | if( name.right(1).find('/') == -1) | 1353 | if( name.right(1).find('/') == -1) |
1343 | s+="/"; | 1354 | s+="/"; |
1344 | // if(s.right(1) != '/') | 1355 | lnk.setFile( s); |
1345 | lnk.setFile( s); | ||
1346 | |||
1347 | } | 1356 | } |
1348 | lnk.setType("audio/x-mpegurl"); | 1357 | lnk.setType("audio/x-mpegurl"); |
1349 | 1358 | ||
1350 | qDebug("DocLnk add "+name); | 1359 | qDebug("DocLnk add "+name); |
1351 | d->selectedFiles->addToSelection( lnk); | 1360 | d->selectedFiles->addToSelection( lnk); |
1352 | } | 1361 | } |
1353 | } | 1362 | } |
1354 | i++; | 1363 | i++; |
1355 | } | 1364 | } |
1356 | } | 1365 | } |
1357 | 1366 | ||