QGraphicsView实现简易地图20『鹰眼视图-全图显示』

news2025/1/13 10:42:52

前文链接:QGraphicsView实现简易地图19『迁徙图』
鹰眼视图-全图显示
能够显示所有已加载的瓦片地图,支持当前视口的范围显示器。鼠标在鹰眼视图上移动时,支持是否干预主视图地图加载两种模式,即移动时是否让主视图加载空白处的瓦片。
动态演示效果
这里演示的是鹰眼视图移动时不干预主视图的地图加载

静态展示图片
在这里插入图片描述

核心代码

void EagleView::paintEvent(QPaintEvent *event)
{
	QGraphicsScene *scene = m_mainView->scene();
	// 设置图像大小与场景图元边界大小一致
	QRect itemsBoundingRect = m_mainView->tilesBoundingRect();
		
	int viewW = viewport()->width();
	int viewH = viewport()->height();
	double scaleW = itemsBoundingRect.width() * 1.0 / viewW;
	double scaleH = itemsBoundingRect.height() * 1.0 / viewH;
	m_backgroundScale = qMax(scaleW, scaleH);
	double pixmapW = itemsBoundingRect.width() / m_backgroundScale;
	double pixmapH = itemsBoundingRect.height() / m_backgroundScale;

	m_backgroundRect = QRectF(0, 0, pixmapW, pixmapH);
	if (pixmapW < viewW)
		m_backgroundRect.moveLeft((viewW - pixmapW) / 2);
	if (pixmapH < viewH)
		m_backgroundRect.moveTop((viewH - pixmapH) / 2);

	// 渲染图像
	QPixmap	pixmap(pixmapW, pixmapH);
	pixmap.fill(Qt::red);
	QPainter painter;
	painter.begin(viewport());
	painter.setRenderHints(/*QPainter::Antialiasing | */QPainter::/*HighQualityAntialiasing*/SmoothPixmapTransform);
	scene->render(&painter, m_backgroundRect, itemsBoundingRect);

	// 范围指示器
	int mainViewW = m_mainView->viewport()->width();
	int mainViewH = m_mainView->viewport()->height();
	scaleW = mainViewW * 1.0 / itemsBoundingRect.width();
	scaleH = mainViewH * 1.0 / itemsBoundingRect.height();
	double scale = qMax(scaleW, scaleH);
	if (scale >= 1)
	{// 当比率>=1时,矩形导航框为整个鹰眼视图中的背景图元大小
		QPointF viewportTopLeftToScenePos = m_mainView->mapToScene(QPoint(0, 0));
		// 调整位置
		double x, y, w, h;
		if (scaleW >= 1)
		{
			w = m_backgroundRect.width();
			x = m_backgroundRect.x() + 1;
		}
		else
		{
			w = pixmapW * scaleW;
			double offsetX = m_backgroundRect.x();
			x = offsetX + (viewportTopLeftToScenePos.x() - itemsBoundingRect.x()) / itemsBoundingRect.width() * pixmapW;
		}

		if (scaleH >= 1)
		{
			h = m_backgroundRect.height();
			y = m_backgroundRect.y();
		}
		else
		{
			h = pixmapH * scaleH;
			double offsetY = m_backgroundRect.y();
			y = offsetY + (viewportTopLeftToScenePos.y() - itemsBoundingRect.y()) / itemsBoundingRect.height() * pixmapH;
		}

		m_indicatorRect = QRectF(x, y, w - 1, h);
		painter.setPen(Qt::red);
		painter.drawRect(m_indicatorRect);

		m_restrictRect = m_backgroundRect.adjusted(w / 2, h / 2, -w / 2, -h / 2);
	}
	else// scale < 1
	{// 当比率<1时,矩形导航框为主视窗中图元占整个场景图元的比率所对应的鹰眼视图大小
		QPointF viewportTopLeftToScenePos = m_mainView->mapToScene(QPoint(0, 0));
		// 调整位置
		double offsetX = m_backgroundRect.x();
		double offsetY = m_backgroundRect.y();
		double x = offsetX + (viewportTopLeftToScenePos.x() - itemsBoundingRect.x()) / itemsBoundingRect.width() * pixmapW;
		double y = offsetY + (viewportTopLeftToScenePos.y() - itemsBoundingRect.y()) / itemsBoundingRect.height() * pixmapH;
		double w = pixmapW * scaleW;
		double h = pixmapH * scaleH;
		m_indicatorRect = QRectF(x, y, w - 1, h);
		painter.setPen(Qt::red);
		painter.drawRect(m_indicatorRect);

		m_restrictRect = m_backgroundRect.adjusted(w / 2, h / 2, -w / 2, -h / 2);
	}

	QGraphicsView::paintEvent(event);
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1805211.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

无头+单向+非循环链表的实现

这里写目录标题 1. 链表1.1 链表的概念及结构1.2 链表的分类 2. 接口实现3. 链表的实现3.1 打印链表3.2 头插3.3 尾插3.4 头删3.5 尾删3.6 单链表查找3.7 在pos之前插入3.8 在pos之后插入3.9 删除pos位置的值3.10 删除pos位置之后的值3.11 链表的释放3.12 动态申请一个节点 4. …

基于SVPWM矢量控制的无速度传感器电机控制系统simulink建模与仿真

目录 1.课题概述 2.系统仿真结果 3.核心程序与模型 4.系统原理简介 5.完整工程文件 1.课题概述 基于SVPWM矢量控制的无速度传感器电机控制系统simulink建模与仿真&#xff0c;包括电机&#xff0c;SVPWM模块&#xff0c;矢量控制器模块等。 2.系统仿真结果 3.核心程序与模…

【Java 百“练”成钢】Java 基础:带参数的方法

Java 基础&#xff1a;带参数的方法 01.求和02.字符串输出03.寻找最大值04.寻找最小值05.字符串拼接06.求平均值07.数组排序08.累乘09.存在的字符串10.长整型求和11.寻找字符串索引12.字符串拼接&#xff08;StringBuilder&#xff09; 01.求和 public class SumCalculator {s…

各类电机数学模型相关公式总结 —— 集成芯片驱动

0、背景技术概述 永磁直流电机&#xff08;PMDC&#xff09;、永磁同步电机&#xff08;PMSM&#xff09;、无刷直流电机&#xff08;BLDC&#xff09;以及混合式两相步进电机在小功率应用场景中多采用集成芯片驱动&#xff08;如二合一、三合一驱动芯片&#xff09;的原因主要…

python 多任务之多线程

多线程 线程是程序执行的最小单位&#xff0c;实际上进程只负责分配资源&#xff0c;而利用这些资源执行程序的是线程&#xff0c;也就是说进程是线程的容器&#xff0c;一个进程中最少有一个线程来负责执行程序&#xff0c;它可以与同属一个进程的其它线程共享进程所拥有的全…

前端使用轮播图的方法有哪些

前端使用轮播图的方法可以使用swiper:Swiper中文网-轮播图幻灯片js插件,H5页面前端开发 这是swiper官网,在官网里面可以找到很多轮播图的实际案例: 我们挑选可用的案例或者修改的案例,打开后打开源码,就可以获取到当前的源码了,加以调试就可以获得我们需要的结果, 例如: 上图…

openai 前员工释放出关于AGI的前世今生和未来发展趋势的详细报告

目录 1.引言2.AGI的临近3.投资与工业动员4.国家安全与AI竞赛5.技术挑战与机遇6.项目与政策7.结语8.原文PDF链接PS.扩展阅读ps1.六自由度机器人相关文章资源ps2.四轴机器相关文章资源ps3.移动小车相关文章资源 1.引言 2024年&#xff0c;我们站在了一个全新的科技前沿。在这篇文…

LabVIEW电机槽楔松动声测系统

LabVIEW电机槽楔松动声测系统 开发了一种利用LabVIEW软件和硬件平台&#xff0c;为大型电机设计的槽楔松动声测系统。该系统通过声波检测技术&#xff0c;实现了对电机槽楔是否松动的快速准确判断&#xff0c;极大地提高了检测效率和安全性。 项目背景 大型电机在运行过程中…

python-微分方程计算

首先导入数据 import numpy as np from scipy.integrate import odeint from scipy.optimize import minimize import matplotlib.pyplot as pltdata np.array([[30, 4],[47.2, 6.1],[70.2, 9.8],[77.4, 35.2],[36.3, 59.4],[20.6, 41.7],[18.1, 19],[21.4, 13],[22, 8.3],[2…

字符串形成树形

字符串形成树形 有的时候我们形成树形不是以ID的关系进行匹配的而是以字符串进行形成 数据 CREATE TABLE `contract_main_org_info` (`id` bigint(20) NOT NULL COMMENT 组织单位id,`parent_id` int(11) NULL DEFAULT NULL COMMENT 父组织单位id,`org_name` varchar(255) CHA…

什么是pump?pump跟单机器人是什么?

区块链pump&#xff08;拉盘&#xff09;是一种市场操纵策略&#xff0c;通常指在短时间内人为抬高某种加密货币的价格&#xff0c;从而吸引其他投资者购买&#xff0c;随后通过快速出售&#xff08;dump&#xff09;获利。这种策略通常由一群协调好的投资者或交易团体执行&…

学习使用 Frida 过程中出现的问题

一、adb shell命令报错&#xff1a;error: no devices found 目前该问题解决方法仅供参考&#xff0c;可先看看再选择试试&#xff01;&#xff01;&#xff01;&#xff01;&#xff01; 查看此电脑也会发现没有出现手机型号文件夹。 第一步&#xff1a; 检查一下手机开了u…

适用于电脑的 5 大嗨格式数据恢复替代方案

嗨格式数据恢复是有一定知名度的 Windows 和 Mac 恢复程序&#xff0c;旨在恢复格式化、删除和丢失的图片、视频和音频。该应用程序支持多种文件格式以及相机 RAW 图像。最好的部分&#xff1f;它的预览功能可以在恢复照片和其他媒体文件之前检查和验证它​​们——这可以节省大…

Golang | Leetcode Golang题解之第139题单词拆分

题目&#xff1a; 题解&#xff1a; func wordBreak(s string, wordDict []string) bool {wordDictSet : make(map[string]bool)for _, w : range wordDict {wordDictSet[w] true}dp : make([]bool, len(s) 1)dp[0] truefor i : 1; i < len(s); i {for j : 0; j < i;…

简单的基于threejs和BVH第一人称视角和第三人称视角控制器

渲染框架是基于THREE,碰撞检测是基于BVH。本来用的是three自带的octree结构做碰撞发现性能不太好 核心代码&#xff1a; import * as THREE from three import { RoundedBoxGeometry } from three/examples/jsm/geometries/RoundedBoxGeometry.js; import { MeshBVH, MeshBVHHe…

C++做题

我们可以将0——9看成一个一维数组&#xff1a;a[11] #include<cstdio> int a[11],n; int x,p; int main(){scanf("%d",&n);for(int i1;i<n;i){pi;while(p!0){xp%10;a[x];//让下标x每次出现时增加1(描述不清楚)p/10;}}for(int i0;i<9;i){printf(&qu…

Linux—小小内核升级

本篇主要是讲述下关于内核的一些基本常识&#xff0c;并记录下内核升级和编译的过程&#xff0c;若有遗漏/有误之处&#xff0c;望各位大佬们指出。 Ⅰ 基本内核常识 常见内核安装包 内核(kernel)&#xff1a;这是Linux操作系统的核心部分&#xff0c;它负责管理系统的硬件和…

拉格朗日乘子将不等式约束转化为等式约束例子

拉格朗日乘子将不等式约束转化为等式约束例子 在优化问题中,常常需要将不等式约束转化为等式约束。使用拉格朗日乘子法,可以通过引入松弛变量将不等式约束转换为等式约束,然后构造拉格朗日函数进行求解。 拉格朗日乘子法简介 拉格朗日乘子法是求解带约束优化问题的一种方…

局域网测速

对于网管来说&#xff0c;企业局域网络的速度是知道的&#xff0c;因为网管清楚企业局域网络的拓扑结构、网络链路、网络设备以及实际到桌面的情况。 有时候即使千兆到桌面实际因为影响的因素多&#xff0c;实际的网络速度可能会打一定的折扣&#xff0c;那么就需要清楚实际的网…

数据挖掘分析的一点进步分享

import pandas as pd import matplotlib.pyplot as plt import numpy as npdata pd.read_csv(heros.csv,encoding"gbk") data.head() 导入数据集 进行分析 df_datadata.copy() df_data.describe()df_data.info() df_data.drop(英雄,axis1,inplaceTrue) df_data[最…