comparison layer/ImageLayer.cpp @ 706:97ea68f62c1f imaf_enc

Merge from default branch
author Chris Cannam
date Thu, 05 Dec 2013 09:47:02 +0000
parents 1a0dfcbffaf1
children 1d526ba11a24
comparison
equal deleted inserted replaced
678:26c5f7fd4807 706:97ea68f62c1f
161 if (x >= px && x < px + width) { 161 if (x >= px && x < px + width) {
162 rv.insert(p); 162 rv.insert(p);
163 } 163 }
164 } 164 }
165 165
166 // std::cerr << rv.size() << " point(s)" << std::endl; 166 // cerr << rv.size() << " point(s)" << endl;
167 167
168 return rv; 168 return rv;
169 } 169 }
170 170
171 QString 171 QString
498 //!!! how to reap no-longer-used images? 498 //!!! how to reap no-longer-used images?
499 499
500 bool 500 bool
501 ImageLayer::getImageOriginalSize(QString name, QSize &size) const 501 ImageLayer::getImageOriginalSize(QString name, QSize &size) const
502 { 502 {
503 // std::cerr << "getImageOriginalSize: \"" << name << "\"" << std::endl; 503 // cerr << "getImageOriginalSize: \"" << name << "\"" << endl;
504 504
505 QMutexLocker locker(&m_imageMapMutex); 505 QMutexLocker locker(&m_imageMapMutex);
506 if (m_images.find(name) == m_images.end()) { 506 if (m_images.find(name) == m_images.end()) {
507 // std::cerr << "don't have, trying to open local" << std::endl; 507 // cerr << "don't have, trying to open local" << endl;
508 m_images[name] = QImage(getLocalFilename(name)); 508 m_images[name] = QImage(getLocalFilename(name));
509 } 509 }
510 if (m_images[name].isNull()) { 510 if (m_images[name].isNull()) {
511 // std::cerr << "null image" << std::endl; 511 // cerr << "null image" << endl;
512 return false; 512 return false;
513 } else { 513 } else {
514 size = m_images[name].size(); 514 size = m_images[name].size();
515 return true; 515 return true;
516 } 516 }
527 if (!m_scaled[v][name].isNull() && 527 if (!m_scaled[v][name].isNull() &&
528 ((m_scaled[v][name].width() == maxSize.width() && 528 ((m_scaled[v][name].width() == maxSize.width() &&
529 m_scaled[v][name].height() <= maxSize.height()) || 529 m_scaled[v][name].height() <= maxSize.height()) ||
530 (m_scaled[v][name].width() <= maxSize.width() && 530 (m_scaled[v][name].width() <= maxSize.width() &&
531 m_scaled[v][name].height() == maxSize.height()))) { 531 m_scaled[v][name].height() == maxSize.height()))) {
532 // std::cerr << "cache hit" << std::endl; 532 // cerr << "cache hit" << endl;
533 return m_scaled[v][name]; 533 return m_scaled[v][name];
534 } 534 }
535 535
536 QMutexLocker locker(&m_imageMapMutex); 536 QMutexLocker locker(&m_imageMapMutex);
537 537
538 if (m_images.find(name) == m_images.end()) { 538 if (m_images.find(name) == m_images.end()) {
539 m_images[name] = QImage(getLocalFilename(name)); 539 m_images[name] = QImage(getLocalFilename(name));
540 } 540 }
541 541
542 if (m_images[name].isNull()) { 542 if (m_images[name].isNull()) {
543 // std::cerr << "null image" << std::endl; 543 // cerr << "null image" << endl;
544 m_scaled[v][name] = QImage(); 544 m_scaled[v][name] = QImage();
545 } else if (m_images[name].width() <= maxSize.width() && 545 } else if (m_images[name].width() <= maxSize.width() &&
546 m_images[name].height() <= maxSize.height()) { 546 m_images[name].height() <= maxSize.height()) {
547 m_scaled[v][name] = m_images[name]; 547 m_scaled[v][name] = m_images[name];
548 } else { 548 } else {
625 bool 625 bool
626 ImageLayer::addImage(long frame, QString url) 626 ImageLayer::addImage(long frame, QString url)
627 { 627 {
628 QImage image(getLocalFilename(url)); 628 QImage image(getLocalFilename(url));
629 if (image.isNull()) { 629 if (image.isNull()) {
630 std::cerr << "Failed to open image from url \"" << url << "\" (local filename \"" << getLocalFilename(url) << "\"" << std::endl; 630 cerr << "Failed to open image from url \"" << url << "\" (local filename \"" << getLocalFilename(url) << "\"" << endl;
631 delete m_fileSources[url]; 631 delete m_fileSources[url];
632 m_fileSources.erase(url); 632 m_fileSources.erase(url);
633 return false; 633 return false;
634 } 634 }
635 635
913 } 913 }
914 914
915 ProgressDialog dialog(tr("Opening image URL..."), true, 2000); 915 ProgressDialog dialog(tr("Opening image URL..."), true, 2000);
916 FileSource *rf = new FileSource(img, &dialog); 916 FileSource *rf = new FileSource(img, &dialog);
917 if (rf->isOK()) { 917 if (rf->isOK()) {
918 std::cerr << "ok, adding it (local filename = " << rf->getLocalFilename() << ")" << std::endl; 918 cerr << "ok, adding it (local filename = " << rf->getLocalFilename() << ")" << endl;
919 m_fileSources[img] = rf; 919 m_fileSources[img] = rf;
920 connect(rf, SIGNAL(ready()), this, SLOT(fileSourceReady())); 920 connect(rf, SIGNAL(ready()), this, SLOT(fileSourceReady()));
921 } else { 921 } else {
922 delete rf; 922 delete rf;
923 } 923 }
946 QString img; 946 QString img;
947 for (FileSourceMap::const_iterator i = m_fileSources.begin(); 947 for (FileSourceMap::const_iterator i = m_fileSources.begin();
948 i != m_fileSources.end(); ++i) { 948 i != m_fileSources.end(); ++i) {
949 if (i->second == rf) { 949 if (i->second == rf) {
950 img = i->first; 950 img = i->first;
951 // std::cerr << "it's image \"" << img << "\"" << std::endl; 951 // cerr << "it's image \"" << img << "\"" << endl;
952 break; 952 break;
953 } 953 }
954 } 954 }
955 if (img == "") return; 955 if (img == "") return;
956 956