如何禁用由CGContextDrawPDFPage生成的某些PDF的控制台日志记录

时间:2010-12-03 14:35:44

标签: iphone objective-c pdf nslog

我有一些问题,某些PDF的日志记录控制一些节点号和字体系列,这使我的应用程序变慢。有谁知道如何禁用日志记录?

我用过:     CGContextDrawPDFPage(context,page);

所有PDF都不会发生这种情况,another SO question中的一个解释是当渲染器不知道PDF使用的字体时会发生日志记录。我使用的PDF是http://dl.dropbox.com/u/861361/test.pdf

仅供参考,我使用的是版本3.2 iOS(iPad)

2 个答案:

答案 0 :(得分:1)

不幸的是我不知道如何抑制日志记录。

有一种方法可以获取字形,并将文本绘制为矢量元素而不是文本,从而避免字体问题。 (信用:jegeblad)。字形不是直接字符。

创建字体:

//NSString * fontName;
CGFont cgfont = CGFontCreateWithFontName ((CFStringRef)fontName);
CGContextSetFont(cg, cgfont);
CGContextSetFontSize(cg, fontSize);

如果我们想画画,例如一个名为word的NSString ..有关字形的一些信息:

int count = [word.s length];
unichar * buffer = new unichar[count+1];
CGGlyph * glyphs = new CGGlyph[count+1];
int * adv = new int[count+1];
CGRect * rects = new CGRect[count+1];
[word.s getCharacters:buffer];
CGFontGetGlyphsForUnichars(cgfont, buffer, glyphs, [word.s length]);
CGFontGetGlyphAdvances(cgfont,glyphs,count,adv);
CGFontGetGlyphBBoxes(cgfont, glyphs, count, rects);

换句话说,我们得到单词字母的字形,然后我们得到各个字形的维度和进展。注意:我找不到任何方法来确定单词的字形数。 现在我们准备绘制字形了:

CGContextShowGlyphsAtPoint(outputCG, x, y, glyphs,count);

这很整洁,但它无法解决整个字体嵌入问题。但是,如果让石英将文本绘制为矢量元素而不是... well ... text,我们可以解决这个问题。我们只需使用函数更改文本的绘制方式:

CGContextSetTextDrawingMode (outputCG, kCGTextClip);

这将使用文本作为剪切路径,而不是简单地绘制它。如果我们首先调用CGContextShowGlyphsAtPoint,然后在显示字形的区域周围绘制一个填充的矩形,那么该矩形将被剪切为字形,基本上我们正在绘制单词的字母。但是,由于我们绘制的是矩形而不是文本,因此生成的PDF文件将不包含文本,而是包含一组看起来像文本的矢量元素。因此,Quartz不再需要在PDF文件中嵌入字体。一种方法是通过以下循环:

double scale = ffontSize / double( CGFontGetUnitsPerEm(cgfont) );
for (size_t i = 0; i < count; ++i) {
CGContextSaveGState(outputCG);
CGContextShowGlyphsAtPoint(outputCG, x, p.y + spaceH, &glyphs[i], 1 );  
CGContextBeginPath(outputCG);
CGContextAddRect(outputCG, 
CGRectMake(x+scale* rects[i].origin.x , p.y + spaceH + scale*(rects[i].origin.y),
scale*(rects[i].size.width), scale*(rects[i].size.height)) );
CGContextFillPath(outputCG);
CGContextRestoreGState(outputCG);
x += adv[i] * scale;
}

通过将剪切路径设置为单个字形并在其后面绘制填充矩形,一次绘制一个字形。我当然将当前的填充颜色设置为我想要文本的颜色。

请记住在完成后释放字体:

CGFontRelease(cgfont);

答案 1 :(得分:0)

生成的日志被刷新到STDOUT,如果你真的想要禁用日志记录,关闭STDOUT并将STDOUT重定向到/ dev / null或其他不是STDOUT的流;)

int fileDes = creat("/dev/null", S_IRUSR | S_IWUSR | S_IRGRP | S_IROTH);
dup2(fileDes, STDOUT_FILENO);
close(fileDes);