图文编辑器源码
Ⅰ java语言写一个文本编辑器的源代码 要能测试通过的!用Eclipse能运行通过的!
一. 高亮的内容:
需要高亮的内容有:
1. 关键字, 如 public, int, true 等. 
2. 运算符, 如 +, -, *, /等
3. 数字
4. 高亮字符串, 如 "example of string"
5. 高亮单行注释
6. 高亮多行注释
二. 实现高亮的核心方法:
StyledDocument.setCharacterAttributes(int offset, int length, AttributeSet s, boolean replace) 
三. 文本编辑器选择.
Java中提供的多行文本编辑器有: JTextComponent, JTextArea, JTextPane, JEditorPane等, 都可以使用. 但是因为语法着色中文本要使用多种风格的样式, 所以这些文本编辑器的document要使用StyledDocument. 
JTextArea使用的是PlainDocument, 此document不能进行多种格式的着色.
JTextPane, JEditorPane使用的是StyledDocument, 默认就可以使用. 
为了实现语法着色, 可以继承自DefaultStyledDocument, 设置其为这些文本编辑器的documet, 或者也可以直接使用JTextPane, JEditorPane来做. 为了方便, 这里就直接使用JTextPane了.
四. 何时进行着色.
当文本编辑器中有字符被插入或者删除时, 文本的内容就发生了变化, 这时检查, 进行着色.
为了监视到文本的内容发生了变化, 要给document添加一个DocumentListener监听器, 在他的removeUpdate和insertUpdate中进行着色处理.
而changedUpdate方法在文本的属性例如前景色, 背景色, 字体等风格改变时才会被调用.
 @Override
 public void changedUpdate(DocumentEvent e) {
 }
 @Override
 public void insertUpdate(DocumentEvent e) {
  try {
   colouring((StyledDocument) e.getDocument(), e.getOffset(), e.getLength());
  } catch (BadLocationException e1) {
   e1.printStackTrace();
  }
 }
 @Override
 public void removeUpdate(DocumentEvent e) {
  try {
   // 因为删除后光标紧接着影响的单词两边, 所以长度就不需要了
   colouring((StyledDocument) e.getDocument(), e.getOffset(), 0);
  } catch (BadLocationException e1) {
   e1.printStackTrace();
  }
 }
五. 着色范围: 
pos: 指变化前光标的位置.
len: 指变化的字符数.
例如有关键字public, int
单词"publicint", 在"public"和"int"中插入一个空格后变成"public int", 一个单词变成了两个, 这时对"public" 和 "int"进行着色.
着色范围是public中p的位置和int中t的位置加1, 即是pos前面单词开始的下标和pos+len开始单词结束的下标. 所以上例中要着色的范围是"public int". 
提供了方法indexOfWordStart来取得pos前单词开始的下标, 方法indexOfWordEnd来取得pos后单词结束的下标.
 public int indexOfWordStart(Document doc, int pos) throws BadLocationException {
  // 从pos开始向前找到第一个非单词字符.
  for (; pos > 0 && isWordCharacter(doc, pos - 1); --pos);
  return pos;
 }
 public int indexOfWordEnd(Document doc, int pos) throws BadLocationException {
  // 从pos开始向前找到第一个非单词字符.
  for (; isWordCharacter(doc, pos); ++pos);
  return pos;
 }
一个字符是单词的有效字符: 是字母, 数字, 下划线.
 public boolean isWordCharacter(Document doc, int pos) throws BadLocationException {
  char ch = getCharAt(doc, pos); // 取得在文档中pos位置处的字符
  if (Character.isLetter(ch) || Character.isDigit(ch) || ch == '_') 
  return false;
 }
所以着色的范围是[start, end] :
 int start = indexOfWordStart(doc, pos);
 int end = indexOfWordEnd(doc, pos + len);
