好吧,我正在为OpenGL绘制Iphone图表。一切正常,直到我使用该Texture2D类绘制X轴标签和Y轴标签。绘制标签的功能在我认为非常耗时的每一帧执行。为了解决动画放缓,我有两个想法,但我仍然无法找到如何实现它们: 1.绘制标签1次,但下次只是重用它们,重用矩阵或纹理,如果有有任何可能(抱歉,我是一个新手,我可能会写一些不够的东西); 2.当清洁缓冲区(glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT))时,只清洁屏幕的一部分,而不是整个渲染场景,我也很乐意知道是否有可能清除整个屏幕,但是(例如在柱状图中,只清除列,而不是背景,而不是标签或lengend)。 非常感谢您的帮助。Iphone OpenGL ES重复使用或绘制一次纹理场景
0
A
回答
0
如果每次清除完整的渲染缓冲区,事情将会简单得多,并且更加顺畅。只需将轴预渲染为单个纹理并在每次通过时渲染纹理即可。
2
glLoadIdentity(); // Added line
glEnableClientState(GL_VERTEX_ARRAY);
glEnableClientState(GL_TEXTURE_COORD_ARRAY);
glEnable(GL_TEXTURE_2D);
glEnable(GL_BLEND);
glBlendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA);
NumberFormatter *lFormater = [[NumberFormatter alloc] init];
int i = 0;
for (NSNumber *lNumber in mColXLabelCoord) {
NSNumber *lUnformated = [NSNumber numberWithInteger:[[NSString stringWithString:[mColYLabelsArray objectAtIndex:i]] integerValue]];
NSString *lFormated = [NSString stringWithString:[lFormater stringFromNumber:lUnformated withMask:[[mGraphArray objectAtIndex:0] mGraphMask]]];
Texture2D* lWord= [[Texture2D alloc] initWithString:lFormated dimensions:CGSizeMake(40, 15) alignment:UITextAlignmentLeft fontName:@"Helvetica" fontSize:13];
glColor4f(RedFromRGB(0xFFFFFF), GreenFromRGB(0xFFFFFF), BlueFromRGB(0xFFFFFF), 1.0);
[lWord drawInRect:CGRectMake([lNumber floatValue]+2, 470,40,15) rotation:-90];
[lWord release];
i++;
}
[lFormater release];
i = [mColYCoord count]-1;
for (NSNumber *lNumber in mColYCoord) {
Texture2D* lWord= [[Texture2D alloc] initWithString:[NSString stringWithFormat:((GraphValue*)[mGraphValuesArray objectAtIndex:i]).mGraphValueXLabel,[lNumber floatValue]]
dimensions:CGSizeMake(40, 15)
alignment:UITextAlignmentCenter
fontName:@"Helvetica" fontSize:12];
if ([mColYCoord count] < kOptimalLabelNumber) {
glColor4f(RedFromRGB(0xFFFFFF), GreenFromRGB(0xFFFFFF), BlueFromRGB(0xFFFFFF), 1.0);
[lWord drawInRect:CGRectMake(10, [lNumber floatValue]+15, 40, 15) rotation:-90];
}else {
glColor4f(RedFromRGB(0xFFFFFF), GreenFromRGB(0xFFFFFF), BlueFromRGB(0xFFFFFF), 1.0);
[lWord drawInRect:CGRectMake(2, [lNumber floatValue]+5, 40, 15) rotation:-30];
}
[lWord release];
i--;
}
glBlendFunc(GL_ONE, GL_ONE_MINUS_SRC_ALPHA);
glDisable(GL_BLEND);
glDisable(GL_TEXTURE_2D);
glDisableClientState(GL_TEXTURE_COORD_ARRAY);
glDisableClientState(GL_VERTEX_ARRAY);
相关问题
- 1. Opengl-es绘制纹理
- 2. OpenGL ES iPhone纹理
- 3. 仅绘制一个纹理的OpenGL ES iPhone
- 4. iOS 4.1 OpenGL ES 1.1未绘制纹理
- 5. OpenGL ES纹理不会绘制
- 6. Android的OpenGL ES没有绘制纹理
- 7. OpenGL ES绘制黑色纹理
- 8. 如何使用OpenGL ES 2将纹理绘制为四边形?
- 9. 如何在OpenGL ES 2.0中将纹理绘制为2D背景?
- 10. 的OpenGL ES 2.0 - 复制纹理数据
- 11. OpenGL ES 2.0纹理
- 12. opengl es:用渐变渐变绘制纹理
- 13. 异步纹理加载iPhone OpenGL ES 2
- 14. 在iPhone的OpenGL ES中纹理球体
- 15. iPhone的OpenGL-ES视频纹理
- 16. iPhone OpenGL ES 2.0 - 像素完美纹理
- 17. 禁用opengl es纹理ios
- 18. 纹理复制opengl
- 19. OpenGL ES渲染到纹理
- 20. 用OpenGL ES绘制纹理最简单的方法是什么?
- 21. OpenGL ES在多纹理中使用glColor4f
- 22. OpenGL ES 2.0衍生纹理
- 23. OpenGL纹理没有绘制?
- 24. Java openGL绘制纹理
- 25. OpenGL ES 2.0 - 如何仅使用着色器绘制纹理的一部分?
- 26. 设置OpenGL ES 2.0纹理
- 27. 当使用GL_TEXTURE_2D时,OpenGL纹理首次绘制白色
- 28. Android OpenGL ES 2.0 - glReadPixels()和glTexImage2D()绘制黑色纹理?
- 29. OpenGL ES的iPhone - 绘制反锯齿线
- 30. Android Opengl-es在纹理上制作透明背景,如何?
通过清除渲染缓冲区做你的意思是清除框架和深度缓冲(glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT))。如果是这样,我会在每一帧中清除它们。我如何预先渲染轴到一个纹理。对不起,您能否提供更多详细信息,以及一些代码示例?我会提到你,我正在使用Texture2D类来绘制标签。以下是我如何做到的: – 2010-10-29 13:39:29