完善目录结构
完善了目录结构,添加了以前的web段com组件调用的代码(在/测试目录下)(部署没有使用到)
This commit is contained in:
186
测试/单独功能测试/0-DLL测试(实际没有部署)/dll-goal无数据库/Thinner.cpp
Normal file
186
测试/单独功能测试/0-DLL测试(实际没有部署)/dll-goal无数据库/Thinner.cpp
Normal file
@@ -0,0 +1,186 @@
|
||||
//**************************************************************************
|
||||
//Thinner.cpp
|
||||
//细化算法实现文件
|
||||
//**************************************************************************
|
||||
//#include "StdAfx.h"
|
||||
#include <stdlib.h>
|
||||
#include <malloc.h>
|
||||
#include "Thinner.h"
|
||||
#include <stdio.h>
|
||||
|
||||
void beforethin(unsigned char *ip, unsigned char *jp, unsigned long lx, unsigned long ly){
|
||||
//void beforethin(char *ip, char *jp,
|
||||
// unsigned long lx, unsigned long ly)
|
||||
unsigned long i,j;
|
||||
|
||||
// printf("--Thinner_beforeThin--");
|
||||
for(i=0; i<ly; i++){
|
||||
for(j=0; j<lx; j++){
|
||||
//这里要视前景是白点还是黑点而定,可以改动
|
||||
//如果前景是白点,就是这样;反之反过来
|
||||
//jp[i*lx+j]=ip[i*lx+j];
|
||||
/* jp[i*lx+j]=255;*/
|
||||
if(ip[i*lx+j]>0)
|
||||
jp[i*lx+j]=0;
|
||||
else
|
||||
jp[i*lx+j]=255;
|
||||
}
|
||||
}
|
||||
}
|
||||
/////////////////////////////////////////////////////////////////////////
|
||||
//Rosenfeld细化算法
|
||||
//功能:对图象进行细化
|
||||
//参数:image:代表图象的一维数组
|
||||
// lx:图象宽度
|
||||
// ly:图象高度
|
||||
// 无返回值
|
||||
void ThinnerRosenfeld(void *image, unsigned long lx, unsigned long ly){
|
||||
char *f, *g;
|
||||
char n[10];
|
||||
char a[5] = {0, -1, 1, 0, 0};
|
||||
char b[5] = {0, 0, 0, 1, -1};
|
||||
char nrnd, cond, n48, n26, n24, n46, n68, n82, n123, n345, n567, n781;
|
||||
short k, shori;
|
||||
unsigned long i, j;
|
||||
long ii, jj, kk, kk1, kk2, kk3, size;
|
||||
|
||||
// printf("--Thinner_Rosenfeld--");
|
||||
size = (long)lx * (long)ly;
|
||||
|
||||
g = (char *)malloc(size);
|
||||
if(g==NULL){
|
||||
printf("error in alocating mmeory!\n");
|
||||
return;
|
||||
}
|
||||
|
||||
f = (char *)image;
|
||||
for(kk=0l; kk<size; kk++){
|
||||
g[kk] = f[kk];
|
||||
}
|
||||
|
||||
do{
|
||||
shori = 0;
|
||||
for(k=1; k<=4; k++){
|
||||
for(i=1; i<lx-1; i++){
|
||||
ii = i + a[k];
|
||||
|
||||
for(j=1; j<ly-1; j++){
|
||||
kk = i*ly + j;
|
||||
|
||||
if(!f[kk])
|
||||
continue;
|
||||
|
||||
jj = j + b[k];
|
||||
kk1 = ii*ly + jj;
|
||||
|
||||
if(f[kk1])
|
||||
continue;
|
||||
|
||||
kk1 = kk - ly -1;
|
||||
kk2 = kk1 + 1;
|
||||
kk3 = kk2 + 1;
|
||||
n[3] = f[kk1];
|
||||
n[2] = f[kk2];
|
||||
n[1] = f[kk3];
|
||||
kk1 = kk - 1;
|
||||
kk3 = kk + 1;
|
||||
n[4] = f[kk1];
|
||||
n[8] = f[kk3];
|
||||
kk1 = kk + ly - 1;
|
||||
kk2 = kk1 + 1;
|
||||
kk3 = kk2 + 1;
|
||||
n[5] = f[kk1];
|
||||
n[6] = f[kk2];
|
||||
n[7] = f[kk3];
|
||||
|
||||
nrnd = n[1] + n[2] + n[3] + n[4]
|
||||
+n[5] + n[6] + n[7] + n[8];
|
||||
if(nrnd<=1)
|
||||
continue;
|
||||
|
||||
cond = 0;
|
||||
n48 = n[4] + n[8];
|
||||
n26 = n[2] + n[6];
|
||||
n24 = n[2] + n[4];
|
||||
n46 = n[4] + n[6];
|
||||
n68 = n[6] + n[8];
|
||||
n82 = n[8] + n[2];
|
||||
n123 = n[1] + n[2] + n[3];
|
||||
n345 = n[3] + n[4] + n[5];
|
||||
n567 = n[5] + n[6] + n[7];
|
||||
n781 = n[7] + n[8] + n[1];
|
||||
|
||||
if(n[2]==1 && n48==0 && n567>0){
|
||||
if(!cond)
|
||||
continue;
|
||||
g[kk] = 0;
|
||||
shori = 1;
|
||||
continue;
|
||||
}
|
||||
if(n[6]==1 && n48==0 && n123>0) {
|
||||
if(!cond)
|
||||
continue;
|
||||
g[kk] = 0;
|
||||
shori = 1;
|
||||
continue;
|
||||
}
|
||||
if(n[8]==1 && n26==0 && n345>0){
|
||||
if(!cond)
|
||||
continue;
|
||||
g[kk] = 0;
|
||||
shori = 1;
|
||||
continue;
|
||||
}
|
||||
if(n[4]==1 && n26==0 && n781>0) {
|
||||
if(!cond)
|
||||
continue;
|
||||
g[kk] = 0;
|
||||
shori = 1;
|
||||
continue;
|
||||
}
|
||||
if(n[5]==1 && n46==0){
|
||||
if(!cond)
|
||||
continue;
|
||||
g[kk] = 0;
|
||||
shori = 1;
|
||||
continue;
|
||||
}
|
||||
if(n[7]==1 && n68==0){
|
||||
if(!cond)
|
||||
continue;
|
||||
g[kk] = 0;
|
||||
shori = 1;
|
||||
continue;
|
||||
}
|
||||
if(n[1]==1 && n82==0){
|
||||
if(!cond)
|
||||
continue;
|
||||
g[kk] = 0;
|
||||
shori = 1;
|
||||
continue;
|
||||
}
|
||||
if(n[3]==1 && n24==0){
|
||||
if(!cond)
|
||||
continue;
|
||||
g[kk] = 0;
|
||||
shori = 1;
|
||||
continue;
|
||||
}
|
||||
cond = 1;
|
||||
if(!cond)
|
||||
continue;
|
||||
g[kk] = 0;
|
||||
shori = 1;
|
||||
}
|
||||
}
|
||||
|
||||
for(i=0; i<lx; i++){
|
||||
for(j=0; j<ly; j++){
|
||||
kk = i*ly + j;
|
||||
f[kk] = g[kk];
|
||||
}
|
||||
}
|
||||
}
|
||||
}while(shori);
|
||||
free(g);
|
||||
}
|
||||
Reference in New Issue
Block a user