Bug 348172

Summary: Scaling options missing in print dialog
Product: [Applications] okular Reporter: Pascal Niklaus <pascal+kde>
Component: printingAssignee: Okular developers <okular-devel>
Status: RESOLVED FIXED    
Severity: normal CC: aacid, dollinger.florian, eherenz, elgaard, energie.mc2, fabrice.salvaire, fxjaeckel, h.lorch, kai_m, m.bosch.sau, m.weghorn, maql.nju, matthewtrescott, molletts, MurzNN, m_105, nate, oliver.sander, rail.bird, sergio.callegari, simonandric5, tim.eberhardt, truart
Priority: NOR Keywords: usability
Version: 0.21.3   
Target Milestone: ---   
Platform: Other   
OS: Linux   
Latest Commit: Version Fixed In: 19.04.0
Sentry Crash Report:
Attachments: kprinter screen shot

Description Pascal Niklaus 2015-05-24 05:32:46 UTC
This relates to https://bugs.kde.org/show_bug.cgi?id=347631. I now resubmit two separate bug reports as requested.

I am not sure whether it is related to okular or QPrinter.

The print dialogue lacks options to either
1) shrink PDF pages to paper size
2) enlarge to fit paper size 
3) print at 100% scale. 

Reasons:

1) and 2): When printing text documents, one often wants to use the entire page area. Otherwise, it will be impossible to print content that is much smaller or larger than the printer's paper size.

3)  Some documents need to be printed at 100% scale (e.g. technical drawings with defined scale). 

These options were present in KPrinter4, but "disappeared" from KDE5.

Reproducible: Always

Steps to Reproduce:
Does not apply



I classify this as a bug, because 

1) as a result, it is impossible to print some documents in a usable way, which IMO is a core functionality of a PDF viewer

2) From a user point of view, this seems like a regression in terms of feature set available. KDE4 provided these options.
Comment 1 Albert Astals Cid 2015-05-25 18:15:52 UTC
> 2) From a user point of view, this seems like a regression in terms of feature set available. KDE4 provided these options.

What?
Comment 2 Pascal Niklaus 2015-05-25 19:30:39 UTC
Created attachment 92818 [details]
kprinter screen shot

These options...
Comment 3 Albert Astals Cid 2015-05-25 19:51:24 UTC
Yes kprinter4 has those features and you can still use it, no?
I'm a bit confused by how it is "a regression"
Comment 4 Pascal Niklaus 2015-05-27 16:47:06 UTC
My point is that scaling is critical for many applications, and with the current standard print dialog I don't even know whether and how a document is scaled/printed.

Fortunately, I can still use kprinter4 if I really need to. But of course I can also use another pdf viewer, or Gnome, but that is not the point here, isn't it?
Comment 5 Niels Elgaard 2015-07-21 17:51:47 UTC
Yes, it is way easier to use e.g., evince, then you do not have to convert it to PS before printing.
Comment 6 Ian Schwarz 2016-10-11 23:20:42 UTC
*** This bug has been confirmed by popular vote. ***
Comment 7 Ian Schwarz 2016-10-11 23:25:02 UTC
qpdfview offers this option, which is why I keep it around. I, too, would like to be able to print borderless PDFs in okular without later realizing my printer has produced a useless, cut-off copy.
Comment 8 Florian Dollinger 2017-01-16 18:29:53 UTC
https://bugs.kde.org/show_bug.cgi?id=339176 and this one (https://bugs.kde.org/show_bug.cgi?id=348172) are possibly duplicates.
Comment 9 Christian Herenz 2017-01-25 22:35:38 UTC
Yes - this is a feature missing for people who have to print a lot of PDFs.  Most notably since sometimes the "automatic scale" that is determined to print a document is completely wrong.
Comment 10 Florian Dollinger 2017-01-25 23:32:19 UTC
The main problem is that the pdf is saved as a temporary .ps file (which isnt scaled), try the pdfprintpdf branch for now... that branch sends the .pdf directly to thd cups server (and also the -o fit-to-page option).

