python---- pyqt 十字光标

# encoding: UTF-8
import sys,os

import pyqtgraph as pg
import datetime as dt
import numpy as np
import traceback

from pyqtgraph.Qt import QtGui, QtCore
from pyqtgraph.Point import Point
########################################################################
# 十字光标支持
########################################################################
class CrosshairTool(QtCore.QObject):
    """
    此类给pg.PlotWidget()添加crossHair功能,PlotWidget实例需要初始化时传入
    """
    signal = QtCore.pyqtSignal(type(tuple([])))
    #----------------------------------------------------------------------
    def __init__( self,pw,xAxis,viwe,parent=None):
        self.__view = viwe
        self.pw=pw
        self.xData=xAxis
        super(CrosshairTool, self).__init__()
        self.xAxis = 0
        self.yAxis = 0

        # 在y轴动态mid跟随最新价显示最新价和最新时间
        self.rects = [self.__view.vb.sceneBoundingRect()]
        self.__textDate = pg.TextItem()
        self.__textSig=pg.TextItem()
        self.__textDate.setZValue(2)
        self.__textSig.setZValue(2)
        # 注册十字光标
        self.vLine = pg.InfiniteLine(angle=90, movable=False)
        self.hLine = pg.InfiniteLine(angle=0, movable=False)
        self.vLine.setPos(0)
        self.hLine.setPos(0)
        self.__view.vb.addItem(self.vLine, ignoreBounds=True)
        self.__view.vb.addItem(self.hLine, ignoreBounds=True)
        self.__view.vb.addItem(self.__textDate, ignoreBounds=True)
        self.__view.vb.addItem(self.__textSig, ignoreBounds=True)
        self.proxy = pg.SignalProxy(self.pw.scene().sigMouseMoved, rateLimit=60, slot=self.mouseMoved)
        # 跨线程刷新界面支持
        self.signal.connect(self.update)

    # ----------------------------------------------------------------------
    def update(self, pos):
        """刷新界面显示"""
        xAxis, yAxis = pos
        xAxis, yAxis = (self.xAxis, self.yAxis) if xAxis is None else (xAxis, yAxis)
        self.moveTo(xAxis, yAxis)

    # ----------------------------------------------------------------------
    def mouseMoved(self, evt):

            pos = evt[0]  ## using signal proxy turns original arguments into a tuple
            self.rects = [self.__view.vb.sceneBoundingRect()]
            # if self.pw.sceneBoundingRect().contains(pos):
            mousePoint = self.__view.vb.mapSceneToView(pos)
            xAxis = mousePoint.x()
            yAxis = mousePoint.y()
            self.moveTo(xAxis, yAxis)

     # ----------------------------------------------------------------------

    def moveTo(self, xAxis, yAxis):
        xAxis, yAxis = (self.xAxis, self.yAxis) if xAxis is None else (xAxis, yAxis)
        self.rects = [self.__view.sceneBoundingRect() ]
        if not xAxis or not yAxis:
            return
        self.xAxis = xAxis
        self.yAxis = yAxis
        self.vhLinesSetXY(xAxis, yAxis)
        self.plotVolue(xAxis,yAxis)
    # ----------------------------------------------------------------------

    def vhLinesSetXY(self, xAxis, yAxis):
        """水平和竖线位置设置"""
        self.vLine.setPos(xAxis)
        self.hLine.setPos(yAxis)
    # ----------------------------------------------------------------------
    def plotVolue(self,xAxis,yAxis):
        if self.xData:
            if int(round(xAxis)) <=len(self.xData)-1:
                 xValue =self.xData[int(round(xAxis))]
            elif int(xAxis)>len(self.xData)-1:
                xValue=self.xData[len(self.xData)-1]
            else:
                xValue = self.xData[int(xAxis)]
            if (isinstance(xValue, dt.datetime)):
                xValueText = dt.datetime.strftime(xValue, '%Y-%m-%d %H:%M:%S')
            elif (isinstance(xValue, (str))):
                xValueText = xValue
            elif (isinstance(xValue, (int))):
                xValueText = xValue
            else:
                xValueText = ""
        else:
             xValueText=xAxis
        self.__textDate.setHtml(
            '<div style="text-align: center">\
                <span style="color: yellow; font-size: 20px;">x=%s</span>\
            </div>' \
            % (xValueText))
        self.__textSig.setHtml(
            '<div style="text-align: right">\
                <span style="color: yellow; font-size: 20px;">y=%0.2f</span>\
            </div>' \
            % (yAxis))
        # y,右上角显示
        rightAxis = self.__view.getAxis('right')
        rightAxisWidth = rightAxis.width()
        rectTextsig = self.__textDate.boundingRect()
        rectTextsigwidth = rectTextsig.width()
        topRight = self.__view.vb.mapSceneToView(
            QtCore.QPointF(self.rects[0].width() - (rightAxisWidth+rectTextsigwidth), self.rects[0].top()))
       if yAxis<self.rects[0].top():
           self.__textSig.anchor=Point((1,1));
       else:
           self.__textSig.anchor = Point((1, 0));
 
  

 


        self.__textSig.setPos(topRight.x(), yAxis)
        # X坐标
        rectTextDate = self.__textDate.boundingRect()
        rectTextDateHeight = rectTextDate.height()
        bottomAxis = self.__view.getAxis('bottom')
        bottomAxisHeight = bottomAxis.height()
        bottomRight = self.__view.vb.mapSceneToView(QtCore.QPointF(self.rects[0].width(), \
                                                                   self.rects[0].bottom() - (
                                                                       bottomAxisHeight + rectTextDateHeight)))
       # # 修改对称方式防止遮挡
        if xAxis >self.rects[0].width():
            self.__textDate.anchor = Point((1, 0))
        else:
            self.__textDate.anchor = Point((0, 0))
 
  

 



        self.__textDate.setPos(xAxis, bottomRight.y())

 

