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;
			}	
		}
	}
}

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

相关推荐
Humbunklung26 分钟前
unordered_map使用MFC的CString作为键值遇到C2056和C2064错误
c++·stl·mfc
爱编程的化学家1 小时前
代码随想录算法训练营第十一天--二叉树2 || 226.翻转二叉树 / 101.对称二叉树 / 104.二叉树的最大深度 / 111.二叉树的最小深度
数据结构·c++·算法·leetcode·二叉树·代码随想录
眠りたいです2 小时前
基于脚手架微服务的视频点播系统-数据管理与网络通信部分的预备工作
c++·qt·ui·微服务·云原生·架构·媒体
烦躁的大鼻嘎2 小时前
【Linux】深入Linux多线程架构与高性能编程
linux·运维·服务器·开发语言·c++·ubuntu
野生的编程萌新2 小时前
【C++深学日志】C++编程利器:缺省参数、函数重载、引用详解
c语言·开发语言·c++
愚润求学2 小时前
【贪心算法】day10
c++·算法·leetcode·贪心算法
智者知已应修善业3 小时前
【矩阵找最大小所在位置】2022-11-13
c语言·c++·经验分享·笔记·算法·矩阵
小柯J桑_3 小时前
C++之特殊类设计
java·开发语言·c++
bikong74 小时前
Qt/C++,windows多进程demo
c++·windows·qt
努力学习的小廉4 小时前
我爱学算法之—— 位运算(上)
c++·算法