ImageMagick: DrawImage(Image*,DrawInfo*) 绘制填充图片时卡住的原因分析

今天傍晚在测试的时候无意发现有两个动画会卡住,正常情况下,20秒就完成的操作,突然卡住。

CPU:95%+,经过30 - 50秒左右后,程序又能正常的向下执行,结果是对的。

 

这种情况不是每次都发生,有的时候执行20次,会出现 1 - 2次卡住,但没有完全卡死。

 

经过在多段代码之间加多个printf()来打印执行的位置,发现卡住的代码是:DrawImage(mw_frame->images, draw_info);

 

下面是相关代码:

经过测试发现每次卡住的时候,都是在 i == 0的时候,通过分析发现,如果 i == 0,那么绘制的四边框将不存在。

因为四边框的宽与高都为 0, 可能就是因为这个原因导致 DrawImage() 卡住。

我将原来的 for(i=0;i<...) 改为 for(i=1;i<) 后,经过多次测试发现不会再卡住了。

 

DrawingWand *d_wand = NewDrawingWand(); //

 

//从四周不断的画四边形

DrawRectangle(d_wand, 0, 0, step * i, step * i); //左上角

DrawRectangle(d_wand, 0, height, step * i, height - step * i); //左下角

DrawRectangle(d_wand, width, 0, width - step * i, step * i); //右上角

DrawRectangle(d_wand, width , height, width - step * i, height - step * i); //右下角

 

// Now "peek" at the wand

DrawInfo *draw_info = PeekDrawingWand(d_wand); //返回当前图形的魔杖信息。

draw_info->fill_pattern = mw->images; //设置填充图片

 

if(mw_frame == NULL)

{

    //如果 mw_pre 不为空, 就使用上一个 mw_pre, 反之就新建一个新画布

    mw_frame = mw_pre ? mw_pre : imgNewCanvas(width, height, "#000000");

}

DrawImage(mw_frame->images, draw_info); //绘制图片, 在这里有的时候会卡住,频率在: 10%左右

 

2014-09-14

posted @ 2015-06-18 09:57  personnel  阅读(719)  评论(0编辑  收藏  举报
友情链接:图片批量处理工具 gif动态图制作工具 制作电子相册 图片排版工具 制作淘宝主图视频 MKScript 鼠标键盘自动化脚本语言