<div dir="ltr">Hi Kevin,<div><br></div><div><br></div><div>Thanks for the summary.</div><div><br></div><div>Might I be a pain, and suggest that if it's going to happen through the mir API, we also need a simple app that can take screenshots. Writing python <-> C bindings probably isn't the best way to go here, so I wonder if we could have a simple app that we can call like so: "mir-screenshot /path/to/file.png".</div>
<div><br></div><div>That should be easy to write, I think?</div></div><div class="gmail_extra"><br><br><div class="gmail_quote">On Thu, Dec 5, 2013 at 12:33 AM, Kevin Gunn <span dir="ltr"><<a href="mailto:kevin.gunn@canonical.com" target="_blank">kevin.gunn@canonical.com</a>></span> wrote:<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr"><div>After some discussion</div><div><ul><li>first goal is to satisfy our QA requirement to capture full screen output</li>
<ul><li>note, fullscreen only for now, not going to address app windows</li></ul><li>
screencast/screenshot will go through the mir api</li><ul><li>e.g. mir_connection_output_surface, where the client can indicate whether or not the client wants a gl or sw buffer, and then mir_output_advance_buffer to indicate reading the next buffer (note names subj to change...just proposed ;)</li>
<li>which fails for unprivileged clients</li><li>we did discuss the potential addition of explicit capability acquire/release for privileged apps, but it was decided we shouldn't add this to the api until we have more concrete need/use cases</li>
</ul><li>mir will have a server side check with unity-mir for unity8 to check against app armor to determine if the app has the capability to screencast, this check will only happen when the call to the api is made</li></ul>
</div><div><br></div></div><div class="HOEnZb"><div class="h5"><div class="gmail_extra"><br><br><div class="gmail_quote">On Thu, Nov 28, 2013 at 1:40 AM, Daniel van Vugt <span dir="ltr"><<a href="mailto:daniel.van.vugt@canonical.com" target="_blank">daniel.van.vugt@canonical.com</a>></span> wrote:<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">Keeping in mind recording at full frame rate (or near) would solve both problems, I think we should have a single approach.<br>
<br>
The key thing to remember is bandwidth. Only the buffer sharing logic used in client IPC has the bandwidth to cope with recording/screencasting.<br>
<br>
Consider: 1920x1200 x 4bytesperpixel x 60FPS<br>
--> 553 megabytes per second<br>
<br>
Or even: 1366x768 x 4bytesperpixel x 30FPS<br>
--> 126 megabytes per second<br>
<br>
Hopefully it would be encoded more efficiently for storage, but still, you need to use buffer IPC that's designed for speed. Fortunately we have that already.<div><div><br>
<br>
<br>
On 27/11/13 23:30, Ricardo Mendoza wrote:<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
On Wed, 2013-11-27 at 07:32 +0100, Thomas Voß wrote:<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
On Tue, Nov 26, 2013 at 4:12 PM, Alexandros Frantzis<br>
<<a href="mailto:alexandros.frantzis@canonical.com" target="_blank">alexandros.frantzis@<u></u>canonical.com</a>> wrote:<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
On Tue, Nov 26, 2013 at 01:13:28PM +0000, Gerry Boland wrote:<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
Hey,<br>
The system compositor will probably not be using the Qt scenegraph, but<br>
instead Mir's own compositor. I don't know if using<br>
QQuickWindow::grabWindow() will work in that case (though if it just<br>
calls glReadPixels, it probably will).<br>
<br>
Also if hardware (non-GL) compositing is being used, reading back pixels<br>
via glReadPixels won't be enough as not everything on screen will be<br>
drawn by GL.<br>
</blockquote>
<br>
The original discussion was about autopilot being able to take<br>
screenshots/casts of unity8 for testing and validation purposes, and we<br>
came up with a simple solution for this use case.<br>
<br>
</blockquote>
<br>
That's a fair point. As I understand it, there is the immediate<br>
requirement to support QA with screenshotting capabilities and the<br>
presented approach can be used to provide the required functionality.<br>
</blockquote>
<br>
Back to this, providing a screenshotting interface with a default file<br>
sink is a matter of... 30 minutes? I believe extending the<br>
com.canonical.Unity.Screen interface; as long as you decide on a place<br>
to put screenshot files and a default format.<br>
<br>
I believe we should provide this right away for QA, the rest of the plan<br>
seems more broad and therefore not really committable to a strict<br>
timeframe. I agree that casting would be great and that we need it, just<br>
not sure if its the right time to slot it into the dev plan.<br>
<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
However, it seems that people have more use cases for screen capturing<br>
that require additional complexity. I think we need to discuss a bit<br>
more about what we really need and when, check what is feasible in our<br>
time frames and prioritize work. The upcoming sprint seems ideal for<br>
this.<br>
<br>
</blockquote>
<br>
+1.<br>
<br>
Cheers,<br>
<br>
Thomas<br>
<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
Thanks,<br>
Alexandros<br>
</blockquote></blockquote>
<br>
Regards,<br>
<br>
<br>
Ricardo<br>
<br>
<br>
</blockquote>
<br>
-- <br>
Mir-devel mailing list<br>
<a href="mailto:Mir-devel@lists.ubuntu.com" target="_blank">Mir-devel@lists.ubuntu.com</a><br>
Modify settings or unsubscribe at: <a href="https://lists.ubuntu.com/mailman/listinfo/mir-devel" target="_blank">https://lists.ubuntu.com/<u></u>mailman/listinfo/mir-devel</a><br>
</div></div></blockquote></div><br></div>
</div></div><br>--<br>
Mir-devel mailing list<br>
<a href="mailto:Mir-devel@lists.ubuntu.com">Mir-devel@lists.ubuntu.com</a><br>
Modify settings or unsubscribe at: <a href="https://lists.ubuntu.com/mailman/listinfo/mir-devel" target="_blank">https://lists.ubuntu.com/mailman/listinfo/mir-devel</a><br>
<br></blockquote></div><br><br clear="all"><div><br></div>-- <br><div dir="ltr"><div>Thomi Richards<br></div><a href="mailto:thomi.richards@canonical.com" target="_blank">thomi.richards@canonical.com</a><br></div>
</div>