EnergySpectrumAnalyer/src/ThreeDimensionalConformityAnalysisView/ParticleDataStatistics.h

56 lines
1.7 KiB
C
Raw Normal View History

2026-03-26 17:35:58 +08:00
#ifndef PARTICLEDATASTATISTICS_H
#define PARTICLEDATASTATISTICS_H
#include <QWidget>
#include "DetectorStatusSummary.h"
#include "CoincidenceSpectrumProcess.h"
#include <QMap>
using namespace CoincidenceSpectrum;
namespace Ui {
class ParticleDataStatistics;
}
class ParticleDataStatistics : public QWidget
{
Q_OBJECT
public:
explicit ParticleDataStatistics(QWidget *parent = nullptr);
~ParticleDataStatistics();
void setWidgetData(int board, int channel, int countNum, int secondNum);
void setInitWidgetData(int board, int channel, int countNum, int secondNum);
//处理板卡信息
void handleBoard(std::vector<F2t9Order::SpectrumData> eventData);
//设置数据
void setCoincidenceEvent(const F2t9Order::CoincidenceEvent &CoincidenceEvent);
private:
// 初始化映射表
void InitUi();
//统计每个板卡的初级粒子计数
QMap<QString, int> statisticsFirstParticleQuantity();
//处理初级粒子信息
std::vector<F2t9Order::SpectrumData> handleBasicSubordinate(std::vector<F2t9Order::SpectrumData> dataList,int Board, int Channel);
private slots:
//点击板卡探测器时触发的函数 区分初级粒子和次级粒子计数
void _slotClickedBoard(QString board);
void _slotClickedTwoBoard(QString board);
signals:
void Signal_InitialState();
void Signal_ClickedBoard(int board,int channel);
private:
Ui::ParticleDataStatistics *ui;
// 存储所有 DetectorStatusSummary 指针的二维数组索引从0开始
DetectorStatusSummary* m_widgetMap[MAX_BOARD][MAX_CHANNEL];
//初级粒子板卡号
int m_bd;
//初级粒子通道号
int m_ch;
};
#endif // PARTICLEDATASTATISTICS_H