1
0

exportdialogs.cpp 5.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193
  1. #include "exportdialogs.h"
  2. #include <QIntValidator>
  3. #include <QFileDialog>
  4. #include <QMessageBox>
  5. #include "Mandel.h"
  6. #include "VideoStream.h"
  7. static bool exportVideo(const ExportVideoInfo& evi);
  8. ExportImageDialog::ExportImageDialog(QWidget* parent) :
  9. QDialog{ parent }
  10. {
  11. eid.setupUi(this);
  12. this->adjustSize();
  13. eid.maxIterations->setValidator(new QIntValidator(1, 1000000000, this));
  14. eid.imgWidth->setValidator(new QIntValidator(1, 10000000, this));
  15. eid.imgHeight->setValidator(new QIntValidator(1, 10000000, this));
  16. }
  17. int ExportImageDialog::getMaxIterations(void) const
  18. {
  19. return std::stoi(eid.maxIterations->text().toStdString());
  20. }
  21. int ExportImageDialog::getWidth(void) const
  22. {
  23. return std::stoi(eid.imgWidth->text().toStdString());
  24. }
  25. int ExportImageDialog::getHeight(void) const
  26. {
  27. return std::stoi(eid.imgHeight->text().toStdString());
  28. }
  29. QString ExportImageDialog::getPath(void) const
  30. {
  31. return eid.savePath->text();
  32. }
  33. void ExportImageDialog::on_pushButton_clicked()
  34. {
  35. QString saveAs = QFileDialog::getSaveFileName(this,
  36. tr("Save exported image"), "",
  37. tr("PNG image (*.png);;JPEG image (*.jpg);;All Files (*)"));
  38. if(!saveAs.isEmpty() && !saveAs.isNull())
  39. eid.savePath->setText(saveAs);
  40. this->repaint();
  41. }
  42. void ExportImageDialog::on_buttonBox_accepted()
  43. {
  44. if (eid.savePath->text() == "") {
  45. QMessageBox msgBox;
  46. msgBox.setText("Please specify a path.");
  47. msgBox.show();
  48. msgBox.exec();
  49. reject();
  50. }
  51. }
  52. ExportVideoDialog::ExportVideoDialog(QWidget* parent, const ExportVideoInfo& evi) :
  53. QDialog{ parent },
  54. evi{ evi }
  55. {
  56. evd.setupUi(this);
  57. this->adjustSize();
  58. evd.maxIterations->setValidator(new QIntValidator(1, 1000000000, this));
  59. evd.vidWidth->setValidator(new QIntValidator(1, 10000000, this));
  60. evd.vidHeight->setValidator(new QIntValidator(1, 10000000, this));
  61. evd.bitrate->setValidator(new QIntValidator(1, 10000000, this));
  62. evd.startX->setText(QString::number(evi.start.x));
  63. evd.startY->setText(QString::number(evi.start.y));
  64. evd.startW->setText(QString::number(evi.start.width));
  65. evd.startH->setText(QString::number(evi.start.height));
  66. evd.endX->setText(QString::number(evi.end.x));
  67. evd.endY->setText(QString::number(evi.end.y));
  68. evd.endW->setText(QString::number(evi.end.width));
  69. evd.endH->setText(QString::number(evi.end.height));
  70. auto presets = {
  71. "ultrafast",
  72. "superfast",
  73. "veryfast",
  74. "faster",
  75. "fast",
  76. "medium",
  77. "slow",
  78. "slower",
  79. "veryslow",
  80. };
  81. for (auto& preset : presets) {
  82. evd.encodingPresetBox->addItem(preset);
  83. }
  84. }
  85. const ExportVideoInfo& ExportVideoDialog::getExportVideoInfo(void) const
  86. {
  87. return evi;
  88. }
  89. void ExportVideoDialog::on_buttonBox_accepted()
  90. {
  91. if (evd.savePath->text() == "") {
  92. QMessageBox* msgBox = new QMessageBox;
  93. msgBox->setText("Please specify a path.");
  94. msgBox->exec();
  95. emit reject();
  96. }
  97. evi.path = evd.savePath->text().toStdString();
  98. evi.width = evd.vidWidth->text().toInt();
  99. evi.height = evd.vidHeight->text().toInt();
  100. evi.maxIterations = evd.maxIterations->text().toInt();
  101. evi.bitrate = evd.bitrate->text().toInt();
  102. evi.preset = evd.encodingPresetBox->currentText().toStdString();
  103. /*evi.start = mnd::MandelViewport {
  104. evd.startX->text().toDouble(),
  105. evd.startY->text().toDouble(),
  106. evd.startW->text().toDouble(),
  107. evd.startH->text().toDouble(),
  108. };
  109. evi.end = mnd::MandelViewport {
  110. evd.endX->text().toDouble(),
  111. evd.endY->text().toDouble(),
  112. evd.endW->text().toDouble(),
  113. evd.endH->text().toDouble(),
  114. };*/
  115. evi.start.adjustAspectRatio(evi.width, evi.height);
  116. evi.end.adjustAspectRatio(evi.width, evi.height);
  117. MandelVideoGenerator mvg(evi);
  118. mvg.generate();
  119. //if (exportVideo(evi)) {
  120. QMessageBox* msgBox = new QMessageBox;
  121. msgBox->setText("Video successfully exported.");
  122. msgBox->exec();
  123. //}
  124. }
  125. void ExportVideoDialog::on_pushButton_clicked()
  126. {
  127. QString saveAs = QFileDialog::getSaveFileName(this,
  128. tr("Save exported image"), "",
  129. tr("AVI video (*.avi);;MP4 video (*.mp4);;All Files (*)"));
  130. evd.savePath->setText(saveAs);
  131. this->repaint();
  132. }
  133. bool exportVideo(const ExportVideoInfo& evi)
  134. {
  135. auto lerp = [] (double a, double b, double v) {
  136. return a * (1 - v) + b * v;
  137. };
  138. mnd::MandelContext ctxt = mnd::initializeContext();
  139. mnd::Generator& gen = *ctxt.getDevices()[0].getGeneratorFloat();
  140. mnd::MandelInfo mi;
  141. mi.bWidth = evi.width;
  142. mi.bHeight = evi.height;
  143. mi.maxIter = evi.maxIterations;
  144. VideoStream vs(evi.width, evi.height, evi.path, evi.bitrate, evi.preset.c_str());
  145. double x = evi.end.x + evi.end.width / 2;
  146. double y = evi.end.y + evi.end.height / 2;
  147. double w = evi.start.width;
  148. double h = evi.start.height;
  149. while(w > evi.end.width || h > evi.end.height) {
  150. mi.view = mnd::MandelViewport{ x - w/2, y - h/2, w, h };
  151. Bitmap<float> raw{ evi.width, evi.height };
  152. gen.generate(mi, raw.pixels.get());
  153. vs.addFrame(raw.map<RGBColor>([] (float x) { return
  154. RGBColor{ uint8_t(::sin(x / 100) * 127 + 127), uint8_t(::sin(x / 213) * 127 + 127), uint8_t(::cos(x / 173) * 127 + 127) };
  155. }));
  156. w *= 0.975;
  157. h *= 0.975;
  158. }
  159. return true;
  160. }