转载于:https://www.cnblogs.com/ft-Pavilion/p/7975729.html

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Python-pyqt5-hexview是一种基于Python和PyQt5这两个开发工具创建的十六进制数据查看器,是一个实用的工具,可以方便地查看二进制、十六进制数据。它提供了一种方便的方法来查看和编辑二进制文件,可以快速鉴定和分析数据,是开发人员、安全研究人员和网络管理员的理想选择。 Python-pyqt5-hexview可以明显提高开发人员的编程效率,节省时间和精力。它提供了一个友好的图形用户界面,用户可以在这个界面中选择要查看的数据文件,并自动将其转换成十六进制格式。具体而言,用户可以通过界面的文件浏览器来选择所需文件并打开文件。接下来,Python-pyqt5-hexview将自动将其读入并将数据转换成十六进制形式,并将其呈现在界面上。 Python-pyqt5-hexview支持多种常见的数据格式,以便用户可以轻松地查看和编辑复杂的数据文件。此外,它还具有许多其他功能,包括选择数据的起始和结束位置、搜索特定的十六进制模式、支持编辑和自动保存等。总之,Python-pyqt5-hexview是一个极为实用的数据查看器,为用户提供了一种方便、快速和高效的方式来查看和分析二进制和十六进制数据。 ### 回答2: Python-pyqt5-hexview是一种Python的库,是一个用于视觉化hex编辑器的插件。它使用PyQt5创建了一个用户界面,使用户能够以字节的形式查看和编辑二进制文件。此外,它还提供了搜索和替换功能,使用户能够快速准确地定位到需要编辑的信息。Python-pyqt5-hexview易于使用,具有良好的用户界面,是一款非常实用的工具。它可以被应用于各种领域,如数据恢复和修复、漏洞分析和漏洞利用。通过Python-pyqt5-hexview,用户可以查看和编辑数据,发现和利用漏洞,更好地理解和分析二进制文件。此外,它还可以被用于创建自定义hex编辑器,满足特定需求的个性化开发。总之,Python-pyqt5-hexview是一个功能强大的工具,为大量二进制文件的处理提供了方便、快捷的途径。 ### 回答3: Python-PyQt5-Hexview是一个Python和PyQt5编写的十六进制查看器,可以用于查看和编辑二进制文件。它具有用户友好的界面和丰富的操作功能,可以以字节为单位显示文件内容,并支持多种数据视图,方便用户查看和编辑不同格式的数据。此外,Python-PyQt5-Hexview还支持从文件和剪贴板中导入和导出数据,用户可以轻松地将文件内容复制到剪贴板并粘贴到其他应用程序中。除此之外,用户还可以将文件保存为常见的二进制文件格式,如.HEX或.BIN,方便用户进行后续的处理和分析。Python-PyQt5-Hexview还可以进行搜索和替换操作,用户可以快速定位和修改文件中的关键信息。Python-PyQt5-Hexview支持Windows、Linux和MacOS等多个操作系统,用户可以在不同平台上轻松使用它。总之,Python-PyQt5-Hexview是一个功能强大且易于使用的十六进制查看器,可以帮助用户快速查看和编辑二进制文件,是程序员和安全专家必备的工具之一。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值