我有一个在后台运行的BlackBerry应用程序需要知道何时<!>“未接来电<!>”;系统对话框由系统启动,并以编程方式关闭它而无需用户干预。我怎么能这样做?

我实际上几乎知道对话框何时启动,即稍后我以编程方式结束调用...但是如何获得对话框的引用并关闭它? / p>

有帮助吗?

解决方案

设备关闭按钮的按键注入如下所示:

KeyEvent inject = new KeyEvent(KeyEvent.KEY_DOWN, Characters.ESCAPE, 0);
inject.post();

不要忘记设置设备版本的权限: 选项= <!> gt;高级选项= <!> gt; Applications = <!> gt; [您的申请] = <!> gt;编辑默认权限= <!> GT;交互= <!> gt;关键笔划注入

可能有用:
BlackBerry - 模拟KeyPress活动

代码示例:

class Scr extends MainScreen implements PhoneListener {
    public Scr() {
        Phone.addPhoneListener(this);
    }

    public boolean onClose() {
        Phone.removePhoneListener(this);
        return super.onClose();
    }

    public void callDisconnected(int callId) {
        Timer timer = new Timer();
        timer.schedule(new TimerTask(){public void run() {
            KeyEvent event = new KeyEvent(KeyEvent.KEY_DOWN,  
                        Characters.ESCAPE, 
                        KeyListener.STATUS_NOT_FROM_KEYPAD);
            event.post();
        }}, 1000);      
    }

    public void callAdded(int callId) {
    }

    public void callAnswered(int callId) {
    }

    public void callConferenceCallEstablished(int callId) {
    }

    public void callConnected(int callId) {
    }

    public void callDirectConnectConnected(int callId) {    
    }

    public void callDirectConnectDisconnected(int callId) {
    }

    public void callEndedByUser(int callId) {
    }

    public void callFailed(int callId, int reason) {
    }

    public void callHeld(int callId) {
    }

    public void callIncoming(int callId) {
    }

    public void callInitiated(int callid) {
    }

    public void callRemoved(int callId) {
    }

    public void callResumed(int callId) {   
    }

    public void callWaiting(int callid) {
    }

    public void conferenceCallDisconnected(int callId) {
    }
}

其他提示

如果你知道对话框在那里,并且是最顶层的对话框,那么EventInjector API可能会这样做 - net.rim.device.api.system.EventInjector。当您知道对话框在那里时,发送带有ESCAPE键代码的KeyEvent。该API通常在大多数企业环境中被锁定,但是......

免责声明:我自己没有尝试过,如果有效,我会感到有些惊讶,因为这可能意味着您也可以解除“允许此连接”对话框,这将是一个安全漏洞。

这应该有效:

UiApplication.getUiApplication().invokeLater(new Runnable(){
  public void run(){
    UiApplication.getActiveScreen().close();
  }
});
许可以下: CC-BY-SA归因
不隶属于 StackOverflow
scroll top