error C2664: 'PolyBezier' : cannot convert parameter 1 from 'struct CEx07aDoc::tagPOINT [10]' to 'const struct tagPOINT *'怎么回

Ilovestephenson 2005-09-12 09:50:46
尝试强制类型转换还是不行!有人知道怎么解决吗?

问题如下:
在class CEx07aDoc中定义POINT并定义POINT类型的数组变量:

typedef struct tagPOINT{
LONG x;
LONG y;
}POINT;

POINT BezierPoint[10];

在void CEx07aView::DrawBezier (CDC *pDC)中调用CDC的成员函数PolyBezier
其函数原型为PolyBezier(const tagPOINT*,int)

pDC->PolyBezier(pDoc->BezierPoint , 4);
程序编译无误,但是假如这个语句之后就会出现错误,错误提示如下:
error C2664: 'PolyBezier' : cannot convert parameter 1 from 'struct CEx07aDoc::tagPOINT [10]' to 'const struct tagPOINT *'
Types pointed to are unrelated; conversion requires reinterpret_cast, C-style cast or function-style cast

尝试用强制转换还是出现同样的错误,有哪位知道的指点下,如果需要完整的程序,请回帖告诉我
我会发到你的邮箱,我的邮箱是zhanghuiling_1983@56.com,也可以发邮件给我!

我尝试过在网搜索相关的文章,搜到了一篇,不过我看得也没能解决这个问题。所以希望在这里能够得到解决方案。先在这里表示感谢了!


...全文
273 7 打赏 收藏 转发到动态 举报
写回复
用AI写文章
7 条回复
切换为时间正序
请发表友善的回复…
发表回复
rageliu 2005-09-13
  • 打赏
  • 举报
回复
顶...
alen_ghl 2005-09-13
  • 打赏
  • 举报
回复
同意,换个名字
菜牛 2005-09-13
  • 打赏
  • 举报
回复
POINT是已经有定义的了,你最好另外给个名字,这种习惯不好。

'CEx07aDoc::tagPOINT [10]' 可见你是在CEx07aDoc内部定义结构的,放到外部去。
jjiaming 2005-09-13
  • 打赏
  • 举报
回复
源码已经收到
把pDC->PolyBezier(pDoc->BezierPoint , 4);
改为 pDC->PolyBezier((tagPOINT *)pDoc->BezierPoint , 4);
就可以了。我刚刚试过了。
菜牛 2005-09-13
  • 打赏
  • 举报
回复
这个结构的声明放到CEx07aDoc前面去,不要放在内部。
Ilovestephenson 2005-09-13
  • 打赏
  • 举报
回复
大家提到的这个确实是个好的意见,以后我会注意的,但是对于这个问题来说,改了之后并不见效!
希望大家继续帮我找原因,如果我找出解决办法,我会在这里贴出来的

谢谢各位了!
jjiaming 2005-09-12
  • 打赏
  • 举报
回复
POINT结构不是MFC中已经定义的了吗?
把你的代码发过来看看
lliulean@yahoo.com.cn
代码下载链接: https://pan.quark.cn/s/23ff226fe24b ### iTest自动化测试工具知识点详解#### 一、iTest自动化测试工具简介iTest是由业界领先测试设备制造商Spirent所研发的一款自动化测试工具。该工具为用户呈现了一个集成化的自动化测试解决方案,借助这一工具,用户能够完成软件及网络测试的编写与自动化执行。iTest不仅适用于专业的测试工程师,对于非测试人员来说,同样是一个功能强大的工具,能够协助他们对网络中的设备和应用进行访问和自动化操作。#### 二、iTest Lite快速入门指南iTest Lite是一款免费提供给用户的版本,其目的是为用户呈现一个简明的iTest产品概览。用户可以从官方网站(www.fanfaresoftware.com)获取并安装iTest Lite。此工具不仅能够支持用户进行软件和网络测试,还能用于对网络上的设备或应用程序进行管理和自动化。#### 三、iTest的工作流程- **主页内容**:在iTest被启动之后,主页内容将展示在右侧,而活动列表则位于左侧。主页上不仅包含欢迎消息,还会提供iTest工作流程的高级图示以及链接到Fanfare社区的入口,用户可以通过论坛帖子、教程视频等资源进一步了解iTest。 - **活动列表**:这是使用iTest功能的推荐起点。活动列表包含以下几个部分: - **连接设备**:一种便捷的方法来验证iTest是否能够连接到测试设备。 - **构建拓扑结构**:在这一步骤中,可以迅速定义一组想要进行测试的设备或应用程序。 - **开发测试用例**:创建一个自动化的测试用例,用于针对任何特定的拓扑结构进行测试。 - **查看测试报告**:访问个人...
代码下载链接: https://pan.quark.cn/s/89ea75840350 STM32微控制器的实时时钟(RTC)作为一个独立的计时单元,能够在系统重启或从休眠状态激活后持续保持时间设置不变。本文将详细探究STM32 RTC的运行机制,涵盖时钟结构图解析以及时间显示的原理。需要明确的是,STM32的RTC模块坐落于备份领域(Backup domain),它借助32.768kHz的辅助晶体振荡器作为时钟供给。在进行RTC编程实践时,务必小心谨慎地处理与RTC相关的寄存器配置。随后,我们将借助RTC时钟结构图展开深入剖析。时钟结构图主要由两大块构成:APB1接口区块与RTC主控单元。APB1接口区块负责对与RTC关联的寄存器进行数据交互,而RTC主控单元内含两个子模块:RTC分频调节模块以及一个32位可变步长计数器。在RTC主控单元内部,有几个关键寄存器是必须掌握的:1. RTC_DIV(RTC分频调节余数寄存器):此寄存器旨在获取超越秒级的更高精度时间(如0.1秒、0.01秒)。该寄存器在数值减至极值后会由硬件自动重置。其数值由RTC_PRL(RTC分频调节装载寄存器)提供,其时钟频率源自RTCCLK。2. RTC_PRL(RTC分频调节装载寄存器):它为RTC_DIV提供重置数值,同时用于设定时钟频率的缩放比例。例如,若晶体振荡器频率为32.768KHz,将RTC_PRL设定为32767,即可得到每秒的计数速率。3. RTC_CNT(RTC计数器寄存器):该寄存器记录秒数,并可用于触发计数器溢出中断。4. RTC_ALR(RTC闹钟寄存器):用于设定闹钟时刻,一旦计数器的数值与闹钟寄存器匹配,并且中断功能已启用,便会引发一个闹钟中断事件。在物理实现层...

16,551

社区成员

发帖
与我相关
我的任务
社区描述
VC/MFC相关问题讨论
社区管理员
  • 基础类社区
  • Creator Browser
  • encoderlee
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

        VC/MFC社区版块或许是CSDN最“古老”的版块了,记忆之中,与CSDN的年龄几乎差不多。随着时间的推移,MFC技术渐渐的偏离了开发主流,若干年之后的今天,当我们面对着微软的这个经典之笔,内心充满着敬意,那些曾经的记忆,可以说代表着二十年前曾经的辉煌……
        向经典致敬,或许是老一代程序员内心里面难以释怀的感受。互联网大行其道的今天,我们期待着MFC技术能够恢复其曾经的辉煌,或许这个期待会永远成为一种“梦想”,或许一切皆有可能……
        我们希望这个版块可以很好的适配Web时代,期待更好的互联网技术能够使得MFC技术框架得以重现活力,……

试试用AI创作助手写篇文章吧