qt的血泪教训——地图存储与绘制

文章目录

  • 前言
  • [一. 项目背景](#一. 项目背景)
  • [二. 代码实现](#二. 代码实现)
    • [1. 指针数组创建](#1. 指针数组创建)
    • [2. gui坐标和数组的对应问题](#2. gui坐标和数组的对应问题)

前言

本文并不是严格的教程,只是笔者考试一败涂地后的碎碎念

一. 项目背景

从文件读入数据, 文件共有M + 1行, 数据格式如下:

text 复制代码
m n
a(0,0) a(0,1) ... a(0,n-1)
...
a(m-1,0) a(m-1,1) ... a(m-1,n-1)

m为地图的行数, n为地图的列数,

a(x,y)表示第x行第y列的数值:

  • =0, 用绿色表示
  • =1, 用红色表示

二. 代码实现

1. 指针数组创建

c++ 复制代码
class MainWindow : public QWidget
{
	...
	int **map;
	int m, n;
};
void MainWindow::load()
{
	map = new int*[m]; // m行
	for(int i = 0; i < m; ++i){
		//注意, 这里是对刚刚创建好的每一行进行操作, 所以循环到m
		map[i] = new int[n];
	}
}

2. gui坐标和数组的对应问题

然后就是本文的核心了, 也是最容易弄错的地方. 由于存地图的时候先存行数后存列数, 所以每个坐标(x, y)表示的是x行y列, 然而在绘图的时候用的是xy坐标, 也就是说, 横坐标对应的是列数, 纵坐标对应的是行数, 和存储正好相反. 因此paint函数应该如下:

c++ 复制代码
void MainWindow::paintEvent(QPaintEvent *event)
{
	QPainter painter(this);
	const int FILE_SIZE = 60;
	for(int y = 0; y < m; ++y){//先行,先y
		for(int x = 0; x < n; ++x){//后列,后x
			switch(map[x][y]){
			case 0:
			painter.fillRect(x * FILE_SIZE, y * FILE_SIZE, FILE_SIZE, FILE_SIZE, Qt::green);
				break;
			case 1:
			painter.fillRect(x * FILE_SIZE, y * FILE_SIZE, FILE_SIZE, FILE_SIZE, Qt::red);
				break;
			}	
		}
	}
}

否则绘制出来的图形会是轴对称的,长宽颠倒.

相关推荐
6Hzlia2 分钟前
【Hot 100 刷题计划】 LeetCode 24. 两两交换链表中的节点 | C++ 精准指针舞步
c++·leetcode·链表
汉克老师34 分钟前
GESP2025年6月认证C++五级( 第一部分选择题(9-15))
c++·贪心算法·分治算法·二分算法·gesp5级·gesp五级·高精度除法
qiqsevenqiqiqiqi1 小时前
MT2048三连 暴力→数学推导→O (n) 优化
数据结构·c++·算法
ximu_polaris1 小时前
设计模式(C++)-行为型模式-模版方法模式
c++·设计模式
码之气三段.1 小时前
十五届山东ccpc省赛补题(update)
数据结构·c++·算法
王老师青少年编程2 小时前
csp信奥赛C++高频考点专项训练之贪心算法 --【跳跃与过河问题】:过河问题
c++·算法·贪心·csp·信奥赛·跳跃与过河问题·过河问题
是个西兰花2 小时前
C++11:智能指针
开发语言·c++·智能指针·rall
CN-Dust2 小时前
【C++专题】输出cout例题
开发语言·c++
小短腿的代码世界2 小时前
QCefView深度解析:Qt应用中嵌入Chromium浏览器的终极方案
开发语言·qt
沉默-_-2 小时前
备战蓝桥杯-哈希
c++·学习·算法·蓝桥杯·哈希算法