本文部分内容和灵感来自eclipse.org网站,特此声明。更多内容,请参考:
http://eclipse.org/articles/Article-SWT-Design-1/SWT-Design-1.html
众所周知,SWT与Swing最大的不同就是它直接使用操作系统提供的现成的本地图形接口,于是具备本地化的Look & Feel。但是它是怎么做到这一点的呢,当然是通过JNI。我们来看一个例子,假定我们使用Win32的API。
我们现在有一个文本框text,通过如下的代码,我们给它一个字符串,并让它选择/highlight从3~5([3,5])的字符。
text.setText(“abcdefgh”);
text.setSelection(3, 6);
在Windows下,这个setSelection方法是怎么实现的呢?我们可以看看源码:

public void setSelection (int start, int end)
{
…
OS.SendMessage (handle, OS.EM_SETSEL, start, end);
OS.SendMessage (handle, OS.EM_SCROLLCARET, 0, 0);
}做过Windows编程的朋友可能一下子就认出了这个SendMessage,这不就是Win32 API中用于向窗体发送消息的函数吗?呵呵,没错,我们再来看一下这个SendMessage方法的原型:

public static final int SendMessage (int hWnd, int Msg, int wParam, int lParam)
{
if (IsUnicode) return SendMessageW (hWnd, Msg, wParam, lParam);
return SendMessageA (hWnd, Msg, wParam, lParam);
}
public static final native int SendMessageW (int hWnd, int Msg, int wParam, int lParam);
public static final native int SendMessageA (int hWnd, int Msg, int wParam, int lParam);
我们看到了两个版本,一个版本针对Unicode,另一个版本针对ASCII,正好Win32 API也是如此,我们在这里看到的是native的方法,这意味着具体还有一组JNI的C代码来直接与操作系统的函数打交道:
#ifndef NO_SendMessageW__IIII
JNIEXPORT jint JNICALL OS_NATIVE(SendMessageW__IIII)
(JNIEnv *env, jclass that, jint arg0, jint arg1, jint arg2, jint arg3)

{
jint rc;
OS_NATIVE_ENTER(env, that, SendMessageW__IIII_FUNC);
rc = (jint)SendMessageW((HWND)arg0, arg1, (WPARAM)arg2, (LPARAM)arg3);
OS_NATIVE_EXIT(env, that, SendMessageW__IIII_FUNC);
return rc;
}
#endif
#ifndef NO_SendMessageA__IIII
JNIEXPORT jint JNICALL OS_NATIVE(SendMessageA__IIII)
(JNIEnv *env, jclass that, jint arg0, jint arg1, jint arg2, jint arg3)

{
jint rc;
OS_NATIVE_ENTER(env, that, SendMessageA__IIII_FUNC);
rc = (jint)SendMessageA((HWND)arg0, arg1, (WPARAM)arg2, (LPARAM)arg3);
OS_NATIVE_EXIT(env, that, SendMessageA__IIII_FUNC);
return rc;
}
#endif
上一页 下一页






