⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 contikilog.java

📁 Contiki是一个开源
💻 JAVA
字号:
/* * Copyright (c) 2008, Swedish Institute of Computer Science. * All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * 1. Redistributions of source code must retain the above copyright *    notice, this list of conditions and the following disclaimer. * 2. Redistributions in binary form must reproduce the above copyright *    notice, this list of conditions and the following disclaimer in the *    documentation and/or other materials provided with the distribution. * 3. Neither the name of the Institute nor the names of its contributors *    may be used to endorse or promote products derived from this software *    without specific prior written permission. * * THIS SOFTWARE IS PROVIDED BY THE INSTITUTE AND CONTRIBUTORS ``AS IS'' AND * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE * ARE DISCLAIMED.  IN NO EVENT SHALL THE INSTITUTE OR CONTRIBUTORS BE LIABLE * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF * SUCH DAMAGE. * * $Id: ContikiLog.java,v 1.7 2008/10/28 12:55:20 fros4943 Exp $ */package se.sics.cooja.contikimote.interfaces;import java.awt.*;import java.util.*;import javax.swing.*;import org.apache.log4j.Logger;import org.jdom.Element;import se.sics.cooja.*;import se.sics.cooja.contikimote.ContikiMoteInterface;import se.sics.cooja.interfaces.Log;import se.sics.cooja.interfaces.PolledAfterActiveTicks;/** * Log mote interface. Captures both log_message(,) and printf(..). * * Contiki variables: * <ul> * <li>char simLoggedFlag * (1=mote has new outgoing log messages, else no new) * <li>int simLoggedLength * (length of new log message) * <li>byte[] simLoggedData (data of new log messages) * </ul> * <p> * * Core interface: * <ul> * <li>simlog_interface * </ul> * <p> * * This observable notifies at new mote log output. * * @author Fredrik 謘terlind */public class ContikiLog extends Log implements ContikiMoteInterface, PolledAfterActiveTicks {  private static Logger logger = Logger.getLogger(ContikiLog.class);  private Mote mote = null;  private SectionMoteMemory moteMem = null;  private String lastLogMessage = null;  /**   * Creates an interface to mote's logging output.   *   * @param mote    Log's mote.   * @see             Mote   * @see             se.sics.cooja.MoteInterfaceHandler   */  public ContikiLog(Mote mote) {    this.mote = mote;    this.moteMem = (SectionMoteMemory) mote.getMemory();  }  public static String[] getCoreInterfaceDependencies() {    return new String[] { "simlog_interface" };  }  public void doActionsAfterTick() {    if (moteMem.getByteValueOf("simLoggedFlag") == 1) {     int totalLength = moteMem.getIntValueOf("simLoggedLength");      byte[] bytes = moteMem.getByteArray("simLoggedData", totalLength);      char[] chars = new char[bytes.length];      for (int i=0; i < chars.length; i++) {        chars[i] = (char) bytes[i];      }      moteMem.setByteValueOf("simLoggedFlag", (byte) 0);      moteMem.setIntValueOf("simLoggedLength", 0);      String messages[] = String.valueOf(chars).split("\n");      for (String message: messages) {        lastLogMessage = message;        this.setChanged();        this.notifyObservers(mote);      }    }  }  public String getLastLogMessage() {    return lastLogMessage;  }  public JPanel getInterfaceVisualizer() {    JPanel panel = new JPanel();    panel.setLayout(new BorderLayout());    final JTextArea logTextPane = new JTextArea();    logTextPane.setOpaque(false);    logTextPane.setEditable(false);    if (lastLogMessage == null) {      logTextPane.setText("");    } else {      logTextPane.append(lastLogMessage + "\n");    }    Observer observer;    this.addObserver(observer = new Observer() {      public void update(Observable obs, Object obj) {        logTextPane.append(lastLogMessage + "\n");        logTextPane.setCaretPosition(logTextPane.getDocument().getLength());      }    });    // Saving observer reference for releaseInterfaceVisualizer    panel.putClientProperty("intf_obs", observer);    JScrollPane scrollPane = new JScrollPane(logTextPane);    scrollPane.setPreferredSize(new Dimension(100,100));    panel.add(BorderLayout.NORTH, new JLabel("Last log messages:"));    panel.add(BorderLayout.CENTER, scrollPane);    return panel;  }  public void releaseInterfaceVisualizer(JPanel panel) {    Observer observer = (Observer) panel.getClientProperty("intf_obs");    if (observer == null) {      logger.fatal("Error when releasing panel, observer is null");      return;    }    this.deleteObserver(observer);  }  public double energyConsumption() {    // Does not require energy    return 0.0;  }  public Collection<Element> getConfigXML() {    return null;  }  public void setConfigXML(Collection<Element> configXML, boolean visAvailable) {  }}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -