retina rendering of layout fine. rulers and other bitmap objects not obeying retina dpi

This commit is contained in:
Thomas Ferreira de Lima 2018-03-15 14:37:38 -04:00
parent 53bc8e97fe
commit b6ec5b7c0d
2 changed files with 9 additions and 8 deletions

View File

@ -584,7 +584,7 @@ fi
echo "Running build ($MAKE_PRG $MAKE_OPT all) .." echo "Running build ($MAKE_PRG $MAKE_OPT all) .."
cd $BUILD cd $BUILD
$MAKE_PRG $MAKE_OPT || exit $MAKE_PRG $MAKE_OPT || exit 1
cd $CURR_DIR cd $CURR_DIR
echo "" echo ""

View File

@ -469,7 +469,7 @@ LayoutCanvas::prepare_drawing ()
{ {
if (m_need_redraw) { if (m_need_redraw) {
BitmapViewObjectCanvas::set_size (m_viewport_l.width (), m_viewport_l.height (), 1.0 / double (m_oversampling)); BitmapViewObjectCanvas::set_size (m_viewport_l.width (), m_viewport_l.height (), 1.0 / double (m_oversampling) * 2);
if (! mp_image || if (! mp_image ||
(unsigned int) mp_image->width () != m_viewport_l.width () || (unsigned int) mp_image->width () != m_viewport_l.width () ||
@ -506,7 +506,7 @@ LayoutCanvas::prepare_drawing ()
++c; ++c;
} }
mp_redraw_thread->commit (m_layers, m_viewport_l, 1.0 / double (m_oversampling)); mp_redraw_thread->commit (m_layers, m_viewport_l, 1.0 / double (m_oversampling) * 2);
if (tl::verbosity () >= 20) { if (tl::verbosity () >= 20) {
tl::info << "Restored image from cache"; tl::info << "Restored image from cache";
@ -556,7 +556,7 @@ LayoutCanvas::prepare_drawing ()
} }
if (m_redraw_clearing) { if (m_redraw_clearing) {
mp_redraw_thread->start (mp_view->synchronous () ? 0 : mp_view->drawing_workers (), m_layers, m_viewport_l, 1.0 / double (m_oversampling), m_redraw_force_update); mp_redraw_thread->start (mp_view->synchronous () ? 0 : mp_view->drawing_workers (), m_layers, m_viewport_l, 1.0 / double (m_oversampling) * 2, m_redraw_force_update);
} else { } else {
mp_redraw_thread->restart (m_need_redraw_layer); mp_redraw_thread->restart (m_need_redraw_layer);
} }
@ -668,7 +668,7 @@ LayoutCanvas::paintEvent (QPaintEvent *)
if (m_oversampling == 1) { if (m_oversampling == 1) {
*mp_pixmap = QPixmap::fromImage (full_image); // Qt 4.6.0 workaround *mp_pixmap = QPixmap::fromImage (full_image); // Qt 4.6.0 workaround
} else { } else {
QImage subsampled_image (m_viewport.width (), m_viewport.height (), mp_image->format ()); QImage subsampled_image (m_viewport.width () * 2, m_viewport.height () * 2, mp_image->format ());
subsampled_image.setDevicePixelRatio(2.0); subsampled_image.setDevicePixelRatio(2.0);
subsample (full_image, subsampled_image, m_oversampling); subsample (full_image, subsampled_image, m_oversampling);
*mp_pixmap = QPixmap::fromImage (subsampled_image); // Qt 4.6.0 workaround *mp_pixmap = QPixmap::fromImage (subsampled_image); // Qt 4.6.0 workaround
@ -713,8 +713,9 @@ LayoutCanvas::paintEvent (QPaintEvent *)
if (fg_bitmap (n) != 0) { if (fg_bitmap (n) != 0) {
memset (p_data, 0, nbytes); memset (p_data, 0, nbytes);
bitmap_to_bitmap (fg_style (n), *fg_bitmap (n), p_data, m_viewport_l.width (), m_viewport_l.height (), dither_pattern (), line_styles ()); bitmap_to_bitmap (fg_style (n), *fg_bitmap (n), p_data, m_viewport_l.width (), m_viewport_l.height (), dither_pattern (), line_styles ());
subsample (p_data, m_viewport.width (), m_viewport.height (), m_oversampling); subsample (p_data, m_viewport.width (), m_viewport.height (), m_oversampling * 2);
QBitmap bitmap = QBitmap::fromData (QSize (m_viewport.width (), m_viewport.height ()), p_data); QBitmap bitmap = QBitmap::fromData (QSize (m_viewport.width (), m_viewport.height ()), p_data);
bitmap.setDevicePixelRatio(2.0);
painter.setPen (QRgb (fg_style (n).ormask ())); painter.setPen (QRgb (fg_style (n).ormask ()));
painter.drawPixmap (0, 0, bitmap); painter.drawPixmap (0, 0, bitmap);
} }
@ -733,7 +734,7 @@ LayoutCanvas::paintEvent (QPaintEvent *)
} }
// invert and subsample the mask // invert and subsample the mask
subsample (p_data, m_viewport.width (), m_viewport.height (), m_oversampling); subsample (p_data, m_viewport.width (), m_viewport.height (), m_oversampling * 2);
invert (p_data, m_viewport.width (), m_viewport.height ()); invert (p_data, m_viewport.width (), m_viewport.height ());
// create the mask // create the mask
@ -753,7 +754,7 @@ LayoutCanvas::paintEvent (QPaintEvent *)
if (fg_bitmap (n) != 0) { if (fg_bitmap (n) != 0) {
memset (p_data, 0, nbytes); memset (p_data, 0, nbytes);
bitmap_to_bitmap (fg_style (n), *fg_bitmap (n), p_data, m_viewport_l.width (), m_viewport_l.height (), dither_pattern ()); bitmap_to_bitmap (fg_style (n), *fg_bitmap (n), p_data, m_viewport_l.width (), m_viewport_l.height (), dither_pattern ());
subsample (p_data, m_viewport.width (), m_viewport.height (), m_oversampling); subsample (p_data, m_viewport.width (), m_viewport.height (), m_oversampling * 2);
QBitmap bitmap = QBitmap::fromData (QSize (m_viewport.width (), m_viewport.height ()), p_data); QBitmap bitmap = QBitmap::fromData (QSize (m_viewport.width (), m_viewport.height ()), p_data);
painter.setPen (QRgb (fg_style (n).ormask ())); painter.setPen (QRgb (fg_style (n).ormask ()));
painter.drawPixmap (0, 0, bitmap); painter.drawPixmap (0, 0, bitmap);