in reply to Re: Tk, threads, and mjpeg stream
in thread Tk, threads, and mjpeg stream
When I run this, I get the following errors#!/usr/bin/perl -slw use Tk; use Tk::JPEG; use LWP::UserAgent; use MIME::Base64; use IO::Socket; use threads; use threads::shared; my $host = 'someipaddress'; my @urls = qw[ /cgi-bin/nph-zms?mode=jpeg&monitor=1&scale=100&maxfps=5 +&user=web&pass=webuser /cgi-bin/nph-zms?mode=jpeg&monitor=2&scale=100 +&maxfps=5&user=web&pass=webuser /cgi-bin/nph-zms?mode=jpeg&monitor=3& +scale=100&maxfps=5&user=web&pass=webuser /cgi-bin/nph-zms?mode=jpeg&m +onitor=4&scale=100&maxfps=5&user=web&pass=webuser ]; my @data :shared = ('') x 4; ## 4 shared image data buffers my @flags :shared = (0) x 4; ## 4 shared 'image ready' flags sub loadJpg { my( $host, $url, $no, $dataref ) = @_; next if $flags[ $no ]; ## If the flag is still set do nothing #load the image my $sock = IO::Socket::INET->new(PeerAddr=>$host,Proto=>'tcp',Peer +Port=>80,); return unless defined $sock; $sock->autoflush(1); print $sock "GET $url HTTP/1.0\r\nHost: $host\r\n\r\n"; my $status = <$sock>; die unless ($status =~ m|HTTP/\S+\s+200|); my ($grab,$jpeg,$data,$image,$thisbuf,$lastimage); while (my $nread = sysread($sock, $thisbuf, 4096)) { $grab .= $thisbuf; if ( $grab =~ s/(.*?)\n--ZoneMinderFrame\r\n//s ) { $jpeg .= $1; $jpeg =~ s/--ZoneMinderFrame\r\n//; # Heh, what a $jpeg =~ s/Content-Length: \d+\r\n//; # Nasty little $jpeg =~ s/Content-Type: \S+\r\n\r\n//; # Hack $data = encode_base64($jpeg); ## copy to the appropriate shared buffer $dataref->[ $no ] = $data; ## Set the appropriate 'image ready' flag $flags[ $no ] = 1; $lastimage->delete if ($lastimage); #essential as Photo le +aks! $lastimage = $image; undef $jpeg; undef $data; } $jpeg .= $1 if ($grab =~ s/(.*)(?=\n)//s); } } ## Start the threads passing ## The host, url, buffer/flag number and buffer reference my @threads = map{ threads->new( \&loadJpg, $host, $urls[ $_ ], $_, \@data ); } 0 .. 3; my $stop = 0; my $mw = MainWindow->new(title=>"Cams"); $mw->minsize( qw(640 480)); my $top = $mw->Frame()->pack(-side=>'top'); my $bottom = $mw->Frame()->pack(-side=>'bottom'); ## Use an array, indexed by passed number my @photos = ( $top->Label()->pack(-side => 'left'), $top->Label()->pack(-side => 'right'), $bottom->Label()->pack(-side => 'left'), $bottom->Label()->pack(-side => 'right'), ); $mw->Button(-text=>"Stop",-command => sub { $stop=1; })->pack(); ## Set up a regular callback in the main thread that ## a) checks the flags for each image ## and if it is set ## b) Locks the data ## c) Encodes the data ## d) Creates a Photo object from it ## e) Sets it into the widget ## f) Clears the flag ready for the next $mw->repeat( 1000, sub{ for my $n ( 0 .. 3 ) { if( $flags[ $n ] ) { lock( @data ); my $data = encode_base64( $data[ $n ] ); $image[ $n ]->delete if $image[ $n ]; ## Addendum: $image[ $n ] = $mw->Photo( -format=>'jpeg', -data=>$data ) +; $photos[ $n ]->configure( -image => $image[ $n ] ); $flags[ $n ] = 0; } } } ); MainLoop;
I had thought that the string that was being passed was not being encoded correctly (or something along those lines) so I inserted a print statement of the array $data$n and got back actual jpeg information.XS_Tk__Callback_Call error:couldn't recognize image data at /usr/lib/p +erl5/site_perl/5.8.0/i386-linux-thread-multi/Tk/Image.pm line 21. Tk::Error: couldn't recognize image data at /usr/lib/perl5/site_perl/5 +.8.0/i386-linux-thread-multi/Tk/Image.pm line 21. Tk callback for image Tk::After::repeat at /usr/lib/perl5/site_perl/5.8.0/i386-linux-thread +-multi/Tk/After.pm line 79 [repeat,[{},after#4,1000,repeat,[\&main::__ANON__]]] ("after" script) XS_Tk__Callback_Call error:couldn't recognize image data at /usr/lib/p +erl5/site_perl/5.8.0/i386-linux-thread-multi/Tk/Image.pm line 21. Tk::Error: couldn't recognize image data at /usr/lib/perl5/site_perl/5 +.8.0/i386-linux-thread-multi/Tk/Image.pm line 21. Tk callback for image Tk::After::repeat at /usr/lib/perl5/site_perl/5.8.0/i386-linux-thread +-multi/Tk/After.pm line 79 [repeat,[{},after#5,1000,repeat,[\&main::__ANON__]]] ("after" script) XS_Tk__Callback_Call error:couldn't recognize image data at /usr/lib/p +erl5/site_perl/5.8.0/i386-linux-thread-multi/Tk/Image.pm line 21. Tk::Error: couldn't recognize image data at /usr/lib/perl5/site_perl/5 +.8.0/i386-linux-thread-multi/Tk/Image.pm line 21. Tk callback for image Tk::After::repeat at /usr/lib/perl5/site_perl/5.8.0/i386-linux-thread +-multi/Tk/After.pm line 79 [repeat,[{},after#6,1000,repeat,[\&main::__ANON__]]] ("after" script) XS_Tk__Callback_Call error:couldn't recognize image data at /usr/lib/p +erl5/site_perl/5.8.0/i386-linux-thread-multi/Tk/Image.pm line 21. Tk::Error: couldn't recognize image data at /usr/lib/perl5/site_perl/5 +.8.0/i386-linux-thread-multi/Tk/Image.pm line 21. Tk callback for image Tk::After::repeat at /usr/lib/perl5/site_perl/5.8.0/i386-linux-thread +-multi/Tk/After.pm line 79 [repeat,[{},after#7,1000,repeat,[\&main::__ANON__]]] ("after" script)
Thanks again, I'm still working on this one.../9j/4AAQSkZJRgABAQAAAQABAAD/2wBDAAgGBgcGBQgHBwcJCQgKDBQNDAsLDBkSEw8UHR +ofHh0a HBwgJC4nICIsIxwcKDcpLDAxNDQ0Hyc5PTgyPC4zNDL/2wBDAQkJCQwLDBgNDRgyIRwhMj +IyMjIy AAF9AQIDAAQRBRIhMUEGE1FhByJxFDKBkaEII0KxwRVS0fAkM2JyggkKFhcYGRolJicoKS +o0NTY3 ... <trunkated because there's a lot of stuff, and it's a live image> ... TFRuykAemab5oJKnG4VHuJbpRcY4vuwM8jjFOQttBdAM0cFtygZ9KGyxBZulArAMvnHAz3 +pxJWMg kcDr+NCEBQR3PBFRyHltpBJx/OmrAf/ZDQoN
|
|---|
| Replies are listed 'Best First'. | |
|---|---|
|
Re^3: Tk, threads, and mjpeg stream
by satanklawz (Beadle) on Apr 18, 2006 at 15:14 UTC | |
by satanklawz (Beadle) on Apr 18, 2006 at 18:06 UTC | |
by BrowserUk (Patriarch) on Apr 18, 2006 at 21:42 UTC |