六. 关键字着色.
从着色范围的开始下标起进行判断, 如果是以字母开或者下划线开头, 则说明是单词, 那么先取得这个单词, 如果这个单词是关键字, 就进行关键字着色, 如果不是, 就进行普通的着色. 着色完这个单词后, 继续后面的着色处理. 已经着色过的字符, 就不再进行着色了.
 public void colouring(StyledDocument doc, int pos, int len) throws BadLocationException {
  // 取得插入或者删除后影响到的单词.
  // 例如"public"在b后插入一个空格, 就变成了:"pub lic", 这时就有两个单词要处理:"pub"和"lic"
  // 这时要取得的范围是pub中p前面的位置和lic中c后面的位置
  int start = indexOfWordStart(doc, pos);
  int end = indexOfWordEnd(doc, pos + len);
  char ch;
  while (start < end) {
   ch = getCharAt(doc, start);
   if (Character.isLetter(ch) || ch == '_') {
    // 如果是以字母或者下划线开头, 说明是单词
    // pos为处理后的最后一个下标
    start = colouringWord(doc, start);
   } else {
    //SwingUtilities.invokeLater(new ColouringTask(doc, pos, wordEnd - pos, normalStyle));
    ++start;
   }
  }
 }
public int colouringWord(StyledDocument doc, int pos) throws BadLocationException {
  int wordEnd = indexOfWordEnd(doc, pos);
  String word = doc.getText(pos, wordEnd - pos); // 要进行着色的单词
  if (keywords.contains(word)) {
   // 如果是关键字, 就进行关键字的着色, 否则使用普通的着色.
   // 这里有一点要注意, 在insertUpdate和removeUpdate的方法调用的过程中, 不能修改doc的属性.
   // 但我们又要达到能够修改doc的属性, 所以把此任务放到这个方法的外面去执行.
   // 实现这一目的, 可以使用新线程, 但放到swing的事件队列里去处理更轻便一点.
   SwingUtilities.invokeLater(new ColouringTask(doc, pos, wordEnd - pos, keywordStyle));
  } else {
   SwingUtilities.invokeLater(new ColouringTask(doc, pos, wordEnd - pos, normalStyle));
  }
  return wordEnd;
 }
因为在insertUpdate和removeUpdate方法中不能修改document的属性, 所以着色的任务放到这两个方法外面, 所以使用了SwingUtilities.invokeLater来实现.
 private class ColouringTask implements Runnable {
  private StyledDocument doc;
  private Style style;
  private int pos;
  private int len;
  public ColouringTask(StyledDocument doc, int pos, int len, Style style) {
   this.doc = doc;
   this.pos = pos;
   this.len = len;
   this.style = style;
  }
  public void run() {
   try {
    // 这里就是对字符进行着色
    doc.setCharacterAttributes(pos, len, style, true);
   } catch (Exception e) {}
  }
 }
七: 源码
关键字着色的完成代码如下, 可以直接编译运行. 对于数字, 运算符, 字符串等的着色处理在以后的教程中会继续进行详解.
import java.awt.Color;
import java.util.HashSet;
import java.util.Set;
import javax.swing.JFrame;
import javax.swing.JTextPane;
import javax.swing.SwingUtilities;
import javax.swing.event.DocumentEvent;
import javax.swing.event.DocumentListener;
import javax.swing.text.BadLocationException;
import javax.swing.text.Document;
import javax.swing.text.Style;
import javax.swing.text.StyleConstants;
import javax.swing.text.StyledDocument;
public class HighlightKeywordsDemo {
 public static void main(String[] args) {
  JFrame frame = new JFrame();
  JTextPane editor = new JTextPane();
  editor.getDocument().addDocumentListener(new SyntaxHighlighter(editor));
  frame.getContentPane().add(editor);
  frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
  frame.setSize(500, 500);
  frame.setVisible(true);
 }
}
/**
 * 当文本输入区的有字符插入或者删除时, 进行高亮.
 * 
 * 要进行语法高亮, 文本输入组件的document要是styled document才行. 所以不要用JTextArea. 可以使用JTextPane.
 * 
 * @author Biao
 * 
 */
