Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

OptimizePrintPreview/EnablePrintPreviewOptimization explanation mentions no drawbacks, the mentioned restriction appears to be incorrect, and other questions. #1546

Open
mdell-seradex opened this issue Dec 18, 2022 · 6 comments
Assignees
Labels
dotnet-framework/prod dotnet-framework/svc dotnet-winforms/tech Pri2 Medium priority product-question Product usage related questions [org][type][category] 📌 seQUESTered Label to indicate an item has been imported. waiting-on-feedback Waiting for feedback from SMEs before they can be merged winforms/subsvc

Comments

@mdell-seradex
Copy link

mdell-seradex commented Dec 18, 2022

Type of issue

Other (describe below)

Description

The document states that if OptimizePrintPreview/EnablePrintPreviewOptimization is set to true, performance can be increased when using network printers or printer preferences are modified.

  1. It seems that the document does not mention any drawback to this. If there are none, then why would anyone want this optimization to be disabled?

  2. Also, it has the following restriction:

If you use the QueryPageSettings event to modify printer settings, the performance of the PrintPreviewDialog control will not improve...

Looking at the reference source code PrintController.PrintLoopOptimized (referencesource), and comparing it to the PrintLoop method just above it, I believe it would be more accurate to say that the optimization is not applied if page settings are modified, not printer settings. Perhaps there are other things using it that I did not find.

  1. Also, it states that apps running on the .NET Framework 4.5.2 must use the EnablePrintPreviewOptimization setting, but when running on .NET Framework 4.6 or later versions, you can use the other version of the setting (OptimizePrintPreview). It almost makes it sound like the older setting would still work. Most systems likely have .NET Framework 4.8.1 installed on them by now. If an app was compiled targeting 4.5.2, but is run on a machine that has 4.8.1 installed, then what setting should be used?
    (Fixed in Update printpreviewdialog-control-overview-windows-forms.md #1558)

  2. Is there no way to apply that setting via code? Digging through the .NET reference source, it appears that is may not be possible. I do see that if System.AppContext is used, it might be, but I have not found when that might be the case. Perhaps because my application is targetting 4.5.2, I do not have access to System.AppContext, as it only applies to .NET Framework 4.6 and above. We are currently working on moving to 4.8.1 as we have third party components that must be updated.

I greatly appreciate any feedback on this.

Thank you.

Page URL

https://learn.microsoft.com/en-us/dotnet/desktop/winforms/controls/printpreviewdialog-control-overview-windows-forms?view=netframeworkdesktop-4.8

Content source URL

https://github.com/dotnet/docs-desktop/blob/live/dotnet-desktop-guide/framework/winforms/controls/printpreviewdialog-control-overview-windows-forms.md

Document Version Independent Id

de0653c6-4e5b-f061-0a05-bfb8d1f3e638

Article author

@adegeo

Metadata

  • ID: def98a89-92a0-b9d2-2ba4-48e8b9171bbb
  • Service: dotnet-framework
  • Sub-service: winforms

Associated WorkItem - 362952

@dotnet-bot dotnet-bot added the ⌚ Not Triaged Not triaged label Dec 18, 2022
@mdell-seradex mdell-seradex changed the title OptimizePrintPreview/EnablePrintPreviewOptimization explanation mentions no drawbacks, and the mentioned restriction appears to be incorrect, and other questions. OptimizePrintPreview/EnablePrintPreviewOptimization explanation mentions no drawbacks, the mentioned restriction appears to be incorrect, and other questions. Dec 18, 2022
@adegeo
Copy link
Contributor

adegeo commented Dec 20, 2022

@mdell-seradex That's a good question. It will probably involve some digging. I'll ping some folks.

@dotnet/dotnet-winforms Can someone answer this question?

@adegeo adegeo added waiting-on-feedback Waiting for feedback from SMEs before they can be merged product-question Product usage related questions [org][type][category] labels Dec 20, 2022
@dotnet-bot dotnet-bot removed the ⌚ Not Triaged Not triaged label Dec 20, 2022
@Tanya-Solyanik
Copy link
Member

Tanya-Solyanik commented Dec 20, 2022

Is there no way to apply that setting via code?

The app compat switch value is cached on the first access and is backed up by a static field. You have to set it the first thing on app start up. https://learn.microsoft.com/en-us/dotnet/api/system.appcontext.setswitch?view=netframework-4.8.1
I had not experimented with this value though.

It seems that the document does not mention any drawback to this

Drawback is a potential, though unlikely, compatibility break in case the app depended on reading printer data for every page.

For other questions I would need to look up sources, will come back later.

@Tanya-Solyanik
Copy link
Member

I believe it would be more accurate to say that the optimization is not applied if page settings are modified, not printer settings.

I see the root of the confusion here. Either way is accurate. The optimization is skipped when the "PageSettings" object is modified and that change is applied to the printer DevMod here - https://referencesource.microsoft.com/#System.Drawing/commonui/System/Drawing/Printing/PageSettings.cs,335 by calling https://learn.microsoft.com/en-us/windows/win32/printdocs/documentproperties.

If an app was compiled targeting 4.5.2, but is run on a machine that has 4.8.1 installed, then what setting should be used?

For application running on frameworks newer than 4.5.2, and 4.5.2 is out of support, so now this shouls always be the case, (no matter what the target framework is), use Switch.System.Drawing.Printing.OptimizePrintPreview app.config switch. The appSettings value had been removed from the codebase.

@mdell-seradex
Copy link
Author

mdell-seradex commented Jan 21, 2023

I take it then that the app's target framework is irrelevant, at least in this case. The installed framework version is what matters.

Also, I suppose that one could say that the optimization is skipped when "modifying the print settings via the PageSettings object", "modifying the PageSettings object which controls the print settings", or something similar.
Thank you for the clarification.

@Tanya-Solyanik
Copy link
Member

I take it then that the app's target framework is irrelevant, at least in this case. The installed framework version is what matters.

yes

"modifying the PageSettings object which controls the print settings"

Maybe this is more accurate, but it crosses into the area where it's best to read source code to see exactly what happens, how PageSettings object control the "printer". I see the doc as an introduction to the feature.

adegeo pushed a commit that referenced this issue Feb 7, 2023
@adegeo adegeo added the 🗺️ reQUEST Trigger label to import an issue into Quest label Nov 19, 2024
@dotnetrepoman dotnetrepoman bot added 🗺️ mapQUEST Only used as a way to mark an issue as updated. RepoMan should instantly remove it. and removed 🗺️ mapQUEST Only used as a way to mark an issue as updated. RepoMan should instantly remove it. labels Nov 19, 2024
@adegeo
Copy link
Contributor

adegeo commented Nov 19, 2024

Adding to Dec sprint as a reminder to read through this and see what doc work is involved in addressing this issue.

@adegeo adegeo self-assigned this Jan 14, 2025
@adegeo adegeo added 🗺️ reQUEST Trigger label to import an issue into Quest and removed 🗺️ reQUEST Trigger label to import an issue into Quest labels Jan 14, 2025
@dotnetrepoman dotnetrepoman bot added the 🗺️ mapQUEST Only used as a way to mark an issue as updated. RepoMan should instantly remove it. label Jan 14, 2025
@dotnet-policy-service dotnet-policy-service bot removed the 🗺️ mapQUEST Only used as a way to mark an issue as updated. RepoMan should instantly remove it. label Jan 14, 2025
@sequestor sequestor bot added 📌 seQUESTered Label to indicate an item has been imported. and removed 🗺️ reQUEST Trigger label to import an issue into Quest labels Jan 15, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
dotnet-framework/prod dotnet-framework/svc dotnet-winforms/tech Pri2 Medium priority product-question Product usage related questions [org][type][category] 📌 seQUESTered Label to indicate an item has been imported. waiting-on-feedback Waiting for feedback from SMEs before they can be merged winforms/subsvc
Projects
Development

No branches or pull requests

4 participants