java font.bold_Java 中 Font 字体类的用法介绍

一、Font 类简介

Font 类是用于设置图形用户界面上的字体样式的,包括字体类型(例如宋体、仿宋、Times New Roman 等)、字体风格(例如斜体字、加粗等)、以及字号大小。

二、Font 类的引用声明

Font 类位于 java.awt 包中,使用时需要在代码顶端声明 import java.awt.Font; 或者 import java.awt.*;

三、Font 类的构造函数

Font 类的构造函数如下:

public Font(String familyName,int style,int size)

具体解释如下:

familyName 是字体类型,例如宋体、仿宋、Times New Roman 等;

style 是字体风格,例如斜体字、加粗等;

size 是字体大小,其默认单位为 pt(磅),数字越大、字就越大(例如 12pt 字比 10pt 的字要大)。

官方提供 4 种字体风格固定值,如下:

Font.PLAIN(普通)

Font.BOLD(加粗)

Font.ITALIC(斜体)

Font.BOLD+ Font.ITALIC(粗斜体)

四、Font 类的实例化方法

利用上面第三点介绍的构造函数,我们可以创建一个自定义样式的字体变量 f。

例如:Font f = new Font(“宋体”,Font.BOLD,20);

上述代码表示我声明了一种自定义字体:宋体、加粗、20pt 大小。

五、Font 类的设置方法

当设置好了字体样式后,可以使用 public void setFont(Font font) 方法将指定组件的字体样式更新。

该方法适用于任意组件,例如按钮 JButton、标签 JLabel、多行文本框 JTextArea 等。

完整代码示例如下:

(1)我有一个多行文本框,给它起名字叫做 ta:

JTextArea ta = new JTextArea();

(2)然后我设置一种新的字体样式 f1:

Font f1= new Font(“宋体”,Font.BOLD,20);

(3)我为 ta 文本框设置字体样式为 f1:

