Graphical Environment

Termux provides support for programs that use X Window System. However, there no hardware acceleration for rendering and user will have to install a third party application to view graphical output.

To use X11-enabled programs, please, make sure that at least one of the following programs is installed:


 * VNC Viewer - the best choice for interacting with graphical environment. Requires a running VNC server.


 * XServer XSDL - this one may be unstable but it provides a standalone Xorg server so you don't have to setup VNC.

Enabling X11 repository
X11 packages are available in a separate APT repository. You can enable it by running the following command:

pkg install x11-repo

It will automatically add appropriate sources.list file and PGP key.

To disable this repository, you need to uninstall package.

Setting up Xserver XSDL
Example startx-openbox.sh: SHELL=/data/data/com.termux/files/usr/bin/bash; export SHELL; export X_CFLAGS="-I/data/data/com.termux/files/usr/include -D_REENTRANT" export X_LIBS="-Wl,-R/data/data/com.termux/files/usr/lib -lX11" export DISPLAY=localhost:0 export PULSE_SERVER=localhost:4712 $SHELL -c "openbox-session &"

Server
If you decided to use VNC for graphical output, follow these instructions for properly setting up VNC server.

1. Install package `tigervnc`:

pkg install tigervnc

2. After installation, execute this:

vncserver -localhost

At first time, you will be prompted for setting up passwords:

You will require a password to access your desktops.

Password: Verify: Would you like to enter a view-only password (y/n)? n

Note that passwords are not visible when you are typing them and maximal password length is 8 characters.

3. If everything is okay, you will see this message:

New 'localhost:1 ' desktop is localhost:1

Creating default startup script /data/data/com.termux/files/home/.vnc/xstartup Creating default config /data/data/com.termux/files/home/.vnc/config Starting applications specified in /data/data/com.termux/files/home/.vnc/xstartup Log file is /data/data/com.termux/files/home/.vnc/localhost:1.log

It means that X (vnc) server is available on display 'localhost:1'.

4. Finally, to make programs do graphical output to the display 'localhost:1', set environment variable like shown here (yes, without specifying 'localhost'):

export DISPLAY=":1"

You may even put this variable to your bashrc or profile so you don't have to always set it manually unless display address will be changed.

Client
Here will be assumed that you use this Android VNC client: VNC Viewer (developed by RealVNC Limited).

1. Determine port number on which VNC server listens. It can be calculated like this:. So for display 'localhost:1' the port will be 5901.

2. Now open the VNC Viewer application and create a new connection with the following information (assuming that VNC port is 5901):

Address: 127.0.0.1:5901

Name: Termux

3. Now launch it. You will be prompted for password that you entered on first launch of 'vncserver'. Depending on packages you installed, you may see either entirely black screen or terminal prompt (only if 'aterm' is installed).

Fluxbox


Simplest way to get a working graphical environment is to install Fluxbox:

pkg install fluxbox

It can be started automatically on VNC server startup. To do this, edit file  as shown here:

Openbox


Openbox requires a more complicated configuration than Fluxbox. Firstly you need to install some packages:

pkg install openbox pypanel xorg-xsetroot

Put the following lines to your :

Don't put anything else to file  but only lines shown above since Openbox has own autostart script. It is located at. Edit this file like here: