java数图像处理常用算.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
前些时候做毕业设计,用java做的数字图像处理方面的东西,这方面的资料ms比较少,发点东西上来大家共享一下,主要就是些算法,有自己写的,有人家的,还有改人家的,有的算法写的不好,大家不要见笑。 一 读取bmp图片数据 //? 获取待检测图像?,数据保存在数组 nData[],nB[]?,nG[]?,nR[]中 ?public? void getBMPImage(String source) throws Exception { ?????????? ???????? clearNData();??????????????????????? //清除数据保存区 ???????? FileInputStream fs = null; ??????? ??????? try { ??????????? fs = new FileInputStream(source); ??????????? int bfLen = 14; ??????????? byte bf[] = new byte[bfLen]; ??????????? fs.read(bf, 0, bfLen); // 读取14字节BMP文件头 ??????????? int biLen = 40; ??????????? byte bi[] = new byte[biLen]; ??????????? fs.read(bi, 0, biLen); // 读取40字节BMP信息头 ??????????? // 源图宽度 ??????????? nWidth = (((int) bi[7] 0xff) 24) ??????????????????? | (((int) bi[6] 0xff) 16) ??????????????????? | (((int) bi[5] 0xff) 8) | (int) bi[4] 0xff; ??????????? // 源图高度 ??????????? nHeight = (((int) bi[11] 0xff) 24) ??????????????????? | (((int) bi[10] 0xff) 16) ??????????????????? | (((int) bi[9] 0xff) 8) | (int) bi[8] 0xff; ??????????? // 位数 ??????????? nBitCount = (((int) bi[15] 0xff) 8) | (int) bi[14] 0xff; ??????????? // 源图大小 ??????????? int nSizeImage = (((int) bi[23] 0xff) 24) ??????????????????? | (((int) bi[22] 0xff) 16) ??????????????????? | (((int) bi[21] 0xff) 8) | (int) bi[20] 0xff; ??????????? // 对24位BMP进行解析 ??????????? if (nBitCount == 24){ ??????????????? int nPad = (nSizeImage / nHeight) - nWidth * 3; ??????????????? nData = new int[nHeight * nWidth]; ??????????????? nB=new int[nHeight * nWidth]; ??????????????? nR=new int[nHeight * nWidth]; ??????????????? nG=new int[nHeight * nWidth]; ??????????????? byte bRGB[] = new byte[(nWidth + nPad) * 3 * nHeight]; ??????????????? fs.read(bRGB, 0, (nWidth + nPad) * 3 * nHeight); ??????????????? int nIndex = 0; ??????????????? for (int j = 0; j nHeight; j++){ ??????????????????? for (int i = 0; i nWidth; i++) { ??????????????????????? nData[nWidth * (nHeight - j - 1) + i] = (255 0xff) 24 ??????????????????????????????? | (((int) bRGB[nI

文档评论(0)

mv2323 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档