ta.setFont(f1);

  • 7
    点赞
  • 42
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
jxl.jar  jxl.jar   通过java操作excel表格的工具库   支持Excel 95-2000的所有版本   生成Excel 2000标准格式   支持字体、数字、日期操作   能够修饰单元格属性   支持图像和图表   应该说以上功能已经能够大致满足我们的需要。最关键的是这套API是纯Java的,并不依赖Windows系统,即使运行在Linux下,它同样能够正确的处理Excel文件。另外需要说明的是,这套API对图形和图表的支持很有限,而且仅仅识别PNG格式。   搭建环境   将下载后的文件解包,得到JXL.JAR,放入classpath,安装就完成了。如果包不能正常的加载,可以把你下载好的JXL.JAR包放入D:\JAVA\jre\lib\ext(我的是JDK1.6)就OK了。我相信在配置TOMCAT时也需要把相关的三个包放到这里面。   基本操作   一、创建文件   拟生成一个名为“测试数据.xls”的Excel文件,其第一个工作表被命名为“第一页”,大致效果如下:   代码(CreateXLS.java):   //生成Excel的   import java.io.*;   import jxl.*;   import jxl.write.*;   public class CreateXLS   {   public static void main(String args[])   {   try   {   //打开文件   WritableWorkbook book=   Workbook.createWorkbook(new File(“测试.xls”));   //生成名为“第一页”的工作表,参数0表示这是第一页   WritableSheet sheet=book.createSheet(“第一页”,0);   //在Label对象的构造子指名单元格位置是第一列第一行(0,0)   //以及单元格内容为test   Label label=new Label(0,0,”test”);   //将定义好的单元格添加到工作表   sheet.addCell(label);   /*生成一个保存数字的单元格   必须使用Number的完整包路径,否则有语法歧义   单元格位置是第二列,第一行,值为789.123*/   jxl.write.Number number = new jxl.write.Number(1,0,789.123);   sheet.addCell(number);   //写入数据并关闭文件   book.write();   book.close();   }catch(Exception e)   {   System.out.println(e);   }   }   }   编译执行后,会在当前位置产生一个Excel文件。   三、读取文件   以刚才我们创建的Excel文件为例,做一个简单的读取操作,程序代码如下:   //读取Excel的   import java.io.*;   import jxl.*;   public class ReadXLS   {   public static void main(String args[])   {   try   {   Workbook book=   Workbook.getWorkbook(new File(“测试.xls”));   //获得第一个工作表对象   Sheet sheet=book.getSheet(0);   //得到第一列第一行的单元格   Cell cell1=sheet.getCell(0,0);   String result=cell1.getContents();   System.out.println(result);   book.close();   }catch(Exception e)   {   System.out.println(e);   }   }   }   程序执行结果:test   四、修改文件   利用jExcelAPI可以修改已有的Excel文件,修改Excel文件的时候,除了打开文件的方式不同之外,其他操作和创建Excel是一样的。下面的例子是在我们已经生成的Excel文件添加一个工作表:   //修改Excel的,添加一个工作表   import java.io.*;   import jxl.*;   import jxl.write.*;   public class UpdateXLS   {   public static void main(String args[])   {   try   {   //Excel获得文件   Workbook wb=Workbook.getWorkbook(new File(“测试.xls”));   //打开一个文件的副本,并且指定数据写回到原文件   WritableWorkbook book=   Workbook.createWorkbook(new File(“测试.xls”),wb);   //添加一个工作表   WritableSheet sheet=book.createSheet(“第二页”,1);   sheet.addCell(new Label(0,0,”第二页的测试数据”));   book.write();   book.close();   }catch(Exception e)   {   System.out.println(e);   }   }   }   高级操作   一、 数据格式化   在Excel不涉及复杂的数据型,能够比较好的处理字串、数字和日期已经能够满足一般的应用。   1、字串格式化   字符串的格式化涉及到的是字体、粗细、字号等元素,这些功能主要由WritableFont和WritableCellFormat来负责。假设我们在生成一个含有字串的单元格时,使用如下语句,为方便叙述,我们为每一行命令加了编号:   WritableFont font1= new WritableFont(WritableFont.TIMES,16,WritableFont.BOLD); 或//设置字体格式为excel支持的格式 WritableFont font3=new WritableFont(WritableFont.createFont("楷体 _GB2312"),12,WritableFont.NO_BOLD );   ① WritableCellFormat format1=new WritableCellFormat(font1);   ② Label label=new Label(0,0,”data 4 test”,format1);   ③ 其①指定了字串格式:字体为TIMES,字号16,加粗显示。   WritableFont有非常丰富的构造子,供不同情况下使用,jExcelAPI的 java-doc有详细列表,这里不再列出。   ②处代码使用了WritableCellFormat,这个非常重要,通过它可以指定单元格的各种属性,后面的单元格格式化会有更多描述。 ③处使用了Label的构造子,指定了字串被赋予那种格式。在WritableCellFormat,还有一个很重要的方法是指定数据的对齐方式,比如针对我们上面的实例,可以指定:   //把水平对齐方式指定为居   format1.setAlignment(jxl.format.Alignment.CENTRE);   //把垂直对齐方式指定为居   format1.setVerticalAlignment(jxl.format.VerticalAlignment.CENTRE);   //设置自动换行   format1.setWrap(true);   二、单元格操作   Excel很重要的一部分是对单元格的操作,比如行高、列宽、单元格合并等,所幸jExcelAPI提供了这些支持。这些操作相对比较简单,下面只介绍一下相关的API。   1、 合并单元格   WritableSheet.mergeCells(int m,int n,int p,int q);   作用是从(m,n)到(p,q)的单元格全部合并,比如:   WritableSheet sheet=book.createSheet(“第一页”,0);   //合并第一列第一行到第六列第一行的所有单元格   sheet.mergeCells(0,0,5,0);   合并既可以是横向的,也可以是纵向的。合并后的单元格不能再次进行合并,否则会触发异常。   2、 行高和列宽   WritableSheet.setRowView(int i,int height);   作用是指定第i+1行的高度,比如:   //将第一行的高度设为200   sheet.setRowView(0,200);   WritableSheet.setColumnView(int i,int width);   作用是指定第i+1列的宽度,比如:   //将第一列的宽度设为30   sheet.setColumnView(0,30);   五、操作图片   public static void write()throws Exception{   WritableWorkbook wwb=Workbook.createWorkbook(new File("c:/1.xls"));   WritableSheet ws=wwb.createSheet("Test Sheet 1",0);   File file=new File("C:\\jbproject\\PVS\\WebRoot\\weekhit\\1109496996281.png");   WritableImage image=new WritableImage(1, 4, 6, 18,file);   ws.addImage(image);   wwb.write();   wwb.close();   }   很简单和插入单元格的方式一样,不过就是参数多了些,WritableImage这个继承了 Draw,上面只是他构造方法的一种,最后一个参数不用说了,前面四个参数的型都是double,依次是 x, y, width, height,注意,这里的宽和高可不是图片的宽和高,而是图片所要占的单位格的个数,因为继承的Draw所以他的型必须是double,具体里面怎么实现的我还没细看:)因为着急赶活,先完成功能,其他的以后有时间慢慢研究。以后会继续写出在使用的心得给大家。   读:   读的时候是这样的一个思路,先用一个输入流(InputStream)得到Excel文件,然后用jxl的Workbook得到工作薄,用Sheet从工作薄得到工作表,用Cell得到工作表得某个单元格。   InputStream->Workbook->Sheet->Cell,就得到了excel文件的单元格   代码:   String path="c:\\excel.xls";//Excel文件URL   InputStream is = new FileInputStream(path);//写入到FileInputStream   jxl.Workbook wb = Workbook.getWorkbook(is); //得到工作薄   jxl.Sheet st = wb.getSheet(0);//得到工作薄的第一个工作表   Cell cell=st.getCell(0,0);//得到工作表的第一个单元格,即A1   String content=cell.getContents();//getContents()将Cell的字符转为字符串   wb.close();//关闭工作薄   is.close();//关闭输入流   我们可以通过Sheet的getCell(x,y)方法得到任意一个单元格,x,y和excel的坐标对应.   例如A1对应(0,0),A2对应(0,1),D3对应(3,2).Excel坐标从A,1开始,jxl全部是从0开始.   还可以通过Sheet的getRows(),getColumns()方法得到行数列数,并用于循环控制,输出一个sheet的所有内容.   写:   往Excel写入内容主要是用jxl.write包。   思路是这样的:   OutputStream<-WritableWorkbook<-WritableSheet<-Label   这里面Label代表的是写入Sheet的Cell位置及内容。   代码:   OutputStream os=new FileOutputStream("c:\\test.xls");//输出的Excel文件URL   WritableWorkbook wwb = Workbook.createWorkbook(os);//创建可写工作薄   WritableSheet ws = wwb.createSheet("sheet1", 0);//创建可写工作表   Label labelCF=new Label(0, 0, "hello");//创建写入位置和内容   ws.addCell(labelCF);//将Label写入sheet   Label的构造函数Label(int x, int y,String aString)xy意同读的时候的xy,aString是写入的内容.   WritableFont wf = new WritableFont(WritableFont.TIMES, 12, WritableFont.BOLD, false);//设置写入字体   WritableCellFormat wcfF = new WritableCellFormat(wf);//设置CellFormat   Label labelCF=new Label(0, 0, "hello");//创建写入位置,内容和格式   Label的另一构造函数Label(int c, int r, String cont, CellFormat st)可以对写入内容进行格式化,设置字体及其它的属性.   现在可以写了   wwb.write();   写完后关闭   wwb.close();   输出流也关闭吧   os.close;   OK,只要把读和写结合起来,就可以在N个Excel读取数据写入你希望的Excel新表,还是比较方便的。   下面是程序一例:   程序代码:sql = "select * from tablename";   rs = stmt.executeQuery(sql);   //新建Excel文件   String filePath=request.getRealPath("aaa.xls");   File myFilePath=new File(filePath);   if(!myFilePath.exists())   myFilePath.createNewFile();   FileWriter resultFile=new FileWriter(myFilePath);   PrintWriter myFile=new PrintWriter(resultFile);   resultFile.close();   //用JXL向新建的文件添加内容   OutputStream outf = new FileOutputStream(filePath);   jxl.write.WritableWorkbook wwb = Workbook.createWorkbook(outf);   jxl.write.WritableSheet ws = wwb.createSheet("sheettest", 0);   int i=0;   int j=0;   for (int k = 0; k < rs.getMetaData().getColumnCount(); k++) {   ws.addCell(new Label(k,0,rs.getMetaData().getColumnName(k+1)));   }   while(rs.next()){   out.println(rs.getMetaData().getColumnCount());   for (int k = 0; k < rs.getMetaData().getColumnCount(); k++) {   ws.addCell(new Label(k,j+i+1,rs.getString(k+1)));   }   i++;   }   wwb.write();   wwb.close();   }catch(Exception e){e.printStackTrace();}   finally{   rs.close();   conn.close();   }   response.sendRedirect("aaa.xls");
Java的Canvas绘图源码实例,主要是画线条、弧线、圆角矩形、三角形、文字、圆形等简单的几何图形,主要是通过创建DrawingCanvas对象canvas,为canvas设置命令监听者,实现接口CommandListener的方法,把缓冲区图像的内容绘制到画布上,画图部分代码:   int w = getWidth(); // 画布的宽度   int h = getHeight(); // 画布的高度   Image buffer = Image.createImage(w, h); // 用于绘图的缓冲图像   Graphics gc = buffer.getGraphics(); // 获取缓冲图像的图形环境   // 清除画布   public void clearScreen() {    gc.setColor(255,255,255); // 设置绘图颜色为白色    gc.fillRect(0,0,w,h); // 把缓冲图像填充为白色    gc.setColor(255,0,0); // 设置绘图颜色为红色   }   // 绘制直线   public void drawLine() {    setTitle("直线"); // 设置画布的标题    clearScreen(); // 清除画布    gc.drawLine(10,10,w-20,h-20); // 绘制黑色直线    gc.setColor(0,0,255); // 设置绘图颜色为蓝色    gc.drawLine(10,h/2,w-10,h/2); // 绘制蓝色直线   }   // 绘制弧   public void drawArc() {    setTitle("弧线和填充弧");    clearScreen();    gc.drawArc(5,5,w/2-20,h/2-20,60,216); // 绘制弧线    gc.drawArc(5,h/2-10,w/2-20,h/2-20,0,360); // 绘制圆    gc.setColor(0,0,255);    gc.fillArc(w/2,5,w/2-20,h/2-20,60,216); // 绘制填充弧线    gc.fillArc(w/2,h/2-10,w/2-20,h/2-20,0,360); // 绘制填充圆   }   // 绘制矩形   public void drawRect() {    setTitle("矩形和填充矩形");    clearScreen();    gc.drawRect(25,25,w/2-30,h/2-30); // 绘制矩形    gc.fillRect(w/2 25,25,w/2-30,h/2-30); // 绘制填充矩形   }   // 绘制圆角矩形   public void drawRoundRect() {    setTitle("圆角矩形和填充圆角矩形");    clearScreen();    gc.drawRoundRect(5,5,w-5-30,h/2-30,20,20); // 绘制圆角矩形    gc.setColor(0,0,255);    gc.fillRoundRect(5,h/2,w-30,h/2-30,20,20); // 绘制填充圆角矩形   }   // 绘制三角形   public void drawTriangle() {    setTitle("填充三角形");    clearScreen();    gc.fillTriangle(w/2, h/6, w/6, h/2, w/2, h/2);   }   // 绘制文字   public void drawText() {    setTitle("文字"); //设置标题    clearScreen();    gc.setFont(Font.getFont(Font.FACE_SYSTEM,Font.STYLE_BOLD,Font.SIZE_SMALL)); // 设置字体    gc.drawString("Hello World!",0,0,gc.TOP|gc.LEFT); // 使用当前字体绘制文字    gc.setFont(Font.getFont(Font.FACE_SYSTEM,Font.STYLE_BOLD|Font.STYLE_UNDERLINED,Font.SIZE_LARGE));    gc.drawString("Hello
Java 2实用教程(第三版)实验指导与习题解答 清华大学出版社 (编著 耿祥义 张跃平) 实验模版代码 建议使用文档结构图 (选择Word菜单→视图→文档结构图) 上机实践1 初识Java 4 实验1 一个简单的应用程序 4 实验2 一个简单的Java Applet程序 4 实验3 联合编译 5 上机实践2 基本数据型与控制语句 6 实验1 输出希腊字母表 6 实验2 回文数 6 实验3 猜数字游戏 8 上机实践3 与对象 9 实验1 三角形、梯形和圆形的封装 9 实验2 实例成员与成员 12 实验3 使用package语句与import语句 13 上机实践4 继承与接口 15 实验1 继承 15 实验2 上转型对象 17 实验3 接口回调 18 上机实践5 字符串、时间与数字 19 实验1 String的常用方法 19 实验2 比较日期的大小 21 实验3 处理大整数 22 上机实践6 组件及事件处理 23 实验1 算术测试 23 实验2 信号灯 25 实验3 布局与日历 28 上机实践7 组件及事件处理2 31 实验1 方程求根 31 实验2 字体对话框 34 实验3 英语单词拼写训练 37 上机实践8 多线程 41 实验1 汉字打字练习 41 实验2 旋转的行星 43 实验3 双线程接力 47 上机实践9 输入输出流 50 实验1 学读汉字 50 实验2 统计英文单词字 53 实验2 读取Zip文件 56 上机实践10 Java 的网络编程 57 实验1 读取服务器端文件 57 实验2 使用套接字读取服务器端对象 59 实验3 基于UDP的图像传输 62 上机实践11 数据结构 66 实验1 扫雷小游戏 66 实验2 排序与查找 70 实验3 使用TreeSet排序 72 上机实践12 java Swing 74 实验1 JLayeredPane分层窗格 74 实验2 使用表格显示日历 75 实验3 多文档界面(MDI) 78 上机实践1 初识Java 实验1 一个简单的应用程序 2.模板代码 Hello.java package 实验一; public class Hello { /** * @param args */ public static void main(String[] args) { // TODO Auto-generated method stub System.out.println("你好,很高兴学习Java"); //命令行窗口输出"你好,很高兴学习Java" A a=new A(); a.fA(); } } class A { void fA() {System.out.println("we are student"); } } 实验2 一个简单的Java Applet程序 2.模板代码 FirstApplet.java import java.applet.*; import java.awt.*; public class FirstApplet extends Applet { public void paint(Graphics g) { g.setColor(Color.blue); g.drawString("这是一个Java Applet 程序",10,30);//在Java Applet绘制一行文字:“这是一个Java Applet 程序” g.setColor(Color.red); g.setFont(new Font("宋体",Font.BOLD,36)); g.drawString("我改变了字体",20,50);//在Java Applet绘制一行文字:“我改变了字体” } }实验3 联合编译 2.模板代码 public class MainClass { public static void main (String args[ ]) { System.out.println("你好,只需编译我") ; //命令行窗口输出"你好,只需编译我" A a=new A(); a.fA(); B b=new B(); b.fB(); } } public class A { void fA() {
整理了Java GUI编程基础知识! public class AllFrame { /** * 这里的代码涉及到 GUI 编程基本面板、基本组件、事件(ActionListener、ChangeListener、MouseListener) */ public AllFrame() { // new 一个主窗体 也可以这样写 new MainFrame(); MainFrame mf = new MainFrame(); } public static void main(String[] args) { new AllFrame(); } // 主窗体 继承 窗体基本格式 Jframe 以下弹出窗口均继承 Jframe class MainFrame extends Jframe implements ActionListener { JMenuBar menubar = new JMenuBar();;// 菜单条 JMenu jmenu[] = new JMenu[5];// panelMenu,usedMenu1,usedMenu2,layoutMenu,helpMenu; // 菜单项 JButton closebtn;// 关闭窗体 // 具体的选项 JMenuItem panelitem[] = new JMenuItem[4]; JMenuItem useditem1[] = new JMenuItem[6]; JMenuItem useditem2[] = new JMenuItem[6]; JMenuItem layoutitem[] = new JMenuItem[3]; JMenuItem helpitem = new JMenuItem("关于"); // 菜单名称 String menu[] = { "面板使用", "常用组件一", "常用组件二", "布局设置", "帮助" }; String pane[] = { "普通面板", "滚动面板", "分割面板", "选项面板" }; String uesd1[] = { "标签", "按钮", "文本框", "文本域", "单选按钮" ,"微调"}; String uesd2[] = { "滑块","复选框", "下拉菜单", "列表", "表格", "树状" }; String layout[] = { "流式布局", "边界布局", "网格布局" }; // Jpanelitem,Jscrollpaneitem,Splitpaneitem,JTabbedpanelitem, // Jlabelitem,Jbuttonitem,JTextfielditem,JTextareaitem,JRadiobuttonitem, // JCheckboxitem,JCombomoxitem,Jlistitem,Jtableitem,Jtreeitem, // Flowlayoutitem,Borderlayoutitem,Girdlayoutitem, // Helpitem}; public MainFrame() { this.setTitle("JAVA图型界面学习(GUI)"); // 加载菜单条到窗体 this.setJMenuBar(menubar); // 重新设置大小 this.setSize(380, 290); // 简单的居方法 在窗体基本格式 Jframe 有详细的居方法 this.setLocationRelativeTo(null); // 设置关闭窗口 this.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE); // 调用方法 menu(); // 设置容器 Container con = this.getContentPane(); // 定义一个 标签 “JAVA图型界面学习” JLabel jl = new JLabel("JAVA图型界面学习"); // 组件 设置字体大小, 其他组件用法相同 jl.setFont(new Font("隶书", Font.BOLD, 24)); // 具体定位 组件名.setBounds(x, y, width, height) jl.setBounds(30, 30, 280, 50); // 把标签加到 con 容器 con.add(jl); /

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值