How to change and update the title of the command prompt window from the java command line application? Every time I run my application, the command prompt window title shows:
C:WINDOWSsystem32cmd.exe - java MyApp
.
I’d like to change and update the window title as the java program runs, for example as wget(win32) updates downloading status in the title: Wget [12%]
.
Advertisement
Answer
Although I haven’t tried it myself, in Windows, one can use the Win32 API call to SetConsoleTitle
in order to change the title of the console.
However, since this is a call to a native library, it will require the use of something like Java Native Interface (JNI) in order to make the call, and this will only work on Windows 2000 and later.
Edit – A solution using JNI
The following is an example of using JNI in order to change the title of the console window from Java in Windows. To implement this, the prerequiste is some knowledge in C and using the compiler/linker.
First, here’s result:
(source: coobird.net)
Disclaimer: This is my first Java application using JNI, so it’s probably not going to be a good example of how to use it — I don’t perform any error-checking at all, and I may be missing some details.
The Java program was the following:
class ChangeTitle { private static native void setTitle(String s); static { System.loadLibrary("ChangeTitle"); } public static void main(String[] args) throws Exception { for (int i = 0; i < 5; i++) { String title = "Hello! " + i; System.out.println("Setting title to: " + title); setTitle(title); Thread.sleep(1000); } } }
Basically, the title is changed every 5 seconds by calling the setTitle
native method in an external native library called ChangeTitle
.
Once the above code is compiled to make a ChangeTitle.class
file, the javah
command is used to create a C header that is used when creating the C library.
Writing the native library
Writing the library will involve writing the C source code against the C header file generated by javah
.
The ChangeTitle.h
header was the following:
/* DO NOT EDIT THIS FILE - it is machine generated */ #include <jni.h> /* Header for class ChangeTitle */ #ifndef _Included_ChangeTitle #define _Included_ChangeTitle #ifdef __cplusplus extern "C" { #endif /* * Class: ChangeTitle * Method: setTitle * Signature: (Ljava/lang/String;)V */ JNIEXPORT void JNICALL Java_ChangeTitle_setTitle (JNIEnv *, jclass, jstring); #ifdef __cplusplus } #endif #endif
Now, the implementation, ChangeTitle.c
:
#include <windows.h> #include <stdio.h> #include <conio.h> #include <jni.h> #include "ChangeTitle.h" JNIEXPORT void JNICALL Java_ChangeTitle_setTitle(JNIEnv* env, jclass c, jstring s) { const jbyte *str; str = (*env)->GetStringUTFChars(env, s, NULL); SetConsoleTitle(str); (*env)->ReleaseStringUTFChars(env, s, str); };
A String
that is passed into the native function is changed into an UTF-8 encoded C string, which is sent to the SetConsoleTitle
function, which, as the function name suggests, changes the title of the console.
(Note: There may be some issues with just passing in the string into the SetConsoleTitle
function, but according to the documentation, it does accept Unicode as well. I’m not too sure how well the code above will work when sending in various strings.)
The above is basically a combination of sample code obtained from Section 3.2: Accessing Strings of The Java Native Interface Programmer’s Guide and Specification, and the SetConsoleTitle
Function page from MSDN.
For a more involved sample code with error-checking, please see the Section 3.2: Accessing Strings and SetConsoleTitle
Function pages.
Building the DLL
The part that turned out to take the most amount of time for me to figure out was getting the C files to compile into an DLL that actually could be read without causing an UnsatisfiedLinkError
.
After a lot of searching and trying things out, I was able to get the C source to compile to a DLL that could be called from Java. Since I am using MinGW, I found a page form mingw.org
which described exactly how to build a DLL for JNI.
Sources:
- The Java Native Interface Programmer’s Guide and Specification
- Chapter 2: Getting Started – Details the process using JNI.
- JNI-MinGW-DLL – Building a JNI DLL on MinGW with gcc.