exportdialogs.cpp 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174
  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.startX->setText(QString::number(evi.start.x));
  62. evd.startY->setText(QString::number(evi.start.y));
  63. evd.startW->setText(QString::number(evi.start.width));
  64. evd.startH->setText(QString::number(evi.start.height));
  65. evd.endX->setText(QString::number(evi.end.x));
  66. evd.endY->setText(QString::number(evi.end.y));
  67. evd.endW->setText(QString::number(evi.end.width));
  68. evd.endH->setText(QString::number(evi.end.height));
  69. }
  70. const ExportVideoInfo& ExportVideoDialog::getExportVideoInfo(void) const
  71. {
  72. return evi;
  73. }
  74. void ExportVideoDialog::on_buttonBox_accepted()
  75. {
  76. if (evd.savePath->text() == "") {
  77. QMessageBox* msgBox = new QMessageBox;
  78. msgBox->setText("Please specify a path.");
  79. msgBox->exec();
  80. emit reject();
  81. }
  82. evi.path = evd.savePath->text().toStdString();
  83. evi.width = evd.vidWidth->text().toInt();
  84. evi.height = evd.vidHeight->text().toInt();
  85. evi.maxIterations = evd.maxIterations->text().toInt();
  86. /*evi.start = mnd::MandelViewport {
  87. evd.startX->text().toDouble(),
  88. evd.startY->text().toDouble(),
  89. evd.startW->text().toDouble(),
  90. evd.startH->text().toDouble(),
  91. };
  92. evi.end = mnd::MandelViewport {
  93. evd.endX->text().toDouble(),
  94. evd.endY->text().toDouble(),
  95. evd.endW->text().toDouble(),
  96. evd.endH->text().toDouble(),
  97. };*/
  98. evi.start.adjustAspectRatio(evi.width, evi.height);
  99. evi.end.adjustAspectRatio(evi.width, evi.height);
  100. MandelVideoGenerator mvg(evi);
  101. mvg.generate();
  102. //if (exportVideo(evi)) {
  103. QMessageBox* msgBox = new QMessageBox;
  104. msgBox->setText("Video successfully exported.");
  105. msgBox->exec();
  106. //}
  107. }
  108. void ExportVideoDialog::on_pushButton_clicked()
  109. {
  110. QString saveAs = QFileDialog::getSaveFileName(this,
  111. tr("Save exported image"), "",
  112. tr("H264 video (*.h264);;All Files (*)"));
  113. evd.savePath->setText(saveAs);
  114. this->repaint();
  115. }
  116. bool exportVideo(const ExportVideoInfo& evi)
  117. {
  118. auto lerp = [] (double a, double b, double v) {
  119. return a * (1 - v) + b * v;
  120. };
  121. mnd::MandelContext ctxt = mnd::initializeContext();
  122. mnd::Generator& gen = *ctxt.getDevices()[0].getGeneratorFloat();
  123. mnd::MandelInfo mi;
  124. mi.bWidth = evi.width;
  125. mi.bHeight = evi.height;
  126. mi.maxIter = evi.maxIterations;
  127. VideoStream vs(evi.width, evi.height, evi.path);
  128. double x = evi.end.x + evi.end.width / 2;
  129. double y = evi.end.y + evi.end.height / 2;
  130. double w = evi.start.width;
  131. double h = evi.start.height;
  132. while(w > evi.end.width || h > evi.end.height) {
  133. mi.view = mnd::MandelViewport{ x - w/2, y - h/2, w, h };
  134. Bitmap<float> raw{ evi.width, evi.height };
  135. gen.generate(mi, raw.pixels.get());
  136. vs.addFrame(raw.map<RGBColor>([] (float x) { return
  137. RGBColor{ uint8_t(::sin(x / 100) * 127 + 127), uint8_t(::sin(x / 213) * 127 + 127), uint8_t(::cos(x / 173) * 127 + 127) };
  138. }));
  139. w *= 0.975;
  140. h *= 0.975;
  141. }
  142. return true;
  143. }