Solved

Font Points to Pixel.

Posted on 1998-08-24
8
756 Views
Last Modified: 2013-12-02
I'm doing a programm that's pset fonts on a bmp picture, but i want the size of the font to be maybe 20 pixels not 20 points, how do i do ??????
0
Comment
Question by:e_norrman
  • 4
  • 4
8 Comments
 
LVL 6

Accepted Solution

by:
clifABB earned 100 total points
ID: 1430681
The answer is almost impossible.  The reason being is that the point to pixel ratio will change depending on the resolution, the size of font, the type of font (fixed width or variable width) and the weight of the font.  
For example, Ariel 10pt on a resolution of 1152x864 will have a height of 10 pixels (13 if you include decenders).  A "W" is 13 pixels wide, an "I" is 1 pixel wide.  Changing to Times New Roman Bold 10pt height = 9 pixels (12 with decenders).  A "W" is 13 pixels wide, an I is 4 pixels wide.

The best you can do is try several fonts, cout the pixels and do some calculations.  The results will never be the same for all fonts, though.
0
 

Author Comment

by:e_norrman
ID: 1430682
wondering how they do in paintprogramms like photoshop, when they converting the font to pixels?
0
 
LVL 6

Expert Comment

by:clifABB
ID: 1430683
A quick and dirty way of calculating might be:
Set the font in a picturebox.
To get the values in pixels:
FontWidth = Picture1.TextWidth("X") / Screen.TwipsPerPixelX
FontHeight = Picture1.TextHeight("X") / Screen.TwipsPerPixelY
Remember that these values will change depending on the font used and the resolution of the screen.
0
 

Author Comment

by:e_norrman
ID: 1430684
solution so far


Dim pix, size As Integer
Dim poi As Double


pix = Screen.TwipsPerPixelY
size= pix * fontstorlek
poi = twi / 27  'or somethimh like that


Picture2.FontSize = poi
0
Is Your Active Directory as Secure as You Think?

More than 75% of all records are compromised because of the loss or theft of a privileged credential. Experts have been exploring Active Directory infrastructure to identify key threats and establish best practices for keeping data safe. Attend this month’s webinar to learn more.

 
LVL 6

Expert Comment

by:clifABB
ID: 1430685
I'm sorry, but I'm not following your code well.  Can you explain further?
0
 

Author Comment

by:e_norrman
ID: 1430686
dim pix, twi as integer
dim poi as double

1. take out the pixels, twips on the screenY
 then i got that maybe there are xxx twips on 1 pixel

2. then take the twipsperpixel * fontsize
 
3. then the points = the poi/ 23 something realy dont know try and find a number that fit.



pix = Screen.TwipsPerPixelY
twi = pix * fontstorlek
poi = twi / 23
   
fontsize = poi

??????

0
 
LVL 6

Expert Comment

by:clifABB
ID: 1430687
OK, I've been doing some research and there is an API call which will return information on the current font:
Private Declare Function GetTextMetrics Lib "gdi32" Alias "GetTextMetricsA" (ByVal hdc As Long, lpMetrics As TEXTMETRIC) As Long

Private Type TEXTMETRIC
        tmHeight As Long           'Height of font
        tmAscent As Long
        tmDescent As Long
        tmInternalLeading As Long
        tmExternalLeading As Long
        tmAveCharWidth As Long     'Average width of font
        tmMaxCharWidth As Long     'Maximum width of font
        tmWeight As Long           'Boldness
        tmOverhang As Long
        tmDigitizedAspectX As Long
        tmDigitizedAspectY As Long
        tmFirstChar As Byte
        tmLastChar As Byte
        tmDefaultChar As Byte
        tmBreakChar As Byte
        tmItalic As Byte
        tmUnderlined As Byte
        tmStruckOut As Byte
        tmPitchAndFamily As Byte
        tmCharSet As Byte
End Type

Usage:
Private Sub Command1_Click()
  Dim TM As TEXTMETRIC
  Dim lRes As Long
 
  lRes = GetTextMetrics(Form1.hdc, TM)
  Debug.Print TM.tmHeight, TM.tmAveCharWidth
End Sub

0
 

Author Comment

by:e_norrman
ID: 1430688
ok i'll try it out and see what happens  

thanks!
0

Featured Post

Is Your Active Directory as Secure as You Think?

More than 75% of all records are compromised because of the loss or theft of a privileged credential. Experts have been exploring Active Directory infrastructure to identify key threats and establish best practices for keeping data safe. Attend this month’s webinar to learn more.

Question has a verified solution.

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

Suggested Solutions

Introduction In a recent article (http://www.experts-exchange.com/A_7811-A-Better-Concatenate-Function.html) for the Excel community, I showed an improved version of the Excel Concatenate() function.  While writing that article I realized that no o…
Have you ever wanted to restrict the users input in a textbox to numbers, and while doing that make sure that they can't 'cheat' by pasting in non-numeric text? Of course you can do that with code you write yourself but it's tedious and error-prone …
Show developers how to use a criteria form to limit the data that appears on an Access report. It is a common requirement that users can specify the criteria for a report at runtime. The easiest way to accomplish this is using a criteria form that a…
Excel styles will make formatting consistent and let you apply and change formatting faster. In this tutorial, you'll learn how to use Excel's built-in styles, how to modify styles, and how to create your own. You'll also learn how to use your custo…

919 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

Need Help in Real-Time?

Connect with top rated Experts

16 Experts available now in Live!

Get 1:1 Help Now