class SyntaxHighlighter implements DocumentListener {
 private Set<String> keywords;
 private Style keywordStyle;
 private Style normalStyle;
 public SyntaxHighlighter(JTextPane editor) {
  // 准备着色使用的样式
  keywordStyle = ((StyledDocument) editor.getDocument()).addStyle("Keyword_Style", null);
  normalStyle = ((StyledDocument) editor.getDocument()).addStyle("Keyword_Style", null);
  StyleConstants.setForeground(keywordStyle, Color.RED);
  StyleConstants.setForeground(normalStyle, Color.BLACK);
  // 准备关键字
  keywords = new HashSet<String>();
  keywords.add("public");
  keywords.add("protected");
  keywords.add("private");
  keywords.add("_int9");
  keywords.add("float");
  keywords.add("double");
 }
 public void colouring(StyledDocument doc, int pos, int len) throws BadLocationException {
  // 取得插入或者删除后影响到的单词.
  // 例如"public"在b后插入一个空格, 就变成了:"pub lic", 这时就有两个单词要处理:"pub"和"lic"
  // 这时要取得的范围是pub中p前面的位置和lic中c后面的位置
  int start = indexOfWordStart(doc, pos);
  int end = indexOfWordEnd(doc, pos + len);
  char ch;
  while (start < end) {
   ch = getCharAt(doc, start);
   if (Character.isLetter(ch) || ch == '_') {
    // 如果是以字母或者下划线开头, 说明是单词
    // pos为处理后的最后一个下标
    start = colouringWord(doc, start);
   } else {
    SwingUtilities.invokeLater(new ColouringTask(doc, start, 1, normalStyle));
    ++start;
   }
  }
 }
 /**
  * 对单词进行着色, 并返回单词结束的下标.
  * 
  * @param doc
  * @param pos
  * @return
  * @throws BadLocationException
  */
 public int colouringWord(StyledDocument doc, int pos) throws BadLocationException {
  int wordEnd = indexOfWordEnd(doc, pos);
  String word = doc.getText(pos, wordEnd - pos);
  if (keywords.contains(word)) {
   // 如果是关键字, 就进行关键字的着色, 否则使用普通的着色.
   // 这里有一点要注意, 在insertUpdate和removeUpdate的方法调用的过程中, 不能修改doc的属性.
   // 但我们又要达到能够修改doc的属性, 所以把此任务放到这个方法的外面去执行.
   // 实现这一目的, 可以使用新线程, 但放到swing的事件队列里去处理更轻便一点.
   SwingUtilities.invokeLater(new ColouringTask(doc, pos, wordEnd - pos, keywordStyle));
  } else {
   SwingUtilities.invokeLater(new ColouringTask(doc, pos, wordEnd - pos, normalStyle));
  }
  return wordEnd;
 }
 /**
  * 取得在文档中下标在pos处的字符.
  * 
  * 如果pos为doc.getLength(), 返回的是一个文档的结束符, 不会抛出异常. 如果pos<0, 则会抛出异常.
  * 所以pos的有效值是[0, doc.getLength()]
  * 
  * @param doc
  * @param pos
  * @return
  * @throws BadLocationException
  */
 public char getCharAt(Document doc, int pos) throws BadLocationException {
  return doc.getText(pos, 1).charAt(0);
 }
 /**
  * 取得下标为pos时, 它所在的单词开始的下标. ±wor^d± (^表示pos, ±表示开始或结束的下标)
  * 
  * @param doc
  * @param pos
  * @return
  * @throws BadLocationException
  */
 public int indexOfWordStart(Document doc, int pos) throws BadLocationException {
  // 从pos开始向前找到第一个非单词字符.
  for (; pos > 0 && isWordCharacter(doc, pos - 1); --pos);
  return pos;
 }
 /**
  * 取得下标为pos时, 它所在的单词结束的下标. ±wor^d± (^表示pos, ±表示开始或结束的下标)
  * 
  * @param doc
  * @param pos
  * @return
  * @throws BadLocationException
  */
 public int indexOfWordEnd(Document doc, int pos) throws BadLocationException {
  // 从pos开始向前找到第一个非单词字符.
  for (; isWordCharacter(doc, pos); ++pos);
  return pos;
 }
 /**
  * 如果一个字符是字母, 数字, 下划线, 则返回true.
  * 
  * @param doc
  * @param pos
  * @return
  * @throws BadLocationException
  */
 public boolean isWordCharacter(Document doc, int pos) throws BadLocationException {
  char ch = getCharAt(doc, pos);
  if (Character.isLetter(ch) || Character.isDigit(ch) || ch == '_') 
  return false;
 }
 @Override
 public void changedUpdate(DocumentEvent e) {
 }
 @Override
 public void insertUpdate(DocumentEvent e) {
  try {
   colouring((StyledDocument) e.getDocument(), e.getOffset(), e.getLength());
  } catch (BadLocationException e1) {
   e1.printStackTrace();
  }
 }
 @Override
 public void removeUpdate(DocumentEvent e) {
  try {
   // 因为删除后光标紧接着影响的单词两边, 所以长度就不需要了
   colouring((StyledDocument) e.getDocument(), e.getOffset(), 0);
  } catch (BadLocationException e1) {
   e1.printStackTrace();
  }
 }
 /**
  * 完成着色任务
  * 
  * @author Biao
  * 
  */
 private class ColouringTask implements Runnable {
  private StyledDocument doc;
  private Style style;
  private int pos;
  private int len;
  public ColouringTask(StyledDocument doc, int pos, int len, Style style) {
   this.doc = doc;
   this.pos = pos;
   this.len = len;
   this.style = style;
  }
  public void run() {
   try {
    // 这里就是对字符进行着色
    doc.setCharacterAttributes(pos, len, style, true);
   } catch (Exception e) {}
  }
 }
}
Ⅱ 源码编辑器电脑版百度怎么下载
你好 很高兴回答你的问题
1、首先,可以在PC下载网下载源码编辑器软件包,解压,双击打开exe文件,进入安装界面
2、选择安装位置,点击下一步
3、创建存放快捷方式的文件夹,点击下一步
4、创建桌面快捷方式,点击下一步
5、准备安装软件,点击安装
6、完成安装,点击完成即可退出安装向导。
根据以上步骤就完成了下载,望采纳 谢谢
Ⅲ 急求简单文本编辑器的C语言源代码,源程序 VC++6.0
//头文件//
main.h
#define CM_FILE_SAVEAS    9072
#define CM_FILE_EXIT    9071
#define CM_FILE_OPEN    9070
#define CM_ABOUT           9069
//主程序文件//
main.c
/*****************************************************/
#include <windows.h>
#pragma hdrstop
#include "Main.h"
static char g_szClassName[] = "MyWindowClass";
static HINSTANCE g_hInst = NULL;
#define IDC_MAIN_TEXT   1001
BOOL LoadFile(HWND hEdit, LPSTR pszFileName)
{
   HANDLE hFile;
   BOOL bSuccess = FALSE;
   hFile = CreateFile(pszFileName, GENERIC_READ, FILE_SHARE_READ, NULL,
      OPEN_EXISTING, 0, 0);
   if(hFile != INVALID_HANDLE_VALUE)
   {
      DWORD dwFileSize;
      dwFileSize = GetFileSize(hFile, NULL);
      if(dwFileSize != 0xFFFFFFFF)
      {
         LPSTR pszFileText;
         pszFileText = (LPSTR)GlobalAlloc(GPTR, dwFileSize + 1);
         if(pszFileText != NULL)
         {
            DWORD dwRead;
            if(ReadFile(hFile, pszFileText, dwFileSize, &dwRead, NULL))
            {
               pszFileText[dwFileSize] = 0; // Null terminator
               if(SetWindowText(hEdit, pszFileText))
                  bSuccess = TRUE; // It worked!
            }
            GlobalFree(pszFileText);
         }
      }
      CloseHandle(hFile);
   }
   return bSuccess;
}
BOOL SaveFile(HWND hEdit, LPSTR pszFileName)
{
   HANDLE hFile;
   BOOL bSuccess = FALSE;
   hFile = CreateFile(pszFileName, GENERIC_WRITE, 0, 0,
      CREATE_ALWAYS, FILE_ATTRIBUTE_NORMAL, 0);
   if(hFile != INVALID_HANDLE_VALUE)
   {
      DWORD dwTextLength;
      dwTextLength = GetWindowTextLength(hEdit);
      if(dwTextLength > 0)// No need to bother if there's no text.
      {
         LPSTR pszText;
         pszText = (LPSTR)GlobalAlloc(GPTR, dwTextLength + 1);
         if(pszText != NULL)
         {
            if(GetWindowText(hEdit, pszText, dwTextLength + 1))
            {
               DWORD dwWritten;
               if(WriteFile(hFile, pszText, dwTextLength, &dwWritten, NULL))
                  bSuccess = TRUE;
            }
            GlobalFree(pszText);
         }
      }
      CloseHandle(hFile);
   }
   return bSuccess;
}
BOOL DoFileOpenSave(HWND hwnd, BOOL bSave)
{
   OPENFILENAME ofn;
   char szFileName[MAX_PATH];
   ZeroMemory(&ofn, sizeof(ofn));
   szFileName[0] = 0;
   ofn.lStructSize = sizeof(ofn);
   ofn.hwndOwner = hwnd;
   ofn.lpstrFilter = "Text Files (*.txt)\0*.txt\0All Files (*.*)\0*.*\0\0";
   ofn.lpstrFile = szFileName;
   ofn.nMaxFile = MAX_PATH;
   ofn.lpstrDefExt = "txt";
   if(bSave)
   {
      ofn.Flags = OFN_EXPLORER | OFN_PATHMUSTEXIST | OFN_HIDEREADONLY |
         OFN_OVERWRITEPROMPT;
         
      if(GetSaveFileName(&ofn))
      {
         if(!SaveFile(GetDlgItem(hwnd, IDC_MAIN_TEXT), szFileName))
         {
            MessageBox(hwnd, "Save file failed.", "Error",
               MB_OK | MB_ICONEXCLAMATION);
            return FALSE;
         }
      }
   }
   else
   {
      ofn.Flags = OFN_EXPLORER | OFN_FILEMUSTEXIST | OFN_HIDEREADONLY;
      if(GetOpenFileName(&ofn))
      {
         if(!LoadFile(GetDlgItem(hwnd, IDC_MAIN_TEXT), szFileName))
         {
            MessageBox(hwnd, "Load of file failed.", "Error",
               MB_OK | MB_ICONEXCLAMATION);
            return FALSE;
         }
      }
   }
   return TRUE;
}
LRESULT CALLBACK WndProc(HWND hwnd, UINT Message, WPARAM wParam, LPARAM lParam)
{
   switch(Message)
   {
      case WM_CREATE:
         CreateWindow("EDIT", "",
            WS_CHILD | WS_VISIBLE | WS_HSCROLL | WS_VSCROLL | ES_MULTILINE |
               ES_WANTRETURN,
            CW_USEDEFAULT, CW_USEDEFAULT, CW_USEDEFAULT, CW_USEDEFAULT,
            hwnd, (HMENU)IDC_MAIN_TEXT, g_hInst, NULL);
         SendDlgItemMessage(hwnd, IDC_MAIN_TEXT, WM_SETFONT,
            (WPARAM)GetStockObject(DEFAULT_GUI_FONT), MAKELPARAM(TRUE, 0));
      break;
      case WM_SIZE:
         if(wParam != SIZE_MINIMIZED)
            MoveWindow(GetDlgItem(hwnd, IDC_MAIN_TEXT), 0, 0, LOWORD(lParam),
               HIWORD(lParam), TRUE);
      break;
      case WM_SETFOCUS:
         SetFocus(GetDlgItem(hwnd, IDC_MAIN_TEXT));
      break;
      case WM_COMMAND:
         switch(LOWORD(wParam))
         {
            case CM_FILE_OPEN:
               DoFileOpenSave(hwnd, FALSE);
            break;
            case CM_FILE_SAVEAS:
               DoFileOpenSave(hwnd, TRUE);
            break;
            case CM_FILE_EXIT:
               PostMessage(hwnd, WM_CLOSE, 0, 0);
            break;
            case CM_ABOUT:
               MessageBox (NULL, "File Editor for Windows !\n Using the Win32 API" , "About...", 0);
         }
      break;
      case WM_CLOSE:
         DestroyWindow(hwnd);
      break;
      case WM_DESTROY:
         PostQuitMessage(0);
      break;
      default:
         return DefWindowProc(hwnd, Message, wParam, lParam);
   }
   return 0;
}
int WINAPI WinMain(HINSTANCE hInstance, HINSTANCE hPrevInstance,
   LPSTR lpCmdLine, int nCmdShow)
{
   WNDCLASSEX WndClass;
   HWND hwnd;
   MSG Msg;
   g_hInst = hInstance;
   WndClass.cbSize        = sizeof(WNDCLASSEX);
   WndClass.style         = 0;
   WndClass.lpfnWndProc   = WndProc;
   WndClass.cbClsExtra    = 0;
   WndClass.cbWndExtra    = 0;
   WndClass.hInstance     = g_hInst;
   WndClass.hIcon         = LoadIcon(NULL, IDI_APPLICATION);
   WndClass.hCursor       = LoadCursor(NULL, IDC_ARROW);
   WndClass.hbrBackground = (HBRUSH)(COLOR_WINDOW+1);
   WndClass.lpszMenuName  = "MAINMENU";
   WndClass.lpszClassName = g_szClassName;
   WndClass.hIconSm       = LoadIcon(NULL, IDI_APPLICATION);
   if(!RegisterClassEx(&WndClass))
   {
      MessageBox(0, "Window Registration Failed!", "Error!",
         MB_ICONEXCLAMATION | MB_OK | MB_SYSTEMMODAL);
      return 0;
   }
   hwnd = CreateWindowEx(
      WS_EX_CLIENTEDGE,
      g_szClassName,
      "A File Program",
      WS_OVERLAPPEDWINDOW,
      CW_USEDEFAULT, CW_USEDEFAULT, 320, 240,
      NULL, NULL, g_hInst, NULL);
   if(hwnd == NULL)
   {
      MessageBox(0, "Window Creation Failed!", "Error!",
         MB_ICONEXCLAMATION | MB_OK | MB_SYSTEMMODAL);
      return 0;
   }
   ShowWindow(hwnd, nCmdShow);
   UpdateWindow(hwnd);
   while(GetMessage(&Msg, NULL, 0, 0))
   {
      TranslateMessage(&Msg);
      DispatchMessage(&Msg);
   }
   return Msg.wParam;
}
Ⅳ 谁有在线网页编辑器源代码ASP网站能用的
城市时尚频道管理系统 软件类别: ASP源码 / 文章管理 
软件语言: 简体中文 
授权方式: 免费版 
文件大小: 2.19M 
系统平台: ASP+ACCESS   
联 系 人: [email protected]
1,文章栏目可二级分类,随意修改,管理员分级管理
2,采用强大的HTML编辑器输入文章
3,不存在任何新闻内容不能分段,不出空格的问题
4,可以直接复制任何图文信息,输出和原来格式一模一样
5,前台使用JS随意调用新闻
6,支持图片文章,无组件上传图片到数据库,前台JS调用
http://www.mycodes.net/soft/10130.htm
Ⅳ 源码编辑器游戏怎么做图片
1、打开源码编辑器。可以直接上传代码片段生成图片,支持所有的编程语言和代码风格,背景色可以自定义,效果实时显示,非常方便。
2、需要保存图片的话,直接点击右上角的Export按钮就行,目前官方支持2种格式的图片,一种是PNG,一种是SVG,输入文件名后,直接就可以保存。以上是源码编辑器游戏怎么做图片的操作方法。
Ⅵ 微信编辑器源码可以插入php页面吗
不可以的,那个微信的编辑器是不开源的,你也找不到那个源码来直接拿下来。
还有什么不懂可以追问。
Ⅶ 跪求好心人分享源码编辑器 V4.0 简体中文版软件免费百度云资源
链接:
提取码:mmvs
软件名称:源码编辑器V4.0简体中文版
语言:简体中文
大小:214.50MB
类别:系统工具
介绍:源码编辑器是一款非常专业的电脑编程软件,通过图文代码的方式,让青少年养成编程兴趣,提高编码学习效率。软件内还提供了素材库供用户选择使用,让孩子在短时间内就能快速提升编程水平,可支持离线编程。
Ⅷ java语言写一个文本编辑器的源代码
import java.awt.*;
import javax.swing.*;
import java.awt.event.*;
import javax.swing.event.*;
import java.util.*;   //Date needed
import java.io.PrintWriter;
public class NotePad extends JFrame
{
 JTextArea jta;
 class newl implements ActionListener
 {
  public void actionPerformed(ActionEvent e)
  {
   jta.setText("");
  }
 }
 
