- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我试图通过 CGPathRefs 将文本分成所有不同的部分。例如,L 有一条路径,而 ?有两个(点和其余部分)。
目前,我能够将每个字母作为路径,但是在“?”的示例中该路径同时包含点和其余部分。我想将它们分开,但似乎无法正常工作。
为了将文本划分为路径,我使用了堆栈溢出的一些答案,效果很好,这是我将每个字母作为路径的部分。在这里,我还通过“CGPathApply”函数运行它来查看每个单独的点
CGPathRef letter = CTFontCreatePathForGlyph(runFont, glyph, NULL);
NSMutableArray *pathElements = [NSMutableArray array];
CGPathApply(letter, (__bridge void * _Nullable)(pathElements), getPointsFromBezier);
然后我会像这样查看 getPointsFromBezier
中的每个点:
void getPointsFromBezier(void *info, const CGPathElement *element){
CGPoint *p = element->points;
NSString *name;
switch (element->type) {
case kCGPathElementMoveToPoint: name = @"kCGPathElementMoveToPoint"; break;
case kCGPathElementAddLineToPoint: name = @"kCGPathElementAddLineToPoint"; break;
case kCGPathElementAddQuadCurveToPoint: name = @"kCGPathElementAddQuadCurveToPoint"; break;
case kCGPathElementAddCurveToPoint: name = @"kCGPathElementAddCurveToPoint"; break;
case kCGPathElementCloseSubpath: name = @"kCGPathElementCloseSubpath"; break;
default: name = @"default"; break;
}
NSLog(@"Type: %@ || Point: %@", name, NSStringFromCGPoint(*p));
}
这给了我这样的输出:
Type: kCGPathElementMoveToPoint || Point: {11.75, 0}
Type: kCGPathElementAddLineToPoint || Point: {11.75, 9.729}
Type: kCGPathElementAddQuadCurveToPoint || Point: {11.75, 11.26}
..
..
Type: kCGPathElementAddQuadCurveToPoint || Point: {13.00, 10.52}
Type: kCGPathElementAddLineToPoint || Point: {13.00, 0}
Type: kCGPathElementCloseSubpath || Point: {13.00, 0}
Type: kCGPathElementMoveToPoint || Point: {12.75, 18.75}
Type: kCGPathElementAddQuadCurveToPoint || Point: {11.5, 18.94}
Type: kCGPathElementAddLineToPoint || Point: {11.5, 19.95}
Type: kCGPathElementAddQuadCurveToPoint || Point: {11.5, 20.41}
..
..
Type: kCGPathElementAddQuadCurveToPoint || Point: {12.75, 18.169}
Type: kCGPathElementCloseSubpath || Point: {12.75, 18.169}
我在这里输入的字符是ก็,我们可以清楚地看到它在输出中有两个不同的路径(即两个 kCGPathElementMoveToPoint 和两个 kCGPathElementCloseSubpath)。
我不确定如何从中正确或很好地创建两个单独的 CGPathRef。
最佳答案
实际上,在写问题时我几乎解决了它。
我创建了一个静态可变 CGPath,然后在通过 CGPathApply 调用的函数中添加点。像这样:
static CGMutablePathRef path;
void getPointsFromBezier(void *info, const CGPathElement *element){
CGPoint *p = element->points;
if ( element->type == kCGPathElementMoveToPoint ){
path = CGPathCreateMutable();
CGPathMoveToPoint(path, nil, p->x, p->y);
}
else if ( element->type == kCGPathElementAddLineToPoint ){
CGPathAddLineToPoint(path, nil, p->x, p->y);
}
else if ( element->type == kCGPathElementAddQuadCurveToPoint ){
CGPathAddQuadCurveToPoint(path, nil, p->x, p->y, p->x, p->y);
}
else if ( element->type == kCGPathElementAddCurveToPoint ){
// ...
}
else if ( element->type == kCGPathElementCloseSubpath ){
CGPathCloseSubpath(path);
[((__bridge NSMutableArray*)info) addObject:(__bridge id _Nonnull)(path)];
path = nil;
CGPathRelease(path);
}
}
然后我简单地循环遍历原始方法中的每个路径并绘制它们而不是原始的“字母”CGPath。
CGPathRef letter = CTFontCreatePathForGlyph(runFont, glyph, NULL);
NSMutableArray *pathElements = [NSMutableArray array];
CGPathApply(letter, (__bridge void * _Nullable)(pathElements), getPointsFromBezier);
for (id e in pathElements) {
CGContextSaveGState(ctx);
CGContextTranslateCTM(ctx,position.x,0 - 40 + CGRectGetMidY(rect) - self.font.descender + position.y);
CGContextScaleCTM(ctx, 1, -1);
CGContextAddPath(ctx, (CGPathRef)e);
[[self r] setFill];
CGContextFillPath(ctx);
CGContextRestoreGState(ctx);
}
CGPathRelease(letter);
这有点像。一个问题是我没有得到正确的曲线,因此生成的路径不像它们应该的那样平滑。如果我解决了,我会更新。
这是目前的结果,您可以看到与底部的原始图像相比,图像有点 block 状。然而,它们有两种不同的颜色,这是最初要解决的问题。
更新:我发现每个点 (element->points) 都包含剩余数据(x 和 y's)以正确绘制点。例如:
if ( element->type == kCGPathElementAddQuadCurveToPoint ){
CGPoint *p0 = &points[0]; // Control points for bezier path
CGPoint *p1 = &points[1]; // Actual points
CGPathAddQuadCurveToPoint(path,
nil,
p0->x,
p0->y,
p1->x,
p1->y);
}
这将正确绘制每个字形。
关于ios - 将 CGPathRef 拆分为多个路径,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45130960/
我有一个数组列表: ArrayList allText = new ArrayList(); 其内容是这样的: [Alabama - Montgomery, Alaska - Juneau, Ariz
我有一个 timestamp 格式的开始和结束时间。我想将它们分成多个时间段,例如 1 小时。 $t1 = strtotime('2010-05-06 12:00:00'); $t2 = strtot
我需要将 span10 分成 3 列,但我无法将它们排列起来。我应该在 span10 中添加一个 span12 还是使用 offset 还是??
我有一个时间序列。我想从早上 8 点到第二天早上 7:59 分成 24 小时的区 block 。我知道如何按日期分组,但我尝试过使用 TimeGroupers 和 DateOffsets 处理这个 8
我收到“街道号码邮政编码城市”形式的地址(作为字符串)。我想要做的是将街道和号码与邮政编码和城市分开。通常你可以按空格分割。但有些街道名称中也有空格,例如:“Emile Van Ermengemlaa
我有一个用户列表。其中一些用户处于第一状态,而其他用户处于第二状态。所以我想要的是将这个列表显示为首先,它按排序顺序显示存在 = 1 的用户,然后按排序顺序显示存在 = 2 的用户。这里的排序是根据用
我感觉我搜索了整个网络,但找不到一种方法将不同高度的 div 很好地划分为 3 列,就像 http://www.ing.nl 上那样 headertekst headerteksttesth
Bootstrap 3 按钮下拉菜单出现问题。你可以在这里看到我的两个例子: http://www.bootply.com/W1dLusilMk http://www.bootply.com/GGBv
我在 php 中执行以下操作 foreach($QuestionAsekd as $k => $v){ $grp_name = $v['NAME']; $groupValues[$gr
我找到了一种用pandas解析html的绝妙方法。我的数据格式有点奇怪(见下文)。我想将这些数据拆分为 2 个单独的数据帧。 注意每个单元格如何由,分隔...是否有任何真正有效的方法来分割所有这些单元
HTML 看起来像这样,但我不允许对其进行更改。我只能编写 CSS 将其变成 2 列。 Povezave www.behance.net www.kiberpipa.org www.o
假设我有以下数据框“A” utilization utilization_billable service 1
我需要将 2 个文本框拉伸(stretch)到 100% 的浏览器宽度,以及一个提交按钮。所有三个都应该在一行中,我试图拉伸(stretch)它但它没有发生......有什么想法吗? 代码: .sea
我是一名优秀的程序员,十分优秀!