Solved

Font Points to Pixel.

Posted on 1998-08-24
8
753 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
How to run any project with ease

Manage projects of all sizes how you want. Great for personal to-do lists, project milestones, team priorities and launch plans.
- Combine task lists, docs, spreadsheets, and chat in one
- View and edit from mobile/offline
- Cut down on emails

 
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

How your wiki can always stay up-to-date

Quip doubles as a “living” wiki and a project management tool that evolves with your organization. As you finish projects in Quip, the work remains, easily accessible to all team members, new and old.
- Increase transparency
- Onboard new hires faster
- Access from mobile/offline

Join & Write a Comment

Introduction While answering a recent question (http://www.experts-exchange.com/Q_27402310.html) in the VB classic zone, I wrote some VB code in the (Office) VBA environment, rather than fire up my older PC.  I didn't post completely correct code o…
I was working on a PowerPoint add-in the other day and a client asked me "can you implement a feature which processes a chart when it's pasted into a slide from another deck?". It got me wondering how to hook into built-in ribbon events in Office.
As developers, we are not limited to the functions provided by the VBA language. In addition, we can call the functions that are part of the Windows operating system. These functions are part of the Windows API (Application Programming Interface). U…
Get people started with the process of using Access VBA to control Excel using automation, Microsoft Access can control other applications. An example is the ability to programmatically talk to Excel. Using automation, an Access application can laun…

708 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

19 Experts available now in Live!

Get 1:1 Help Now