EasyRadar-类的多态

博客主要介绍雷达数据处理相关内容。先通过CString的find()函数打开雷达文件,判断雷达类型并选择相应雷达类;接着利用类的多态,以基类CRadar及子类CSCRadar、CSARadar实现对选择的雷达类的操作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.识别选择的雷达数据文件

打开一个雷达文件,判断雷达类型,选择相应的雷达类
(通过CSring 的 find() 函数)

void CEasyRadarDoc::OnFileOpen()
{
	// TODO: 在此添加命令处理程序代码
	CFileDialog dlg(true);
	CString filename;

	if(dlg.DoModal() == IDOK){
		filename = dlg.GetFileName();//获得数据文件名
		
		if(filename.Find(_T("SA")) != -1) m_Radar = &m_SAradar;//find函数未找到返回-1;类的多态
		else if(filename.Find(_T("SC")) != -1) m_Radar = &m_SCradar;
		else return;

		if(!m_Radar->DecodeFile(dlg.GetPathName())) AfxMessageBox(_T("数据文件解码失败"));
		else{
			m_Radar->DrawVolPolar(0);//画图
			m_fileflag = true;//数据flag
		}
	}
}

2.类的多态实现操作选择的雷达类

#include "Radar.h"
#include "SARadar.h"
#include "SCRadar.h"
-------------------
public:
	CRadar *m_Radar;
	CSARadar m_SAradar;
	CSCRadar m_SCradar;

基类CRadar

#pragma once

class CRadar
{
public:
	CRadar(void);
	virtual ~CRadar(void);
public:
	virtual int DecodeFile(CString filepath);
	virtual int DrawVolPolar(int layer);//layer为层
};

子类CSCRadar

class CSCRadar :
	public CRadar
{
public:
	CSCRadar(void);
	virtual ~CSCRadar(void);

public:
	virtual int DecodeFile(CString filepath);//解码
	virtual int DrawVolPolar(int layer);//layer为层
	int PreDraw();//双缓存设置
private:
	//雷达参数
	FILEHEADRADARSC m_FileHeadSC;
	DATARECORDSC m_DataSC;
	float ***m_ref;//反射率
	float *m_el;//仰角
	float **m_az;//方位角
	int *m_radialnum;//层径向数
	int *m_binnum;//库数
	int *m_binwidth;//库宽

	float m_radLat;
	float m_radLon;
	float m_radHgt;

	//画图参数
	CDC *m_clientdc;
	CDC *m_memDC;
	CBitmap *m_memBmp;
	CRect m_clientrect;
	int m_predrawflag;//画图flag,0:未设置双缓存;1:已设置双缓存
};

子类CSARadar

class CSARadar :
	public CRadar
{
public:
	CSARadar(void);
	~CSARadar(void);
public:
	virtual int DecodeFile(CString filepath);//解码
	virtual int DrawVolPolar(int layer);//layer为层
	int PreDraw();//双缓存设置
private:
	//雷达参数
	SA_DATA_LEVEL2_RADIAL m_rfh;//径向结构体
	float ***m_ref;//反射率
	float *m_el;//仰角
	float **m_az;//方位角
	int *m_radialnum;//层径向数
	int *m_binnum;//库数
	int *m_binwidth;//库宽

	//画图参数
	CDC *m_clientdc;
	CDC *m_memDC;
	CBitmap *m_memBmp;
	CRect m_clientrect;
	int m_predrawflag;//画图flag,0:未设置双缓存;1:已设置双缓存
	};
### 面向对象编程中的多态概念解释 多态是指方法或对象能够表现出多种形式的能力,这是面向对象编程的第三大特性[^1]。它允许程序在不同情况下执行不同的行为,增强了灵活性和扩展性。 #### 多态的具体表现形式 多态可以分为两种主要型: - **编译时多态(静态多态)** - 主要通过函数重载实现,在编译阶段就决定了具体调用的方法版本[^2]。 - **运行时多态(动态多态)** - 通常由子覆盖父的方法来达成,具体的实现取决于实例的实际型,只有到运行时刻才能确定。 #### 示例说明 下面是一个展示Java中多态特性的简单例子,其中包含了方法重写以及向上转型的概念: ```java // 定义一个基 Animal class Animal { public void makeSound() { System.out.println("Some generic animal sound"); } } // 创建 Dog 作为 Animal 的子并重写了 makeSound 方法 class Dog extends Animal { @Override public void makeSound() { System.out.println("Bark!"); } } public class Main { public static void main(String[] args) { // 向上转型:将子的对象赋给超型的变量 Animal myDog = new Dog(); // 调用的是 Dog 中被重写的 makeSound 方法 myDog.makeSound(); // 输出 "Bark!" } } ``` 在这个例子中,`myDog` 是 `Animal` 型的一个引用,但它指向了一个 `Dog` 对象。当调用 `makeSound()` 方法时,实际上执行的是 `Dog` 里定义的行为而不是 `Animal` 里的默认行为,这体现了运行时多态的特点。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值