Back to Silas S. Brown's home page | X11 configuration
X11 software magnification: last resort
- The x11vnc method
- vncviewer.exe version 3
- NX Client and coLinux
- There is also ezoom, intended to work with modern hardware using 3D graphics acceleration, but I have so far not found a hardware setup where it actually works. Ezoom is a plugin for a compositing window manager called Compiz: if you install a Compiz desktop, you should see an option called "Enhanced Zoom Desktop" in CompizConfig Settings Manager, but if the hardware's not right then attempting to zoom in may have no effect. This, together with the awkwardness of setting up Compiz on many distributions and the restriction against using other window managers, puts me off suggesting ezoom.
The x11vnc method
The idea is to run your desktop on a VNC server, and get a VNC client to display a magnified image of this. Few of the free VNC clients have unlimited magnification functionality, so we use x11vnc (a VNC server for real X servers) to magnify another X-based VNC server.This method is usually quite fast and allows you to scroll around a large virtual desktop. It assumes that you are using a Unix-based terminal. If you are using X11 remotely from a non-Unix terminal then see below.
- Using your package manager or otherwise, install the VNC
server program (vncserver or vnc4server or tightvncserver), the TightVNC viewer
program (xvncviewer or xvnc4viewer or xtightvncviewer), and
x11vnc. (See here if you need to update packages offline.)
- If x11vnc is not in your package manager, you may be able to copy the binary from another distribution. (If you have problems compiling yourself, try ./configure --without-zlib --without-libz --without-jpeg as you won't need those features for this hack.)
- If you are
able to compile x11vnc yourself you may be
interested in my x11vnc patch for
large mouse cursors---it applies to x11vnc version 0.7.1
and you
should do
patch x11vnc/x11vnc.c x11vnc.diff CPPFLAGS=-DBIG_CURSOR make -e
instead of make. Newer versions have this functionality integrated and you can use (e.g.) -scale_cursor 4:nb on the x11vnc command line. - If you can't get the TightVNC version of vncviewer then you may not be able to do bump scrolling, in this case you may want to limit your virtual desktop size to half your actual screen resolution.
- You may be able to copy across the
xvncviewer
binary and itslibvncauth.so.0
library from another distribution, in which case don't forget to add the library's directory toLD_LIBRARY_PATH
.
- Give yourself a
VNC password by using the
vncpasswd
command. -
Start the VNC server by using a command such as
vncserver :2 -geometry 1052x864 -depth 16
- Quit the VNC server (e.g. use
killall Xvnc Xrealvnc Xtightvnc
); this first run was only to create the initial.vnc/xstartup
file and does not need to be done every time. - Edit the
.vnc/xstartup
file and add the line:x11vnc -display :2 -rfbport 5903 -forever -scale 2:nb &
where the 2 after the-scale
is the scale factor you want (the:nb
means avoid blurring, which gives a clearer image when using integer scale factors). - If you have x11vnc version 0.7.2 or newer, add
-scale_cursor 4:nb
to the above command line (the 4 is how much you want the mouse cursor to scale in relation to the unmagnified screen). - Note:If the .vnc/xstartup file was not present, then you're probably using Xrealvnc instead of Xvnc, in which case it will look at your Xsession on startup; if you're using a real X server as well then you'll have to script some way of distinguishing between the two (perhaps by checking the DISPLAY environment variable).
- Start the VNC server again using the above command.
- Connect to the magnified display using the command
xvncviewer -fullscreen :3
- You can disconnect and reconnect the viewer as
you wish. To shut down the desktop, do
killall Xvnc Xrealvnc Xtightvnc
. - If the desktop was completely blank, or not to
your satisfaction, then you may need to edit the
.vnc/xstartup
file before starting the server again. - You might want to put the above into your
.xsession
and avoid running a window manager outside the VNC client, so that all your keypresses reach the window manager on the VNC server (but remember to add asleep 2
to let the server start before running the viewer). - If possible, enable backing store in your X server by
having the line
Option: "backingstore"
added to theDevice
section ofXF86Config
and restart the X server. This will improve the responsiveness of scrolling around the desktop. (If it takes time to repaint the screen when you scroll then that means backingstore has not been enabled properly.)
Note: Any
setxkbmap
command (to change the keyboard
e.g. for Dvorak) may not work unless it is sent to
the real display. xmodmap
should work however.
Windows VNC Viewer version 3
One of the few free VNC clients that can magnify is version 3 of vncviewer.exe. Note that this is an old version; newer versions introduced a charge for the magnification functionality (it's still free in the Windows version of TightVNC but the range is more limited). This old vncviewer.exe works in Wine, but is slower and won't let you drag the screen around a large virtual desktop. It can sometimes blur the magnification too, even with integer magnification factors. It may however be useful if for some reason you can't get x11vnc to work.- Give yourself a VNC password by using the
vncpasswd
command. -
Start the VNC server by using a command such as
vncserver :2 -geometry 640x480 -depth 16
The geometry (in the above example, 640x480) should be at most half of your screen's resolution, so if your resolution is 1280x1024 then your maximum geometry is 640x512. (If you want to magnify three times, choose one third instead of half, and so on.) Any larger and you will have to scroll around the desktop using scrollbars, which can be awkward. - Now run
wine vncviewer.exe
(or run it under Windows) and a small dialogue box should appear. In Wine it is possible that the text in the dialogue box will not display; don't worry about this. - Double click on the text box and type the
server you want to connect to; this is
localhost:2
for the above example. Now press the button on the bottom right to bring up the Settings dialogue. Find the check box that has two small text boxes immediately to the right of it, and check it. Double click on the first text box to the right of it and type 2 (the magnification factor). Press Enter, then click the top button. - If the connection is successful, you will now be prompted for your VNC password. Type it and press Enter. The magnified desktop should now appear.
- If you know what you're doing you can use a remote server, tunneled over SSH if necessary; in this case it's also better if you have the old version 3 of the server, otherwise the version 3 client will blur its magnification more often, or you can try TightVNC instead (and you get better compression if you have the TightVNC versions of both viewer and server).
- You can disconnect and reconnect the viewer as
you wish. To shut down the desktop, do
killall Xvnc Xrealvnc
. - If using X11 locally (rather than Windows), you might want to put the above into your
.xsession
and avoid running a window manager outside the VNC client, so that all your keypresses reach the window manager on the VNC server. This is especially the case because you will be doing a lot of keyboard navigation due to the lack of being able to drag around the desktop. (Choose a window manager with many shortcuts, e.g. FVWM2, to run on the VNC server.)
NX Client and coLinux
When working on a remote desktop over a limited-bandwidth connection, you may want to use nomachine.com's NX Client instead of VNC. However it seems that NX Client can't very easily magnify the desktop (and magnifying it at the remote end using the above method will slow down NX considerably), so you may want to run the NX client on a local VNC server and then use one of the above methods to enlarge that local VNC server.If your local machine is Windows then setting up an off-display VNC server can be difficult. But if you have administrative access to the system then (if the system won't run Linux) you might be able to install CoLinux:
- Download the stable release from colinux.org and go through the installation wizard (I chose the Debian image)
- After installation, look in C:\Program Files\coLinux, decompress the .1gb.bz2 disk image, and rename it to "root_fs".
- Look in control panel's Network Connections for "Local
Area Connection" (or whatever your default outgoing
Internet connection is), right-click on it and choose
Properties, Advanced, check the "Allow other users..."
box and in the drop-down box choose the new "Local Area
Connection 9" (which is a virtual connection between the
host Windows OS and the guest Linux OS). This will
allow coLinux to use your outgoing Internet connection.
Now run coLinux like this:
colinux-daemon.exe kernel=vmlinux cobd0=root_fs root=/dev/cobd0 \ hda1=:cobd0 eth0=tuntap,"Local Area Connection 9" mem=512 -t nt
(you may want to put that in a batch file.) The initial root password is "root", and you'll have to type in qwerty regardless of your keyboard map; however you can do "loadkeys dvorak" once logged in, if you want to type Dvorak or any other layout. (To shut down the virtual Linux system, just give it ahalt
command.) - You may need to edit the APT configuration
(
nano /etc/
) and add the following lines:apt/ apt.conf.d/ 70debconf APT::Cache-Limit 12582912; APT::Force-LoopBreak true;
then save and exit, and doapt-get update
(it may give some 404 errors which can be ignored as long as the main mirrors respond OK). - If your first
apt-get
command goes wrong, try this:echo '#!/bin/bash' > /usr/sbin/update-rc.d chmod +x /usr/sbin/update-rc.d apt-get -f install
and then repeat theapt-get
command.
vncserver
package;
be sure to get the fonts packages also.
Put exec /usr/NX/bin/nxclient
into
.vnc/xstartup
(or .Xsession
if appropriate, see note
above), then add the above x11vnc
command before it (if
you're using x11vnc for the magnification, which is the recommended method).
If your Windows VNC client is TightVNC then you may need to add -rfbauth
~/.vnc/passwd
to the x11vnc command line because some versions of
TightVNC will hang if the server doesn't need authentication.
If the NX server is on a VPN then you may find
that coLinux can't see this VPN, so you'll need to set up an SSH tunnel and
tell nxclient to connect to that instead, and .vnc/xstartup
may be
a good place to put the appropriate ssh command;
if you've set up an RSA identity then you should just need
something like
ssh -N -l userID -L localhost:8222:nx-host:22 ssh-relay-host &
(you may also want to include an xsetroot -solid darkblue
command
so you don't have to look at a checkered background if the connection is
delayed).
Finally, start the VNC server by using a command such as
vncserver :2 -geometry 480x300 -depth 16You may wish to add an
echo
command after that, reminding you to
connect the VNC client to the IP address of the coLinux machine, display 3.
If your VNC client does not support bump scrolling, then the geometry
should be half the screen's resolution (assuming the magnification factor is
2 as it is in the above x11vnc
command). This may lead to a
very restrictive display. If nxclient says "press Next to continue"
but the Next button is off-screen, you can just press Enter, but once you're
on the remote desktop, you may find that some applications give you dialogue
boxes that are too big for the screen. If your VNC client supports
bump scrolling
then you can multiply this reduced geometry by between 1.6 and 1.8 (i.e.
make it 80-90% of the screen's resolution if the magnification factor is 2)
and then you'll be able to pan around a virtual desktop. (You probably
don't want to make the virtual desktop any larger than 1.6-1.8 times the
screen size, otherwise you may ``get lost'' since even a full-screen window
can disappear too easily.)
TightVNC 1.3.9 under Windows supports bump scrolling in full-screen mode, but it's so fast that you'll probably only be able to position the display on a corner. If you need a more steady scrolling speed, try RealVNC Free Edition 4.1's full-screen mode (you might want to turn off 'Render Cursor Locally' in the RealVNC Options, because x11vnc displays one). I find that neither of these options are as good as bump scrolling in real X11. You might want to have two configurations, one with a small geometry for normal use and another with a larger geometry for when you need to configure applications that have large dialogue boxes; you will however have to re-login to the remote machine each time you change between these configurations.
Copyright and Trademarks
All material © Silas S. Brown unless otherwise stated.Debian is a trademark owned by Software in the Public Interest, Inc.
Linux is the registered trademark of Linus Torvalds in the U.S. and other countries.
Unix is a trademark of The Open Group.
VNC is a registered trademark of RealVNC Limited.
Windows is a registered trademark of Microsoft Corp.
Zoom is a trademark of Zoom Video Communications, Inc.
Any other trademarks I mentioned without realising are trademarks of their respective holders.