📄 logscreen.java
字号:
// Copyright 2004 Nokia Corporation.
//
// THIS SOURCE CODE IS PROVIDED 'AS IS', WITH NO WARRANTIES WHATSOEVER,
// EXPRESS OR IMPLIED, INCLUDING ANY WARRANTY OF MERCHANTABILITY, FITNESS
// FOR ANY PARTICULAR PURPOSE, OR ARISING FROM A COURSE OF DEALING, USAGE
// OR TRADE PRACTICE, RELATING TO THE SOURCE CODE OR ANY WARRANTY OTHERWISE
// ARISING OUT OF ANY PROPOSAL, SPECIFICATION, OR SAMPLE AND WITH NO
// OBLIGATION OF NOKIA TO PROVIDE THE LICENSEE WITH ANY MAINTENANCE OR
// SUPPORT. FURTHERMORE, NOKIA MAKES NO WARRANTY THAT EXERCISE OF THE
// RIGHTS GRANTED HEREUNDER DOES NOT INFRINGE OR MAY NOT CAUSE INFRINGEMENT
// OF ANY PATENT OR OTHER INTELLECTUAL PROPERTY RIGHTS OWNED OR CONTROLLED
// BY THIRD PARTIES
//
// Furthermore, information provided in this source code is preliminary,
// and may be changed substantially prior to final release. Nokia Corporation
// retains the right to make changes to this source code at
// any time, without notice. This source code is provided for informational
// purposes only.
//
// Nokia and Nokia Connecting People are registered trademarks of Nokia
// Corporation.
// Java and all Java-based marks are trademarks or registered trademarks of
// Sun Microsystems, Inc.
// Other product and company names mentioned herein may be trademarks or
// trade names of their respective owners.
//
// A non-exclusive, non-transferable, worldwide, limited license is hereby
// granted to the Licensee to download, print, reproduce and modify the
// source code. The licensee has the right to market, sell, distribute and
// make available the source code in original or modified form only when
// incorporated into the programs developed by the Licensee. No other
// license, express or implied, by estoppel or otherwise, to any other
// intellectual property rights is granted herein.
package example.btl2capecho;
import java.util.Vector;
import javax.microedition.lcdui.*;
import javax.bluetooth.DiscoveryAgent;
import javax.bluetooth.DiscoveryListener;
// This class represents a simple log screen. In the ideal case,
// the actual log would be encapsulated by a different class
// than the presentation (LogScreen). It is a bit less elegant,
// but eliminates one class, to combine the log and log
// screen in the same class. This MIDlet uses the LogScreen
// mainly as a simple aid during device inquiry + service discovery
// to help a user follow the progress if they wish to. So the
// log isn't persistently saved in the record store. (That would
// be easy to add if it were needed.) For unsophisticated users,
// a MIDlet would use some other visual aid rather than a log to show
// progress through the device inquiry + service discovery phases.
// The target users of this MIDlet are mainly developers learning
// to use Bluetooth, so a LogScreen is probably more helpful for them,
// as it helps show how which Bluetooth devices were found during
// device inquiry, which devices of those are running the desired
// service, and so on.
public class LogScreen
extends Form
implements CommandListener
{
private static final Vector entries = new Vector();
private static final String FIRST_ENTRY = "-- Log started: --\n\n";
// We place a limit the maximum number of entries logged.
// Only the 1 .. MAX_ENTRIES last entries will be kept
// in the log. If the log exceeds MAX_ENTRIES, the
// earliest entries will be deleted.
private static final int MAX_ENTRIES = 300;
static
{
log(FIRST_ENTRY);
}
private final MIDletApplication midlet;
private final Displayable next;
private final Command refreshCommand;
private final Command deleteCommand;
private final Command closeCommand;
public LogScreen(MIDletApplication midlet,
Displayable next,
String title,
String closeLabel)
{
super(title);
this.midlet = midlet;
this.next = next;
refresh(); // add any text already present
refreshCommand = new Command("Refresh", Command.SCREEN, 1);
deleteCommand = new Command("Delete", Command.SCREEN, 2);
closeCommand = new Command(closeLabel, Command.SCREEN, 3);
addCommand(refreshCommand);
addCommand(deleteCommand);
addCommand(closeCommand);
setCommandListener(this);
}
public static void log (String string)
{
if (entries.size() > MAX_ENTRIES)
{
entries.removeElementAt(0);
}
entries.addElement(string);
}
private void refresh()
{
// clear the display's text
while(size() > 0)
{
delete(0);
}
// get the lastest status and display that as text
String text = "";
for (int i=0; i < entries.size(); i++)
{
String str = (String) entries.elementAt(i);
if (str != null)
{
text += str;
}
}
append(text);
}
public void commandAction(Command command, Displayable d)
{
if (command == closeCommand)
{
midlet.logScreenClosed(next);
}
else if (command == refreshCommand)
{
refresh();
}
else if (command == deleteCommand)
{
// The deletion of all log strings affects
// all LogScreen instances.
synchronized(this)
{
entries.removeAllElements();
log(FIRST_ENTRY);
}
refresh();
}
}
// It was somewhat convenient to place these helper
// methods inside the LogScreen class.
public static String inquiryAccessCodeString(int iac)
{
String str = null;
switch(iac)
{
case DiscoveryAgent.CACHED:
str = "CACHED";
break;
case DiscoveryAgent.GIAC:
str = "GIAC";
break;
case DiscoveryAgent.LIAC:
str = "LIAC";
break;
case DiscoveryAgent.PREKNOWN:
str = "PREKNOWN";
break;
}
return str;
}
public static String responseCodeString(int responseCode)
{
String str = null;
switch (responseCode)
{
case DiscoveryListener.SERVICE_SEARCH_COMPLETED:
str = "SERVICE_SEARCH_COMPLETED";
break;
case DiscoveryListener.SERVICE_SEARCH_DEVICE_NOT_REACHABLE:
str = "SERVICE_SEARCH_DEVICE_NOT_REACHABLE";
break;
case DiscoveryListener.SERVICE_SEARCH_ERROR:
str = "SERVICE_SEARCH_ERROR";
break;
case DiscoveryListener.SERVICE_SEARCH_NO_RECORDS:
str = "SERVICE_SEARCH_NO_RECORDS";
break;
case DiscoveryListener.SERVICE_SEARCH_TERMINATED:
str = "SERVICE_SEARCH_TERMINATED";
break;
}
return str;
}
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -