问题:
该函数中用Graphics::drawImage显示图片,如下示
boolean b=false;
b=g.drawImage(imgError,thex(i),they(j),this);
在开始的一段时间内返回值b经常会是false,导致显示不正常,但是,只要显示一段时间后,即该函数被调用若干次后返回值b就会一直是true,再也不会返回false了。
解决方法:
当drawImage这个方法中的图片没有被完全加载的时候,这个方法会返回false。drawImage方法是在调用的时候才加载所需要的图片,所以第一次调用的时候,图片没有被完全加载,造成显示的不正常,甚至不显示图片,此后,图片由于方法调用被加载,以后再以这幅图片为参数的时候,就可以正常显示了。使用MediaTracker类
Image img = Toolkit.getDefaultToolkit().getImage(imgPath);
MediaTracker t = new MediaTracker(this);
t.addImage(img, 0);
t.waitForAll();
将这段代码在drawImage()之前调用,MediaTracker可以确保你的图片在DRAW前被加载以备使用。通过addImage方法加入一个Image并符上一个ID号,waitForAll()等待加入的所有图片被加载完毕。也就是说先前只要正常显示过一次了,那么应该图片已经加载好了,此后此图片就再也不会出现返回false而不能正常显示了。如果只使用drawImage那么是在调用的时候加载图片,如果这个图片在本地,那么加载好图片的速度相当的快。再次调用drawImage方法的时候就能正常显示了。也可以在初始化时对每个图片显示一下,直到每个图片显示都返回true,这样之后就不会再出现不正常的显示了。我想这样每个图片一开始都显示一遍,刚好还可以做程序的开始动画呢:)
分享到:
相关推荐
主要介绍了详解canvas drawImage()方法绘制图片不显示的问题的相关资料,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
主要介绍了微信小程序canvas.drawImage完全显示图片问题的解决,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
drawImage_src
drawImage_demo
Graphics_DrawImage 使用方法 与博客文章同步 不喜勿下,WINCE版本 MC55测试通过
matlab开发-drawimage。获取徒手涂鸦的坐标
主要介绍了小程序中canvas的drawImage方法参数使用详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
对canvas.drawImage方法的相关参数进行图像化描述,方便理解。
MFC编写的图像软件,可绘制出Bezier,B样条和Hermite曲线,界面美观,代码条理清晰,可供学习用。
问题描述 问题产生 对于微信小程序,canvas处理过程中,dramImage默认...解决方案 准备工作 Page({ data:{ imgSrc: '', // 需要处理图片地址 imgW: '', // canvas 宽度 imgH: '', // canvas 高度 byclear: 1 /
3.3_drawImage的参数详解|Canvas图像基础|Canvas图形、动画、游戏开发从入门到精通全系列课程
下面就来一起解决下 二.方法 (一).使用mode:widthFix widthFix:宽度不变,高度自动变化,保持原图宽高比不变。 首先我们先设置image的mode为widthFix,然后给图片加一个固定rpx的宽度,比如:730rpx。 ...
D3DTexture中绘制图像部分函数的参数说明和解释
drawImage.js
drawImage()是一个很关键的方法,它可以引入图像、画布、视频,并对其进行缩放或裁剪。 一共有三种表现形式: 语法 1 JavaScript Code复制内容到剪贴板 context.drawImage(img,dx,dy); 语法 2 JavaScript Code...
本文实例分析了HTML5中drawImage使用时遇到的问题及解决方法。分享给大家供大家参考。具体分析如下: 使用Image遇到的问题: 复制代码代码如下:<!DOCTYPE html><html> <head> <meta charset=”utf...
基于mfc实现基本画图,能画直线 折线 三角形 和椭圆