I am working on custom print dialog, the current one (qtprint) doesn't offer a "fit to page" option - you could add it at a new tab... but thats messy.
Comment 11 Albert Astals Cid 2017-01-26 22:00:44 UTC
A new dialog is a very bad idea.
Comment 12 Florian Dollinger 2017-01-26 23:20:14 UTC
and... why?
the qtprint dialog is - as mentioned - everything but useful, especially for printing multiple pages onto one sheet. that is because it doesn't distinguish between pages and sheets. the options are, furthermore, scattered over two windows (from which one is collabsible) and a lot of tabs everywhere.

adding another tab for multi-page-support wouldn't make it better in my eyes.

take a look at gnomes printdialog (e.g. in evince) - i am not a big gnome fan, but that one is really easy to use and offers everything you need.

the only reason i can think of, why it would be better to use the native one, is uniformity among kde applications.
Comment 13 Albert Astals Cid 2017-01-29 18:05:16 UTC
(In reply to Florian Dollinger from comment #12)
> and... why?

Because it needs to be maintained forever and is duplicated code.

> the qtprint dialog is - as mentioned - everything but useful, especially for
> printing multiple pages onto one sheet. that is because it doesn't
> distinguish between pages and sheets. the options are, furthermore,
> scattered over two windows (from which one is collabsible) and a lot of tabs
> everywhere.
> 
> adding another tab for multi-page-support wouldn't make it better in my eyes.
> 
> take a look at gnomes printdialog (e.g. in evince) - i am not a big gnome
> fan, but that one is really easy to use and offers everything you need.

So just improve the Qt dialog to be more like it?
Comment 14 Nate Graham 2017-09-29 00:55:27 UTC
*** Bug 375566 has been marked as a duplicate of this bug. ***
Comment 15 Nate Graham 2017-09-29 00:59:39 UTC
*** Bug 330820 has been marked as a duplicate of this bug. ***
Comment 16 Kai Maerzhaeuser 2017-11-26 12:26:17 UTC
Bug 336617 is closely related.
Okular is unusable for printing as long as disabling automatic scaling is not possible.
Comment 17 Oliver Sander 2017-11-26 19:28:39 UTC
The requested options are implemented in

  https://phabricator.kde.org/D7962

which in turn depends on

  https://phabricator.kde.org/D7949

Unfortunately, there is a reason why these patches are not currently in the okular git.  They depend on the poppler 'Arthur' backend, which is missing some features.  Therefore, if you want to try this out:
- get a very(!) new poppler
- apply all Arthur-related patches in the poppler bugtracker
- be aware that, depending on what kind of documents you want to print, your mileage can still vary.
Comment 18 Nate Graham 2018-05-08 17:18:12 UTC
*** Bug 393972 has been marked as a duplicate of this bug. ***
Comment 19 Nate Graham 2018-09-20 20:28:50 UTC
*** Bug 398842 has been marked as a duplicate of this bug. ***
Comment 20 Nate Graham 2018-12-23 03:54:55 UTC
Scaling options just went in with https://phabricator.kde.org/D7962!
Comment 21 Nate Graham 2018-12-31 20:59:59 UTC
*** Bug 336617 has been marked as a duplicate of this bug. ***
Comment 22 Nate Graham 2019-01-15 16:33:20 UTC
*** Bug 403148 has been marked as a duplicate of this bug. ***
Comment 23 Nate Graham 2019-01-17 02:57:56 UTC
*** Bug 403263 has been marked as a duplicate of this bug. ***
Comment 24 Michael 2019-01-22 11:03:08 UTC
Just downloaded 18.12.1, applied the patch and recompiled: works well for me! Thanks a lot!

However, I miss one thing: the posibility to save or predefine a default scale mode. Even when I open the print dialog for the same document twice in a row, "force rasterization" is off again.

So when you want to print a bunch of PDFs with e.g. scale mode "full page", this really takes maaaaaany clicks :-) as you have to do it for every pdf.

May I suggest to add an  option to turn on rasterization by default and chose a default scale mode in the "configure okular" dialog?

For the moment, is there any way to preselect the scale mode through some config file?

cu,
Frank
Comment 25 Christoph Feck 2019-02-14 19:03:19 UTC
Michael, I suggest to report a separate ticket for your issue.
Comment 26 Michael Weghorn 2019-04-05 00:13:15 UTC
*** Bug 406237 has been marked as a duplicate of this bug. ***
Comment 27 Michael Weghorn 2019-04-05 07:35:18 UTC
*** Bug 406237 has been marked as a duplicate of this bug. ***