PyQt5 Pyqtgraph plot discret












1















At present, for this project, I'm working with matplolib to trace my plot.
Nevertheless, I wish to convert at pyqtgraph ( Pyqt5).
I didn't found how trace a discret plot of FFT with pyqtgraph, same the picture.
Have you an idea ?



enter image description here










share|improve this question





























    1















    At present, for this project, I'm working with matplolib to trace my plot.
    Nevertheless, I wish to convert at pyqtgraph ( Pyqt5).
    I didn't found how trace a discret plot of FFT with pyqtgraph, same the picture.
    Have you an idea ?



    enter image description here










    share|improve this question



























      1












      1








      1








      At present, for this project, I'm working with matplolib to trace my plot.
      Nevertheless, I wish to convert at pyqtgraph ( Pyqt5).
      I didn't found how trace a discret plot of FFT with pyqtgraph, same the picture.
      Have you an idea ?



      enter image description here










      share|improve this question
















      At present, for this project, I'm working with matplolib to trace my plot.
      Nevertheless, I wish to convert at pyqtgraph ( Pyqt5).
      I didn't found how trace a discret plot of FFT with pyqtgraph, same the picture.
      Have you an idea ?



      enter image description here







      python pyqt pyqt5 pyqtgraph






      share|improve this question















      share|improve this question













      share|improve this question




      share|improve this question








      edited Nov 14 '18 at 4:16









      eyllanesc

      77.3k103156




      77.3k103156










      asked Nov 13 '18 at 15:00









      Jérôme PannetierJérôme Pannetier

      354




      354
























          1 Answer
          1






          active

          oldest

          votes


















          0














          You can create an item in which the vertical lines are drawn:



          from pyqtgraph.Qt import QtGui, QtCore
          import pyqtgraph as pg

          class LinePlot(pg.GraphicsObject):
          def __init__(self, data):
          super(LinePlot, self).__init__()
          self._data =
          self.setData(data)

          def setData(self, data):
          self._data = data
          self.generate()

          def generate(self):
          self.picture = QtGui.QPicture()
          p = QtGui.QPainter(self.picture)
          p.setPen(pg.mkPen('r', width=2))
          for (t, v) in self._data:
          if v != 0:
          p.drawLine(QtCore.QPointF(t, 0), QtCore.QPointF(t, v))

          def paint(self, p, *args):
          p.drawPicture(0, 0, self.picture)

          def boundingRect(self):
          return QtCore.QRectF(self.picture.boundingRect())

          if __name__ == '__main__':
          import sys
          import random

          app = QtGui.QApplication(sys.argv)
          w = QtGui.QMainWindow()
          view = pg.GraphicsLayoutWidget()
          w.setCentralWidget(view)
          plot = view.addPlot()
          vals = [(i, random.randint(0, 255)) for i in range(30)]
          plot.addItem(LinePlot(vals))
          w.show()
          sys.exit(app.exec_())


          enter image description here






          share|improve this answer























            Your Answer






            StackExchange.ifUsing("editor", function () {
            StackExchange.using("externalEditor", function () {
            StackExchange.using("snippets", function () {
            StackExchange.snippets.init();
            });
            });
            }, "code-snippets");

            StackExchange.ready(function() {
            var channelOptions = {
            tags: "".split(" "),
            id: "1"
            };
            initTagRenderer("".split(" "), "".split(" "), channelOptions);

            StackExchange.using("externalEditor", function() {
            // Have to fire editor after snippets, if snippets enabled
            if (StackExchange.settings.snippets.snippetsEnabled) {
            StackExchange.using("snippets", function() {
            createEditor();
            });
            }
            else {
            createEditor();
            }
            });

            function createEditor() {
            StackExchange.prepareEditor({
            heartbeatType: 'answer',
            autoActivateHeartbeat: false,
            convertImagesToLinks: true,
            noModals: true,
            showLowRepImageUploadWarning: true,
            reputationToPostImages: 10,
            bindNavPrevention: true,
            postfix: "",
            imageUploader: {
            brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
            contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
            allowUrls: true
            },
            onDemand: true,
            discardSelector: ".discard-answer"
            ,immediatelyShowMarkdownHelp:true
            });


            }
            });














            draft saved

            draft discarded


















            StackExchange.ready(
            function () {
            StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53283831%2fpyqt5-pyqtgraph-plot-discret%23new-answer', 'question_page');
            }
            );

            Post as a guest















            Required, but never shown

























            1 Answer
            1






            active

            oldest

            votes








            1 Answer
            1






            active

            oldest

            votes









            active

            oldest

            votes






            active

            oldest

            votes









            0














            You can create an item in which the vertical lines are drawn:



            from pyqtgraph.Qt import QtGui, QtCore
            import pyqtgraph as pg

            class LinePlot(pg.GraphicsObject):
            def __init__(self, data):
            super(LinePlot, self).__init__()
            self._data =
            self.setData(data)

            def setData(self, data):
            self._data = data
            self.generate()

            def generate(self):
            self.picture = QtGui.QPicture()
            p = QtGui.QPainter(self.picture)
            p.setPen(pg.mkPen('r', width=2))
            for (t, v) in self._data:
            if v != 0:
            p.drawLine(QtCore.QPointF(t, 0), QtCore.QPointF(t, v))

            def paint(self, p, *args):
            p.drawPicture(0, 0, self.picture)

            def boundingRect(self):
            return QtCore.QRectF(self.picture.boundingRect())

            if __name__ == '__main__':
            import sys
            import random

            app = QtGui.QApplication(sys.argv)
            w = QtGui.QMainWindow()
            view = pg.GraphicsLayoutWidget()
            w.setCentralWidget(view)
            plot = view.addPlot()
            vals = [(i, random.randint(0, 255)) for i in range(30)]
            plot.addItem(LinePlot(vals))
            w.show()
            sys.exit(app.exec_())


            enter image description here






            share|improve this answer




























              0














              You can create an item in which the vertical lines are drawn:



              from pyqtgraph.Qt import QtGui, QtCore
              import pyqtgraph as pg

              class LinePlot(pg.GraphicsObject):
              def __init__(self, data):
              super(LinePlot, self).__init__()
              self._data =
              self.setData(data)

              def setData(self, data):
              self._data = data
              self.generate()

              def generate(self):
              self.picture = QtGui.QPicture()
              p = QtGui.QPainter(self.picture)
              p.setPen(pg.mkPen('r', width=2))
              for (t, v) in self._data:
              if v != 0:
              p.drawLine(QtCore.QPointF(t, 0), QtCore.QPointF(t, v))

              def paint(self, p, *args):
              p.drawPicture(0, 0, self.picture)

              def boundingRect(self):
              return QtCore.QRectF(self.picture.boundingRect())

              if __name__ == '__main__':
              import sys
              import random

              app = QtGui.QApplication(sys.argv)
              w = QtGui.QMainWindow()
              view = pg.GraphicsLayoutWidget()
              w.setCentralWidget(view)
              plot = view.addPlot()
              vals = [(i, random.randint(0, 255)) for i in range(30)]
              plot.addItem(LinePlot(vals))
              w.show()
              sys.exit(app.exec_())


              enter image description here






              share|improve this answer


























                0












                0








                0







                You can create an item in which the vertical lines are drawn:



                from pyqtgraph.Qt import QtGui, QtCore
                import pyqtgraph as pg

                class LinePlot(pg.GraphicsObject):
                def __init__(self, data):
                super(LinePlot, self).__init__()
                self._data =
                self.setData(data)

                def setData(self, data):
                self._data = data
                self.generate()

                def generate(self):
                self.picture = QtGui.QPicture()
                p = QtGui.QPainter(self.picture)
                p.setPen(pg.mkPen('r', width=2))
                for (t, v) in self._data:
                if v != 0:
                p.drawLine(QtCore.QPointF(t, 0), QtCore.QPointF(t, v))

                def paint(self, p, *args):
                p.drawPicture(0, 0, self.picture)

                def boundingRect(self):
                return QtCore.QRectF(self.picture.boundingRect())

                if __name__ == '__main__':
                import sys
                import random

                app = QtGui.QApplication(sys.argv)
                w = QtGui.QMainWindow()
                view = pg.GraphicsLayoutWidget()
                w.setCentralWidget(view)
                plot = view.addPlot()
                vals = [(i, random.randint(0, 255)) for i in range(30)]
                plot.addItem(LinePlot(vals))
                w.show()
                sys.exit(app.exec_())


                enter image description here






                share|improve this answer













                You can create an item in which the vertical lines are drawn:



                from pyqtgraph.Qt import QtGui, QtCore
                import pyqtgraph as pg

                class LinePlot(pg.GraphicsObject):
                def __init__(self, data):
                super(LinePlot, self).__init__()
                self._data =
                self.setData(data)

                def setData(self, data):
                self._data = data
                self.generate()

                def generate(self):
                self.picture = QtGui.QPicture()
                p = QtGui.QPainter(self.picture)
                p.setPen(pg.mkPen('r', width=2))
                for (t, v) in self._data:
                if v != 0:
                p.drawLine(QtCore.QPointF(t, 0), QtCore.QPointF(t, v))

                def paint(self, p, *args):
                p.drawPicture(0, 0, self.picture)

                def boundingRect(self):
                return QtCore.QRectF(self.picture.boundingRect())

                if __name__ == '__main__':
                import sys
                import random

                app = QtGui.QApplication(sys.argv)
                w = QtGui.QMainWindow()
                view = pg.GraphicsLayoutWidget()
                w.setCentralWidget(view)
                plot = view.addPlot()
                vals = [(i, random.randint(0, 255)) for i in range(30)]
                plot.addItem(LinePlot(vals))
                w.show()
                sys.exit(app.exec_())


                enter image description here







                share|improve this answer












                share|improve this answer



                share|improve this answer










                answered Nov 14 '18 at 4:16









                eyllanesceyllanesc

                77.3k103156




                77.3k103156






























                    draft saved

                    draft discarded




















































                    Thanks for contributing an answer to Stack Overflow!


                    • Please be sure to answer the question. Provide details and share your research!

                    But avoid



                    • Asking for help, clarification, or responding to other answers.

                    • Making statements based on opinion; back them up with references or personal experience.


                    To learn more, see our tips on writing great answers.




                    draft saved


                    draft discarded














                    StackExchange.ready(
                    function () {
                    StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53283831%2fpyqt5-pyqtgraph-plot-discret%23new-answer', 'question_page');
                    }
                    );

                    Post as a guest















                    Required, but never shown





















































                    Required, but never shown














                    Required, but never shown












                    Required, but never shown







                    Required, but never shown

































                    Required, but never shown














                    Required, but never shown












                    Required, but never shown







                    Required, but never shown







                    Popular posts from this blog

                    Full-time equivalent

                    さくらももこ

                    13 indicted, 8 arrested in Calif. drug cartel investigation