MHB Solving the Font Size Puzzle for Thumbnail Layers

  • Thread starter Thread starter Echilon1
  • Start date Start date
  • Tags Tags
    Font Puzzle
Click For Summary
The discussion revolves around calculating the appropriate font size for a label in both full-size and thumbnail layers. The user aims to maintain a consistent font size ratio when scaling down the layer, specifically needing to adjust a font size of 30 points for a thumbnail that is one-third the size of the full version. Despite attempts to derive a formula using the parent size and ratios, the user struggles to achieve the desired outcome. The current approach involves adjusting the font size based on the layer's width and the specified font size, but it has not yielded the correct results. The goal is to ensure that the font size scales proportionately with the layer dimensions.
Echilon1
Messages
2
Reaction score
0
I'm drawing a scene with, trying to size my font correctly. I have both a big and small version of the layer on the screen at the same time.

I want to set the font in a label on this layer (both the thumbnail and the full size version) to, for example, size 30. This works fine for the full size layer (call it ratio 1), but if I make the thumbnail 1/3 as big, how do I calculate that the font should be 1/3 as big? I can't get the logic right despite multiplying these numbers all ways.

The properties which the user can change are:

- Font size (pts)
- Thumbnail size (px wide)

To position the label correctly I'm using this (which works):

Code:
// 'element' is the customizable element. element.location is  the percentage across the layer where it's located. Eg: 50 is half way
        CGPoint relativeCoords = ccp (self.contentSize.width/(100/element.location.x),
                                      self.contentSize.height/(100/element.location.y));
        layer.position = relativeCoords;

To determine the right font size, I've tried, among other variants, this (to no avail):

Code:
-(void)sizeToRelative(CGSize)parentSize {
      // self.lbl is the layer within my element
      CGFloat ratioWidth = (parentSize.width/100);
      CGFloat ratioFontSize = (textEle.textProperties.fontSize/100)*(1/3)*(parentSize.width/100);
      [self.lbl setFontSize:ratioFontSize*element.textProperties.fontSize];

The idea is that if I pass in a `parentSize`, to calculate the relative font size. The 'default' size should be as big as 30px in a 100px wide layer. If I have a layer 200px wide, it should return 60 if the user sets the font at size 30.
 
Mathematics news on Phys.org
In psuedo code, this would be:
Code:
        // 'element' is the customizable element. element.location is   the percentage across the layer where it's located. Eg: 50 is half way
        xFromOrigin = width/(100/location.x)
        yFromOrigin = height/(100/location.y));

To determine the right font size, I've tried, among other variants, this (to no avail):
Code:
Given a parentSize with a width and height:
       ratioWidth = (parentSize.width/100);
       ratioFontSize = (fontSize/100)*(1/3)*(parentSize.width/100);
       adjustedFontSize = ratioFontSize*fontSize];
 
Here is a little puzzle from the book 100 Geometric Games by Pierre Berloquin. The side of a small square is one meter long and the side of a larger square one and a half meters long. One vertex of the large square is at the center of the small square. The side of the large square cuts two sides of the small square into one- third parts and two-thirds parts. What is the area where the squares overlap?

Similar threads

  • · Replies 1 ·
Replies
1
Views
4K