Re: Strange 'regression' in gtk+/gstreamer app
Hello Eric, Thanks for the reply. Yeah I forgot to mention that in the Glade file I had set double buffered to false for both GtkDrawingAreas. I also tried setting them to false directly in code once I finish loading/configuring it from the glade file. gtk_builder_connect_signals (builder, DO); g_signal_connect (recordingArea, "realize", rec_realize_cb, DO); g_signal_connect (viewerArea,"realize", view_realize_cb, DO ); gtk_widget_set_double_buffered (GTK_WIDGET(recordingArea), FALSE); gtk_widget_set_double_buffered (GTK_WIDGET(viewerArea), FALSE); One thing this did make me realized is that in my source dir I have a copy of a tutorial/example. "basic-tutorial-5.c" (http://pastebin.com/4 gaWhCJs). It compiles and runs fine - updating the scrollbars without a flicker. It also sets the double buffer to false. So I'm wondering if it has to do with the notebook. That or the fact that I have two drawing areas. One in each notebool panel that is causing the issue. It is just so bizarre that its suddenly occurring years after it was written. Any other ideas? -- Nathanael On Fri, 2016-12-09 at 18:59 -0500, cecas...@aol.com wrote: > > It could be a problem with the double buffering. > > gtk_widget_set_double_buffered() > > Try to set that to false and see if that makes any difference. This > is on Linux? Usually you don't need this function any more and it is > deprecated but it can sometimes still be useful. I know to get > gnuplot pictures to redraw without flickering or a white background, > it needs to be false. > > I did a little gstreamer experimentation a little while back with the > webcam video. It works without gtk_widget_set_double_buffered() using > Ubuntu 16.04, GTK3.18 and gstreamer1.0. No flickering that I can see. > I don't have a scrollbar in there though. It might be helpful. > > https://github.com/cecashon/OrderedSetVelociRaptor/blob/master/Misc/S > ound/webcam3.c > > Eric > > > ___ gtk-app-devel-list mailing list gtk-app-devel-list@gnome.org https://mail.gnome.org/mailman/listinfo/gtk-app-devel-list
Re: Strange 'regression' in gtk+/gstreamer app
Hello Eric, Thanks for the reply. Yeah I forgot to mention that in the Glade file I had set double buffered to false for both GtkDrawingAreas. I also tried setting them to false directly in code once I finish loading/configuring it from the glade file. gtk_builder_connect_signals (builder, DO); g_signal_connect (recordingArea, "realize", rec_realize_cb, DO); g_signal_connect (viewerArea,"realize", view_realize_cb, DO ); gtk_widget_set_double_buffered (GTK_WIDGET(recordingArea), FALSE); gtk_widget_set_double_buffered (GTK_WIDGET(viewerArea), FALSE); One thing this did make me realized is that in my source dir I have a copy of a tutorial/example. "basic-tutorial-5.c" (http://pastebin.com/4 gaWhCJs). It compiles and runs fine - updating the scrollbars without a flicker. It also sets the double buffer to false. So I'm wondering if it has to do with the notebook. That or the fact that I have two drawing areas. One in each notebool panel that is causing the issue. It is just so bizarre that its suddenly occurring years after it was written. Any other ideas? -- Nathanael On Fri, 2016-12-09 at 18:59 -0500, cecas...@aol.com wrote: > > It could be a problem with the double buffering. > > gtk_widget_set_double_buffered() > > Try to set that to false and see if that makes any difference. This > is on Linux? Usually you don't need this function any more and it is > deprecated but it can sometimes still be useful. I know to get > gnuplot pictures to redraw without flickering or a white background, > it needs to be false. > > I did a little gstreamer experimentation a little while back with the > webcam video. It works without gtk_widget_set_double_buffered() using > Ubuntu 16.04, GTK3.18 and gstreamer1.0. No flickering that I can see. > I don't have a scrollbar in there though. It might be helpful. > > https://github.com/cecashon/OrderedSetVelociRaptor/blob/master/Misc/S > ound/webcam3.c > > Eric > > > ___ gtk-app-devel-list mailing list gtk-app-devel-list@gnome.org https://mail.gnome.org/mailman/listinfo/gtk-app-devel-list
Strange 'regression' in gtk+/gstreamer app
Hello, So many years ago we wrote a custom app for a client. It does video recording from either network cameras or optionally built in webcams. Its worked well for a long time. Originally built against gstreamer 0.10. Recently we've replaced some of the hardware and have noticed an issue that I can't for the life of me track down. It was first observed on playback. When updating the position of the scrollbar, the video would flash, as if drawn over in white if you will. It happens each time the scrollbar position moved. For example the callback to update it is called every 200ms, but only when it moves does the flash occur. In digging into it some more, I also realized I could cause it to occur while recording. We have a number of Notebooks in the UI. Mousing over an inactive one where it then gets a little 'highlight' if you will prior to clicking also causes the video to then flicker. Originally to debug this I went into the code that was updating the scrollbar. if (ret && position != GST_CLOCK_TIME_NONE) { g_signal_handler_block (GTK_RANGE(playbackScale), updateId); gtk_range_set_value (GTK_RANGE(playbackScale), positionInSeconds); g_signal_handler_unblock (GTK_RANGE(playbackScale), updateId); } Simply commenting out the gtk_range_set_value stops playback on flicker. Obviously that's less desirable. I wondered if part of the issue was gstreamer 0.10 as its quite old. So started porting it to gstreamer-1.x. Made it far enough that I could test and confirm that I still have flickering when the mouse moves over notebook panels etc. I'm at a complete loss. I looked at Cheese and Totem to see if I could figure out what was going on. It seems they use clutter for quite a bit. I don't know if I want to port it over to that as well if I don't have to. However I would really like some pointers as to what could be causing the issue. I can even take a screencast if anyone wants to see the actual behaviour. Hoping someone has some good ideas, -- Nathanael ___ gtk-app-devel-list mailing list gtk-app-devel-list@gnome.org https://mail.gnome.org/mailman/listinfo/gtk-app-devel-list