Skip to content
  • Categories
  • Recent
  • Tags
  • Popular
  • Users
  • Groups
  • Search
  • Get Qt Extensions
  • Unsolved
Collapse
Brand Logo
  1. Home
  2. Qt Development
  3. Installation and Deployment
  4. Custom image plugin testing difficulties
Forum Updated to NodeBB v4.3 + New Features

Custom image plugin testing difficulties

Scheduled Pinned Locked Moved Installation and Deployment
17 Posts 2 Posters 4.0k Views 2 Watching
  • Oldest to Newest
  • Newest to Oldest
  • Most Votes
Reply
  • Reply as topic
Log in to reply
This topic has been deleted. Only users with topic management privileges can see it.
  • C Offline
    C Offline
    ChrisM87
    wrote on last edited by
    #5

    Well as I showed above, with the QT_DEBUG_PLUGINS variable set, the program is picking it up. However, it still refuses to load it. Is the IID or keys array invalid? I figured if it was choking on the plugin code itself, it would either error, segfault, or spit out a corrupt PNG.

    1 Reply Last reply
    0
    • SGaistS Offline
      SGaistS Offline
      SGaist
      Lifetime Qt Champion
      wrote on last edited by
      #6

      Without seeing your code, it's pretty much Crystal Ball Debugging (™) I can't say

      Interested in AI ? www.idiap.ch
      Please read the Qt Code of Conduct - https://forum.qt.io/topic/113070/qt-code-of-conduct

      1 Reply Last reply
      0
      • C Offline
        C Offline
        ChrisM87
        wrote on last edited by ChrisM87
        #7

        Well, I had posted my code in the original post. However, my handler class was tweaked a bit after spotting some errors, so here's the updated class code:

        EDIT: I did a few tests on QImageReader that should fail with unsupported format error, but I keep getting "unknown error." I attempted to load my ".pro" qmake file to see which error it would get but still unknown error. However, I compiled qtraw from Github, dropped it into an imageformats subdirectory and it ran fine.

        #include <QDataStream>
        #include <QImage>
        #include <QIODevice>
        #include <QtGlobal>
        #include <QtMath>
        #include <QVariant>
        #include <QVector>
        #include <QImageIOHandler>
        
        class TimHandler final: public QImageIOHandler
        {
        public:
        	bool canRead() const;
        	bool read(QImage *img);
        	QVariant option(ImageOption op) const override;
        	bool supportsOption(ImageOption op) const override;
        };
        
        #define BIT16 0.121568627451
        
        bool TimHandler::canRead() const
        {
        	return device()->peek(4) == "\x10\x0\x0\x0";
        }
        
        static inline quint32 rgba5551ToArgb32(quint16 c)
        {
        	quint32 r = ((c & 0xf800) >> 11) / BIT16;
        	quint32 g = ((c & 0x7c0) >> 6) / BIT16;
        	quint32 b = ((c & 0x3e) >> 1) / BIT16;
        	quint32 a = c & 1 ? 0 : 0xff;
        	
        	return ((a << 24) | (r << 16) | (g << 8) | b);
        }
        
        bool TimHandler::read(QImage *img)
        {
        	QDataStream ds(device());
        	ds.setByteOrder(QDataStream::LittleEndian);
        	quint32 magic, flags;
        	
        	ds >> magic >> flags;
        	if (ds.status() != QDataStream::Ok || magic != 0x10)
        		return false;
        	bool hasClut = flags & 0x8 ? true : false;
        	quint8 pxlMode = flags & 0x7;
        	
        	quint8 bpp;
        	switch (pxlMode)
        	{
        		case 0: bpp = 4; break;
        		case 1: bpp = 8; break;
        		case 2: bpp = 16; break;
        		case 3: bpp = 24; break;
        		default: bpp = 4;
        	}
        	
        	QVector<QRgb> clut;
        	if (hasClut)
        	{
        		quint32 colors, npals;
        		ds.skipRawData(12);
        		ds >> colors >> npals;
        		
        		for (quint16 i = 0; i < (colors*npals); i++)
        		{
        			quint16 c;
        			ds >> c;
        			clut.append(rgba5551ToArgb32(c));
        		}
        	}
        	
        	ds.skipRawData(8);
        	quint16 w, h;
        	ds >> w >> h;
        	w = (w*16)/bpp;
        	
        	if (img) delete img;
        	img = new QImage(w, h, QImage::Format_ARGB32);
        	if (hasClut) img->setColorTable(clut);
        	
        	for (quint16 y = 0; y < h; y++)
        	{
        		for (quint16 x = 0; x < w; x++)
        		{
        			switch (bpp)
        			{
        				case 4:
        				{
        					quint8 p;
        					ds >> p;
        					img->setPixel(x++, y, p & 0xf0);
        					img->setPixel(x, y, p & 0xf);
        				}
        					break;
        				case 8:
        				{
        					quint8 p;
        					ds >> p;
        					img->setPixel(x, y, p);
        				}
        					break;
        				case 16:
        				{
        					quint16 p;
        					ds >> p;
        					img->setPixel(x, y, rgba5551ToArgb32(p));
        				}
        					break;
        			}
        		}
        	}
        	
        	return true;
        }
        
        bool TimHandler::supportsOption(ImageOption op) const
        {
        	switch (op)
        	{
        		case Size:
        			return true;
        		default:
        			return false;
        	}
        }
        
        QVariant TimHandler::option(ImageOption op) const
        {
        	switch (op)
        	{
        		case Size:
        		{
        			quint32 size;
        			quint16 w, h;
        			QDataStream ds(device());
        			ds.skipRawData(8);
        			ds >> size;
        			size -= 4; // 12 - image size - palette x - palette y
        			ds.skipRawData(size);
        			ds >> w >> h;
        			return QSize(w, h);
        		}
        		default:
        			return QVariant();
        	}
        }
        
        1 Reply Last reply
        0
        • SGaistS Offline
          SGaistS Offline
          SGaist
          Lifetime Qt Champion
          wrote on last edited by
          #8

          Sorry about the code part, I had a problem when I read it first and only saw the end of it.
          What about a more simple json ?

          {
              "Keys": [ "tim" ],
              "MimeTypes": [ "image/x-tim" ]
          }
          
          

          Interested in AI ? www.idiap.ch
          Please read the Qt Code of Conduct - https://forum.qt.io/topic/113070/qt-code-of-conduct

          1 Reply Last reply
          0
          • C Offline
            C Offline
            ChrisM87
            wrote on last edited by ChrisM87
            #9

            Well, while I could try that, I don't know if that's the mime type for TIM files. A Google search doesn't help either. My examination of qtraw shows that it too lacks a mime type entry. Thus, I thought it was unnecessary.

            EDIT: tried it anyway, still nothing

            1 Reply Last reply
            0
            • SGaistS Offline
              SGaistS Offline
              SGaist
              Lifetime Qt Champion
              wrote on last edited by
              #10

              Just thought of something… Your plugin code is correct but:

              img.load("0025.tim", "tim");

              "0025.tim" is a relative path, is that image in the same folder as your executable ? You should rather give the full path to it.

              Interested in AI ? www.idiap.ch
              Please read the Qt Code of Conduct - https://forum.qt.io/topic/113070/qt-code-of-conduct

              1 Reply Last reply
              0
              • C Offline
                C Offline
                ChrisM87
                wrote on last edited by ChrisM87
                #11

                Same directory, yep. Though of course in a real world scenario this would be different.

                1 Reply Last reply
                0
                • SGaistS Offline
                  SGaistS Offline
                  SGaist
                  Lifetime Qt Champion
                  wrote on last edited by
                  #12

                  I forgot a correction I made:

                  Q_PLUGIN_METADATA(IID "org.qt-project.Qt.QImageIOHandlerFactoryInterface" FILE "tim.json")

                  Interested in AI ? www.idiap.ch
                  Please read the Qt Code of Conduct - https://forum.qt.io/topic/113070/qt-code-of-conduct

                  1 Reply Last reply
                  0
                  • C Offline
                    C Offline
                    ChrisM87
                    wrote on last edited by
                    #13

                    Yeah, I changed it to that in my progress trying to fix it, but no go. I booted up QtCreator and created a new project from Qt plugin template but I see nothing unusual in comparison with my code, aside from the constructor with QObject* parameter, which I skipped in my code because I saw no point for an empty constructor/destructor.

                    1 Reply Last reply
                    0
                    • C Offline
                      C Offline
                      ChrisM87
                      wrote on last edited by
                      #14

                      So after a little tinkering, I got qmake to generate main.moc which I thought was needed, but I'm still having issues with the plugin not being discovered. Additionally, the RGBA5551 conversion function was incorrect, which I fixed, but that shouldn't be the make-or-break factor.

                      1 Reply Last reply
                      0
                      • SGaistS Offline
                        SGaistS Offline
                        SGaist
                        Lifetime Qt Champion
                        wrote on last edited by
                        #15

                        Not being discovered or not loaded ? Did you put your plugin in a imageformats subfolder ?

                        Interested in AI ? www.idiap.ch
                        Please read the Qt Code of Conduct - https://forum.qt.io/topic/113070/qt-code-of-conduct

                        1 Reply Last reply
                        0
                        • C Offline
                          C Offline
                          ChrisM87
                          wrote on last edited by ChrisM87
                          #16

                          Yep. Even set target.path in my .pro file thinking that was the issue. Qt seems very nitpicky.

                          EDIT: Just debugged again, found this gem of an error:

                          QLibraryPrivate::loadPlugin failed on "/home/admin/Documents/Qt-extra/imageformats/qtim/timtest/imageformats/libqtim.so" : "Cannot load library /home/admin/Documents/Qt-extra/imageformats/qtim/timtest/imageformats/libqtim.so: (/home/admin/Documents/Qt-extra/imageformats/qtim/timtest/imageformats/libqtim.so: undefined symbol: _ZN11QTimHandler9setOptionEN15QImageIOHandler11ImageOptionERK8QVariant)"
                          
                          1 Reply Last reply
                          0
                          • SGaistS Offline
                            SGaistS Offline
                            SGaist
                            Lifetime Qt Champion
                            wrote on last edited by
                            #17

                            Which version of Qt are you using ?
                            What happens if you try to load it by hand using QLibrary ?

                            Interested in AI ? www.idiap.ch
                            Please read the Qt Code of Conduct - https://forum.qt.io/topic/113070/qt-code-of-conduct

                            1 Reply Last reply
                            0

                            • Login

                            • Login or register to search.
                            • First post
                              Last post
                            0
                            • Categories
                            • Recent
                            • Tags
                            • Popular
                            • Users
                            • Groups
                            • Search
                            • Get Qt Extensions
                            • Unsolved