 class openl implements ActionListener
 { public void actionPerformed(ActionEvent e)
 {
  JFileChooser jf=new JFileChooser();
  jf.showOpenDialog(NotePad.this);
  
  }
  
 }
 //保存文件的监听
 class savel implements ActionListener
 {
  public void actionPerformed(ActionEvent e)
  {
   JFileChooser jf = new JFileChooser();
   jf.showSaveDialog(NotePad.this);
   
  }
 }
 //打印的监听 ?
 class printl implements ActionListener
 {
  public void actionPerformed(ActionEvent e)
  {
  // PrintWriter p = new PrintWriter(NotePad.this);
  }
 }
 //退出记事本的监听
 class exitl implements ActionListener
 {
  public void actionPerformed(ActionEvent e)
  {
   System.exit(0);//退出
  }
 }
 
 //拷贝的监听
 class l implements ActionListener
 {
    public void actionPerformed(ActionEvent e)
    {
    jta.(); 
    }
 }
 
 //粘贴的监听
 class pastel implements ActionListener
 {
  public void actionPerformed(ActionEvent e)
  {
   jta.paste();
  }
 }
 //剪切的监听
 class cutl implements ActionListener 
 {
  public void actionPerformed(ActionEvent e)
  {
   jta.cut();
  }
 }
 //查找的监听
 
