【发布时间】:2011-12-04 19:01:50
【问题描述】:
我有一个 java 程序,它在后台运行并监视系统剪贴板的更改(我通过轮询来执行此操作,因为它似乎是除了“所有权变体”之外的唯一方法,我必须在其中重置内容一直成为所有者)。如果它发现特定格式的输入文本,它会处理该文本并用结果覆盖剪贴板(这样我就可以在程序在后台运行时复制输入并粘贴结果)。
到目前为止,这在 Windows 上运行良好,但在 Mac OS X 上运行相同的程序时,行为有点奇怪。只要我不将结果复制到系统剪贴板中,轮询机制本身就会按预期工作。但是在我第一次从java程序中设置剪贴板内容的那一刻,它只在激活时识别未来的外部更改。所以我不能让它在后台运行,而是我必须一直“复制输入->切换到java程序->切换回来->粘贴结果”。
因为这很烦人,而这正是我想通过这种“剪贴板监控 -> 结果粘贴”方法避免的事情,所以我很高兴有任何解决这个问题的想法。
编辑:一些代码片段
public void setClipboardText(String text) {
if (text == null) {
throw new NullPointerException();
}
synchronized (this.lastFoundTextLock) {
this.lastFoundText = text;
Toolkit.getDefaultToolkit().getSystemClipboard()
.setContents(new StringSelection(text), null);
}
}
public String getClipboardText() {
Transferable t = Toolkit.getDefaultToolkit().getSystemClipboard().
getContents(null);
try {
if (t != null && t.isDataFlavorSupported(DataFlavor.stringFlavor)) {
String text = (String) t.getTransferData(DataFlavor.stringFlavor);
return text;
}
} catch (UnsupportedFlavorException e) {
} catch (IOException e) {
}
return null;
}
public void run() {
while (true) {
String currentClipboardText = getClipboardText();
boolean isNew;
synchronized (this.lastFoundTextLock) {
isNew = ((this.lastFoundText != null) || (currentClipboardText != null))
&& ((currentClipboardText == null) || !currentClipboardText
.equals(this.lastFoundText));
if (isNew) {
this.lastFoundText = currentClipboardText;
}
}
if (isNew && currentClipboardText != null) {
//new text found
fireNewClipboardTextFound(currentClipboardText);
}
try {
Thread.sleep(this.automaticCheckInterval);
} catch (InterruptedException e) {
// ignore
}
synchronized (this.monitorRunningLock) {
if (!this.monitorRunning) {
break;
}
}
}
}
【问题讨论】:
-
请您粘贴代码的内容,或者至少粘贴您正在使用的特定类和函数吗?
-
当然。我希望添加的代码片段涵盖了您想知道的所有内容:)