Go Premium for a chance to win a PS4. Enter to Win


How can I detect "Larger Font" setting in Win 7?

Posted on 2010-08-26
Medium Priority
Last Modified: 2013-12-14
I have a problem detecting that Windows 7 with Aero is set in "Larger 150%" mode.

Here is a matrix of values that I can detect to determine the font setting:
In Windows XP:
Set to:            OS   Aero      DPI   Title Bar Height
 Normal:,            5.1,      False,   96,    26
 Large:,            5.1,      False,   96,    30
 Extra Large:  5.1,   False,   96     36
In Win 7 (Aero Mode)  
Set to:                             OS   Aero    DPI   Title Bar Height
Smaller 100% (default):,  6.1, True,   96,   22
Medium 125%:,                6.1, True,   120,  27
Larger 150%:,                 6.1, True,    96,   22

In Win 7 (Non Aero Mode)      
Set to:                              OS   Aero    DPI   Title Bar Height
Smaller 100% (default):,  6.1,  False,  96,   19
Medium 125%:,                6.1,  False,  120,  24
Larger 150%:,                 6.1,  False,  144,  29

Note that Windows 7 when set to "Larger Font 150% returns a DPI of 144 in non-Aero mode but 96 when in Aero mode.  That means that my matrix of values in Windows 7 Aero mode shows the same values whether it is in Smaller (default) or Larger mode.

I'm not sure what the results will be in Vista as I do not have a Vista system available so I may be asking a similar question for Vista.

The current question however is:  How can I detect "Larger" mode in Win 7 Aero?

I don't need full code - all I need is to find a "get-able" property that is guaranteed to be different between
Win7-Aero-smaller fonts and Win7-Aero-Larger Fonts.

When switched into "Larger Font" mode, btw, my 1600 by 1200 LCD monitor show a resolution of 1057 by 800.

Question by:DMTrump
  • 6
  • 2
LVL 57

Accepted Solution

McKnife earned 2000 total points
ID: 33541732
Did you ever monitor the registry while changing the value? You can use procmon to do it or record the changes with wininstall LE (by scalable software) or with regshot. All I know is that starting with windows 7, it's a per user setting, which makes machine wide detection more complicated.

Author Comment

ID: 33541944
That's a good suggestion.  I'll investigate to see what I can find.

Author Closing Comment

ID: 33547983
That is such a good path to take that I'm awarding you the points, even though I've not yet been successful with the method.  See my further comment for more information.
Independent Software Vendors: We Want Your Opinion

We value your feedback.

Take our survey and automatically be enter to win anyone of the following:
Yeti Cooler, Amazon eGift Card, and Movie eGift Card!


Author Comment

ID: 33548000
Although I've awarded the points for an excellent suggestion I'm stymied in putting it into practice - but my problems in doing that are another issue that I may have to raise in the Delphi forum.

Here's what I found in the registry - the only value that appears to be related to this issue.

Windows 7 Aero and Non-Aero both:
[HKEY_USERS\S-1-5-21-1425574761-4149950604-329294024-1001\Control Panel\Desktop\WindowMetrics]

However, the same key under these two section the value is 60 for all three resolutions
[HKEY_USERS\.DEFAULT\Control Panel\Desktop\WindowMetrics]
[HKEY_USERS\S-1-5-18\Control Panel\Desktop\WindowMetrics]

I suspect also that the Key Path portion "S-1-5-21-1425574761-4149950604-329294024-100" is an ephemeral value that will be different for every instance of machine/user.

Furthermore, I've been unable to retrieve the value from my machine even when specifying the exact path as listed above.  But as I say - that's a different inquery.

Author Comment

ID: 33548029
Ahhhh - that "S-1-5-21-1425574761-4149950604-329294024-100" must be the "CURRENT USER" ID.

Author Comment

ID: 33548105

McKnife's solution was absolutely correct - and here's the rest of the story:

In whatever language you are using, read the value for
HKEY_CURRENT_USER \Control Panel\Desktop\WindowMetrics AppliedDPI

The value returned for
smaller: 96
medium: 120
larger: 144

Obviously the registry values are recalculated from 60, 78,  and 90 so don't expect those values.

Thanks,  McKnife,  You gave me the right lead!  (Doh!  Why didn't I think of it myself?  <BG>)


LVL 57

Expert Comment

ID: 33548644
To add one: 60, 78 and 90 are the Hex values. If you find a user defined value in there, you can use calc.exe (view set to programmer) to transform the hexadecimal number into decimal.

Author Comment

ID: 33549420
Oh that's another big Doh!

BTW,  I simply used regedit export to get the registries for the various configurations then did a file compare using ExamDiff to find the Key I was interested in and compare the values.

The code I used in my app to extract the value automatically displays integers as decimal values - whereas the raw registry entries always shows integer values in Hex format.  But I had forgotten that!

Thanks again!

Featured Post

Keep up with what's happening at Experts Exchange!

Sign up to receive Decoded, a new monthly digest with product updates, feature release info, continuing education opportunities, and more.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

The recent Microsoft changes on update philosophy for Windows pre-10 and their impact on existing WSUS implementations.
By default the complete memory dump option is disabled in windows . If we want to enable the complete memory dump for a diagnostic purpose, we have a solution for it. here we are using the registry method to enable this.
The Task Scheduler is a powerful tool that is built into Windows. It allows you to schedule tasks (actions) on a recurring basis, such as hourly, daily, weekly, monthly, at log on, at startup, on idle, etc. This video Micro Tutorial is a brief intro…
Want to learn how to record your desktop screen without having to use an outside camera. Click on this video and learn how to use the cool google extension called "Screencastify"! Step 1: Open a new google tab Step 2: Go to the left hand upper corn…

783 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question