 //添加日期的监听
 class datel implements ActionListener
 {
  public void actionPerformed(ActionEvent e)
  {
   Date d=new Date();
   jta.append(d.toString());
  }
 }
//构造函数
 public NotePad()
 {
  jta=new JTextArea("",24,40);
  JScrollPane jsp=new JScrollPane(jta);
  JMenuBar jmb=new JMenuBar();
  JMenu  mFile=new JMenu("File");
  JMenu mEdit=new JMenu("Edit");
 
  JMenuItem mNew=new JMenuItem("New",KeyEvent.VK_N);
  mNew.addActionListener(new newl());
  mFile.add(mNew);
  
  JMenuItem mOpen=new JMenuItem("Open",KeyEvent.VK_O);
  mOpen.addActionListener(new openl());
  mFile.add(mOpen);
  
  JMenuItem mSave=new JMenuItem("Save");
  mSave.addActionListener(new savel());
  mFile.add(mSave);
  
  mFile.addSeparator(); //添加分割线
  
  JMenuItem mPrint = new JMenuItem("Print");
  mPrint.addActionListener(new printl());
  mFile.add(mPrint);
  
  mFile.addSeparator(); //添加分割线
  
  JMenuItem mExit=new JMenuItem("Exit");
  mExit.addActionListener(new exitl());
  mFile.add(mExit);
  mFile.setMnemonic(KeyEvent.VK_F);
 
  //编辑菜单的子菜单的处理
  JMenuItem jmi;
  jmi=new JMenuItem("Copy");
  jmi.addActionListener(new l());
  mEdit.add(jmi);
  
  jmi=new JMenuItem("Cut");
  jmi.addActionListener(new cutl());
  mEdit.add(jmi);
  
  jmi=new JMenuItem("Paste");
  jmi.addActionListener(new pastel());
  mEdit.add(jmi);
  
  mEdit.addSeparator(); //添加分割线
  
  jmi=new JMenuItem("Find");
  
  mEdit.add(jmi);
  
  jmi=new JMenuItem("FindNext");
  mEdit.add(jmi);
  mEdit.addSeparator();
  jmi=new JMenuItem("Select All");
  mEdit.add(jmi);
  jmi=new  JMenuItem("Date/Time");
  jmi.addActionListener(new datel());
  mEdit.add(jmi);
  jmb.add(mFile);
  jmb.add(mEdit);
 
  this.setJMenuBar(jmb);
 
  this.getContentPane().add(jsp);
  this.setSize(200,200);
  this.setVisible(true);
 }
 //主函数,程序入口点
 public static void main(String s[])
 {
  new NotePad();
 }
 
}
Ⅸ C# 图片编辑器 源码
去TAO 宝上找个人写吧,或者去买个源代码
Ⅹ 源码编辑器4.0和源码编辑器有什么不同
源码编辑器4.0比源码编辑器性能体验优化提升。修复了已知bug。
源码编辑器是一款非常有趣的软件,这款软件非常适合小朋友使用,这款编程软件其实就是一个动画编辑软件,可以编辑人物各种事件、控制动作、外观、声音、画笔等等,非常容易上手还有助于益智。
无需编程功底。使用简单,鼠标点击即可。条理清晰,快速完成作品。
