Add fontWidth() and clarify textWidth vs fontWidth docs in textCore.js #7745 #8088
+30
−33
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
Resolves #7745
Adds a new user-facing function,
fontWidth()
, to the p5.js library and updates the documentation to clearly distinguish between advance width and tight bounding box measurements for text. All changes are made insrc/type/textCore.js
.Changes
New Function:
fontWidth()
returns the advance width (loose measurement) of a string, including all leading and trailing whitespace, as measured by the browser’smeasureText().width
.Documentation Updates:
fontWidth()
.textWidth()
documentation to clarify that it returns the tight bounding box width, which may ignore leading/trailing whitespace.Motivation
textWidth()
and the newfontWidth()
regarding whitespace handling.Example Usage
Related Issues
Checklist
fontWidth()
src/type/textCore.js
p5.Font.js
dev-2.0
branchPR Checklist
npm run lint
passes