社区
图形处理/算法
帖子详情
有人做过线形算法吗?
IID
2003-12-12 10:28:52
有人做过线形算法吗?欢迎提供详细思路
...全文
16
4
打赏
收藏
有人做过线形算法吗?
有人做过线形算法吗?欢迎提供详细思路
复制链接
扫一扫
分享
转发到动态
举报
写回复
配置赞助广告
用AI写文章
4 条
回复
切换为时间正序
请发表友善的回复…
发表回复
打赏红包
bluebohe
2003-12-14
打赏
举报
回复
这些代码你研究一下
WINNT下,可以用以下方式创建画笔
LOGBRUSH brush;
brush.lbColor=DrawColor;
brush.lbStyle=BS_SOLID;
mPen.CreatePen(PS_GEOMETRIC|PS_USERSTYLE|PS_ENDCAP_FLAT,(int)LineWide,&brush,i,PenStyle);
Win98中,给DC设置合适的笔宽,选择实线,下面函数可以根据PenStyle数组给定长度值画直线。如果画曲线或者折线,需要把曲线离散成直线段,根据上次画线返回值确定本次画线的起始值,就可以了
#include "math.h"
DWORD PenStyle[16] = {0,0,0,0,0,0,0,0,
0,0,0,0,0,0,0,0};
typedef struct xyz {
double x;
double y;
double z;
} XYZ,*PXYZ,**PPXYZ;
//按照PenStyle[]画一条从p1点到p2点的直线
//例如PenStyle[0]=5,PenStyle[1]=2表示按照长度为5的实线、长度为2的间隔形成的线型画线
//_____ _____ _____ _
//并且指定从线型的何处画,例如iStart=6从Penstyle[1]处的第二个空格开始画
//iStart取值范围为0到一个线型的总长度-1
//返回值:线型总长度与剩余最后一段线长度之差,表示下一次画线应该指定的从何处开始画
int DrawLineA(CDC* pDC,POINT p1,POINT p2,int iStart)
{
int i=0;
int iEnd=0;//返回值,表示最后一段不完全的线段的长度
//计算直线长度
double dDistance=sqrt((p2.x-p1.x)*(p2.x-p1.x)+(p2.y-p1.y)*(p2.y-p1.y));
int iLineType=0;//线型的长度
if(dDistance<2)
{
for(i=0;i<16;i++)
{
if(PenStyle[i]==0)break;
iLineType+=PenStyle[i];
}
iEnd=(int(iStart-dDistance))%iLineType;
if(iEnd<0)iEnd+=iLineType;
return iEnd;
}
double ddltx[16]={0,0,0,0,//每一段线型的x距离
0,0,0,0,
0,0,0,0,
0,0,0,0};
double ddlty[16]={0,0,0,0,//每一段线型的y距离
0,0,0,0,
0,0,0,0,
0,0,0,0};
double dXScale=(p2.x-p1.x)/dDistance;//x方向长度和总长度比例
double dYScale=(p2.y-p1.y)/dDistance;//y方向长度和总长度比例
//计算每一段线型的x、y距离及线型的长度
for(i=0;i<16;i++)
{
if(PenStyle[i]==0)break;
ddltx[i]=PenStyle[i]*dXScale;
ddlty[i]=PenStyle[i]*dYScale;
iLineType+=PenStyle[i];
}
iEnd=(int(dDistance+iStart))%iLineType;
if(iEnd<0)iEnd+=iLineType;
XYZ pp={0,0,0};//第一段之前的完整线型开始点
pDC->MoveTo(p1);
int iLength=-iStart;//已经画的线段的长度
pp.x=iLength*dXScale+p1.x;
pp.y=iLength*dYScale+p1.y;
for(;;)
{
for(i=0;i<16;i++)
{
if(PenStyle[i]==0)break;
pp.x+=ddltx[i];
pp.y+=ddlty[i];
iLength+=PenStyle[i];
if(i%2==0)
{
if(iLength>0)
{
if(iLength<dDistance)
{
pDC->LineTo(pp.x,pp.y);
}
else
{
pDC->LineTo(p2);
return iEnd;
}
}
}else
{
if(iLength>0)
{
if(iLength<dDistance)
{
pDC->MoveTo(pp.x,pp.y);
}
else
{
pDC->MoveTo(p2);
return iEnd;
}
}
}
}
}
return iEnd;
}
IID
2003-12-14
打赏
举报
回复
TO:bluebohe(薄荷) ,是的,前两天网断了,没看到,谢谢
alphapaopao
2003-12-12
打赏
举报
回复
是线型吗?
bluebohe
2003-12-12
打赏
举报
回复
你说清楚一些,线型的话我做过
手把手教你学Python(进阶篇)
12_7_Pandas中分组操作 12_8_Pandas中数据合并操作 12_9_Pandas综合案例 12_10_本章小结 12_11_练习讲解 第13章 数据可视化-matplotlib 13_1_pyplot绘图基础 13_2_绘制
线形
图 13_3_绘制直方图 13_4_绘制条形图 13_5_...
特征编码在风控建模中的应用(上篇)—WOE是否可以提升集成
算法
效果?
在风控模型开流程中,使用的场景分别有A卡、B卡、C卡等模型,常规使用最多的就是逻辑回归
算法
。使用逻辑回归
算法
80%会使用的编码方式就是WOE编码,相信做模型的同学对这种编码方式非常熟悉。 做WOE的编码的好处,...
XY插值
算法
C语言,常用的插值
算法
有哪些?
原标题:常用的插值
算法
有哪些?在三维显示,空间可视化表达和图像处理中,插值处理是比较重要的一个部分。如何能找到快速、简单、有效的插值
算法
是目前研究者们津津乐道的问题。以下几种是前人收集起来的比较常用的...
svm的java实现
关于支持向量机这个东西,其实已经有很多相关的文章了,关于其原理也不是一两篇博客能概括的,包括
线形
可分时解的存在性、最优间隔分类器的问题转化、约束优化与无约束优化的转换、具体的无约束优化
算法
的选择、...
图形处理/算法
19,468
社区成员
50,698
社区内容
发帖
与我相关
我的任务
图形处理/算法
VC/MFC 图形处理/算法
复制链接
扫一扫
分享
社区描述
VC/MFC 图形处理/算法
社区管理员
加入社区
获取链接或二维码
近7日
近30日
至今
加载中
查看更多榜单
社区公告
暂无公告
试试用AI创作助手写篇文章吧
+ 用AI写文章