From d6a26059012dcaf4556b20bb29d469fc490bf3be Mon Sep 17 00:00:00 2001 From: dhowe Date: Wed, 4 Dec 2024 19:50:46 +0000 Subject: [PATCH] support passing offscreen graphics into textToPoints/Paths comment --- src/type/p5.Font.js | 10 +++++----- src/type/text2d.js | 30 +++++++++++++++++------------- 2 files changed, 22 insertions(+), 18 deletions(-) diff --git a/src/type/p5.Font.js b/src/type/p5.Font.js index abe70c8785..085ebb794b 100644 --- a/src/type/p5.Font.js +++ b/src/type/p5.Font.js @@ -142,7 +142,7 @@ function font(p5, fn) { */ _lineateAndPathify(str, x, y, width, height, options = {}) { - let renderer = options?.renderer || this._pInst._renderer; + let renderer = options?.graphics?._renderer || this._pInst._renderer; // save the baseline let setBaseline = renderer.drawingContext.textBaseline; @@ -317,9 +317,9 @@ function font(p5, fn) { drawPaths(ctx, commands, opts) { // for debugging ctx.strokeStyle = opts?.stroke || ctx.strokeStyle; - ctx.fillStyle = opts?.fill || ctx.strokeStyle; + ctx.fillStyle = opts?.fill || ctx.fillStyle; ctx.beginPath(); - commands.forEach(({ type, data }) => { + commands.forEach(([type, ...data ]) => { if (type === 'M') { ctx.moveTo(...data); } else if (type === 'L') { @@ -332,8 +332,8 @@ function font(p5, fn) { ctx.closePath(); } }); - ctx.fill(); - ctx.stroke(); + if (opts?.fill) ctx.fill(); + if (opts?.stroke) ctx.stroke(); } _pathsToCommands(paths, scale) { diff --git a/src/type/text2d.js b/src/type/text2d.js index 9267c10a45..44f4582807 100644 --- a/src/type/text2d.js +++ b/src/type/text2d.js @@ -1,33 +1,35 @@ /* * TODO: - * - get axes and values for parsed fonts - * - change renderer.state to use getters for textAlign, textBaseline, etc. ?? - * - textToPoints: enable passing props in options (textSize, textLeading, etc.)? - * - textToPaths: test rendering in p5 (new?/old api) [x] -- inner hole problem - * - cache parsed fonts (and/or lazy load) ? - * - test textToPoints with google/variable fonts * - more with variable fonts, do slider example - * - better font-loading (google fonts, font-face declarations, multiple fonts with Promise.all()) - * - test textToPoints with offscreen graphics.drawingContext passed in as 'context' + * - better font-loading? (google fonts, font-face declarations, multiple fonts with Promise.all()) + * - test textToPoints with google/variable fonts? * - add test for line-height property in textFont() and textProperty() * - how does this integrate with textLeading? * - spurious warning in oneoff.html (local) - * + + * ON HOLD: + * - get axes and values for parsed fonts + * - change renderer.state to use getters for textAlign, textBaseline, etc. ?? + * DONE: + * - textToPoints/Paths should accept offscreen `graphics` passed in as `options.graphics` [x] + * - textToPaths: test rendering in p5 [x] + * - support direct setting of context2d.font with string [x] * - textToPoints/Path: add re-sampling support with current options [x] * - add fontAscent/Descent and textWeight functions [x] * - textToPaths should split into glyphs and paths [x] * - add textFont(string) that forces context2d.font to be set (if including size part) [x] * - textToPoints: test rectMode for all alignments [x] * - test textToPoints with single line, and overlapping text [x] - * * ENHANCEMENTS: - * - support direct setting of context2d.font with string [x] + * - cache parsed fonts * - support idographic and hanging baselines * - support start and end text-alignments * - add 'justify' alignment */ +import { Graphics } from '../core/p5.Graphics'; + /** * @module Type * @submodule text2d @@ -53,8 +55,7 @@ function text2d(p5, fn) { const CommaDelimRe = /,\s+/; const QuotedRe = /^".*"$/; const TabsRe = /\t/g; - const RendererProp = 0; - const Context2dProp = 1; + const FontVariationSettings = 'fontVariationSettings'; const VariableAxes = ['wght', 'wdth', 'ital', 'slnt', 'opsz']; const VariableAxesRe = new RegExp(`(?:${VariableAxes.join('|')})`); @@ -92,6 +93,9 @@ function text2d(p5, fn) { } return this._renderer[func](...args); }; + p5.Graphics.prototype[func] = function (...args) { + return this._renderer[func](...args); + }; }); const RendererTextProps = {