Hi,<br><br>I would also be interested in an android port, and looking through spice-gtk, it does seems much simpler than spicec.<br><br>Best Regards,<br><br>Attila<br><br><div class="gmail_quote">On Fri, Mar 4, 2011 at 9:36 AM, Alon Levy <span dir="ltr"><<a href="mailto:alevy@redhat.com">alevy@redhat.com</a>></span> wrote:<br>
<blockquote class="gmail_quote" style="margin: 0pt 0pt 0pt 0.8ex; border-left: 1px solid rgb(204, 204, 204); padding-left: 1ex;"><div class="im">On Fri, Mar 04, 2011 at 03:38:51PM +0800, Shuxiang Lim wrote:<br>
> Hi all,<br>
> I'm trying these days to port spicec into Android.But it's a rather TOUGH<br>
> way to go because the structure of spicec and android are desperately<br>
> inappropriate:the linux version of spicec is based on the X11,which is not<br>
> available in Android,thus the UI of spicec should be rewritten from<br>
> scratch...More troublesome is that the UI part and data part in current<br>
<br>
</div>Haven't looked at your proposal below yet, but did you check the spice-gtk<br>
work? maybe it is easier to start from that? are gtk libraries available on<br>
android? not talking about X. spice-gtk has objects for connection and channels<br>
that afaik don't do any output, that's separate from the actual widget that<br>
uses X. Also, gtk 3 has backends - did anyone do a backend for android?<br>
<br>
Since going forward we plan to ditch the spicec client, that would be really<br>
preffered. Now that I see what you have planned it sounds good, but better<br>
to use spice-gtk.<br>
<br>
of course that's not to say we won't love to see this working anyway :)<br>
<div><div></div><div class="h5"><br>
> spicec is entangled in the hierarchical system in C++! So my plan is this:<br>
> first split the spicec into two parts,data and UI,transform the data part<br>
> into libspicec.so;then rewrite the UI part in JAVA. Besides, I should also<br>
> tinker some problems caused by the Crippled NDK C++ support and the Lamed<br>
> bionic c lib in android .<br>
> And now the first step is roughly done,hence the change of the spicec<br>
> structure:<br>
> From<br>
> |-->playback<br>
> thread<br>
> |-->cursor<br>
> thread<br>
> spicec:spicec process(application process)-->main thread->|-->*record thread<br>
> *<br>
> |-->inputs<br>
> thread<br>
> |-->display<br>
> thread<br>
> To:<br>
> ===========================><br>
> |-->libspicec.so:application thread-->main<br>
> thread------>|<br>
> |<br>
> |<br>
> | |<--display thread<--|<br>
> |<br>
> | |--->|<--cursor<br>
> thread<---|<------------------|<br>
> | | |<--inputs thread<---|<br>
> spicec:spicec process--->| | |<--playback thread<-|<br>
> | |<br>
> | |<br>
> | |<br>
> <---------------------------------------------|<br>
> |<br>
> |<br>
> |<br>
> |<br>
> |-->spicec:platform<br>
> thread------------------------------>|<br>
><br>
> The hierarchical relationship has been unleashed with one thread(record<br>
> channel) deleted and two new threads (app and platform) created. The first<br>
> as the "data thread",the other as the "work thread" which is driven by the<br>
> signals from the first thread as well as its sub threads and requested to do<br>
> the UI-related work:<br>
><br>
> platform thread:------------>blocked and waiting:-->job<br>
> request-<--------------|<br>
> | |<br>
> |<br>
> ^ |<br>
> |<br>
> |<br>
> | |<br>
> |<----------|-<-|<br>
> |<br>
> | |<br>
> |<br>
> platform thread over<----------if(job==die)<--| send req. blocked<br>
> and waiting<br>
> | ^ |<br>
> |<br>
> | | |<br>
> ^<br>
> | | |<br>
> _________|_________<br>
> | | |<br>
> | app/plbk/cusor<br>
> thd<br>
> |<---job done----dojob()<--else--| | |->go on->|<br>
> __________________<br>
> | |<br>
> |------------------------------->feed back-->|<br>
><br>
><br>
> So the next work is to expose the native JNI interface in platform thread to<br>
> the UI written in Android SDK. I try to use the UI<br>
> frame of AndroidVNCViewer in<br>
> <a href="http://code.google.com/p/*android*-*vnc*-viewer/,then" target="_blank">code.google.com/p/*android*-*vnc*-viewer/,then</a> the work of platform<br>
> thread will be replaced by UI but the msg<br>
> communication to libspicec will be remained. That's the easiest way I can<br>
> envisage except rewriting all parts in spicec from scratch.<br>
> It's tough too, for I have poor experiance in Java...<br>
> Anyway, is there any other guy working on this? Is my way feasible??Any<br>
> Ideas or help is appreciated.<br>
<br>
</div></div>See above for ideas, don't read them as a criticism, I think this is fantastic<br>
what you've done so far. I remember someone posting "we are working on andriod<br>
in our spare time" post to spice-devel, please grep the archive.<br>
<br>
Alon<br>
<br>
> Best regards.<br>
<br>
> _______________________________________________<br>
> Spice-devel mailing list<br>
> <a href="mailto:Spice-devel@lists.freedesktop.org">Spice-devel@lists.freedesktop.org</a><br>
> <a href="http://lists.freedesktop.org/mailman/listinfo/spice-devel" target="_blank">http://lists.freedesktop.org/mailman/listinfo/spice-devel</a><br>
<br>
_______________________________________________<br>
Spice-devel mailing list<br>
<a href="mailto:Spice-devel@lists.freedesktop.org">Spice-devel@lists.freedesktop.org</a><br>
<a href="http://lists.freedesktop.org/mailman/listinfo/spice-devel" target="_blank">http://lists.freedesktop.org/mailman/listinfo/spice-devel</a><br>
</blockquote></div><br>