導航:首頁 > 編程語言 > twainforjava

twainforjava

發布時間:2022-12-12 06:58:02

『壹』 java增強for循環問題

你還是仔細檢查下代碼,或者貼出完整的代碼,從你貼出的代碼來看,這兩種for循環的結果是一樣的,除非你的id為null,結果是不一樣的,否則就是一樣的,我建議,你if判斷條件命中的話,最好加上break,結束循環

『貳』 Java 中 for 和 while 的區別是什麼

for和while 都是循環 ,要是知道 循環次數 可以 用for,
要是不知道循環的次數,但是知道循環的終止條件 , 則用while.

『叄』 用java程序來獲取掃描儀裡面的數據

下面是一個解決方案 , 用到 Morena 6.0 Framework 框架 里的 javaTwain功能 , 貌似搜了一下

好像要收費的,不過你可以找找是否有破解版的,沒有的話,那就只有走偏門了 看是否能通過反編譯 ,看改源代碼了......
RE:
javatwain may be a powerful solution,you can go to www.gnome.sk to download the newest package.
JavaTwain version 5.1 is a part of the Morena 6.0 Framework now.

below is an simple example:
/*
* $Id: ExampleShow.java,v 1.5 2002/07/15 13:48:55 mmotovsk Exp $
*
* Copyright (c) 1999-2002 Gnome spol. s r.o. All Rights Reserved.
*
* This software is the confidential and proprietary information of
* Gnome spol. s r.o. You shall not disclose such Confidential
* Information and shall use it only in accordance with the terms
* of the license agreement you entered into with Gnome.
*/

// JavaTwain package version 5.1

/**
ExampleShow demonstrates how to scan an image using defaults
from the Twain source.

*/
import java.awt.*;
import java.awt.event.*;
import SK.gnome.twain.*;

public class ExampleShow extends Frame
{ Image image;
public void paint(Graphics g)
{ if (null!=image)
g.drawImage(image, 0, 0, this);
}

WindowListener windowAdapter=new WindowAdapter()
{ public void windowClosing(WindowEvent e)
{ System.exit(0);
}
};

public ExampleShow()
{ try
{ addWindowListener(windowAdapter);
setTitle("ExampleShow Frame Application");
// Open TWAIN select source dialog box
// and initialize the source selected by the user.
TwainSource source=TwainManager.selectSource(null);
image=Toolkit.getDefaultToolkit().createImage(source);
// wait for the image to be completed
MediaTracker tracker=new MediaTracker(this);
tracker.addImage(image, 0);
// this is the moment the scanner user interface pops up
System.err.println("Start loading image ...");
try
{ tracker.waitForAll();
}
catch (InterruptedException e)
{ System.err.println("Image loading was interrupted!");
e.printStackTrace();
}
tracker.removeImage(image);
System.err.println("Image loaded ...");
setSize(image.getWidth(this), image.getHeight(this));
setVisible(true);
TwainManager.close();
}
catch (TwainException e)
{ e.printStackTrace();
}
}

public static void main(String[] args)
{ new ExampleShow();
}
}

『肆』 求~~JAVA兩個數組語句解釋

public class CharArray{
public static void main(String [] args){
//聲明一個26的大小的數組,
char c[]=new char[26];
//循環執行26次。因為數組是26大小
for(int i=0;i<26;i++){
//字母 賦值給c幾 例如:c0=a c1=b ....c25=z
//小寫字母a的ascii碼 加 幾 就是a後面的第幾個字母
c[i]=(char)('a'+i);
//輸入結果 a....
System.out.print(c[i]+" ");}
最後的結果是:a b c ... z。

}
}

public class TwainTest{
public static void main(String [] args){
//聲明一個二維數組 大小是4*5
int twain[][]=new int[4][5];
//聲明一個變數k 初始化為0
int k=0;
//循環遍歷二維數組第一維
for(int i=0;i<4;i++){
//循環遍歷二維數組第二維
for(int j=0;j<5;j++){
//每次加1
k++;
//依次賦值給二維數組
twain[i][j]=k;}
}
//用循環輸出二維數組
for(int m=0;m<4;m++){
for(int n=0;n<5;n++){

System.out.print(twain[m][n]+" ");}
//每輸出一行。換行
System.out.println();}

最後的結果形式:
1 2 3 4 5
6 7 8 9 10
11 12 13 14 15
16 17 18 19 20

}
}

// 夠詳細了吧

『伍』 java for循環的解釋

循環的意思就是讓程序重復地執行某些語句。在程序設計時,常常需要處理大量的重復動作,採用循環結構可以降低程序書寫的長度和復雜度,可使復雜問題簡單化,提高程序的可讀性和執行速度。其中,for循環就是循環結構的一種,另外還有while循環和do-while循環語句。但是for循環是開發者明確知道了循環次數。


For循環格式如下:

for(賦初值;判斷條件;賦值加減){

執行語句

}

若是在循環主體中要處理的語句只有一個,可以將大括弧省去。下面列出for循環的流程:

(1)第一次進入for循環是,要為循環控制變數賦初值。

(2)根據判斷條件內容檢查是否要繼續執行循環,當判斷條件為真(true)時,繼續執行循環主體內的語句;判斷條件為假(false)時,則會跳出循環,執行其它語句。

執行完循環主體內的語句後,循環控制變數會根據增減量的要求更改循環控制變數的值,然後再回到步驟(2)重新判斷是否繼續執行循環。更具上面可以畫出下面的流程圖。

『陸』 java雙重FOR循環怎麼寫

public class ForTest {
public static void main(String args[])
{
int[][] a={{1,2,3},{2,3},{5,6,7,8}};

for (int[] is : a) {
for (int i : is) {
System.out.println(i);
}
}
}
}

『柒』 java for循環用法

Java for循環的幾種用法詳解
本文非常適合初學Java的程序員,主要是來了解一下Java中的幾種for循環用法,分析得十分詳細,一起來看看。
J2SE 1.5提供了另一種形式的for循環。藉助這種形式的for循環,可以用更簡單地方式來遍歷數組和Collection等類型的對象。本文介紹使用這種循環的具體方式,說明如何自行定義能被這樣遍歷的類,並解釋和這一機制的一些常見問題。
在Java程序中,要「逐一處理」――或者說,「遍歷」――某一個數組或Collection中的元素的時候,一般會使用一個for循環來實現(當 然,用其它種類的循環也不是不可以,只是不知道是因為for這個詞的長度比較短,還是因為for這個詞的含義和這種操作比較配,在這種時候for循環比其 它循環常用得多)。
對於遍歷數組,這個循環一般是採取這樣的寫法:
清單1:遍歷數組的傳統方式
/* 建立一個數組 */
int[] integers = {1, 2, 3, 4};
/* 開始遍歷 */
for (int j = 0; j < integers.length; j++) {
int i = integers[j];
System.out.println(i);
}
而對於遍歷Collection對象,這個循環則通常是採用這樣的形式:
清單2:遍歷Collection對象的傳統方式
/* 建立一個Collection */
String[] strings = {"A", "B", "C", "D"};
Collection stringList = java.util.Arrays.asList(strings);
/* 開始遍歷 */
for (Iterator itr = stringList.iterator(); itr.hasNext();) {
Object str = itr.next();
System.out.println(str);
}
而在Java語言的最新版本――J2SE 1.5中,引入了另一種形式的for循環。藉助這種形式的for循環,現在可以用一種更簡單地方式來進行遍歷的工作。
1、 第二種for循環
不嚴格的說,Java的第二種for循環基本是這樣的格式:
for (循環變數類型 循環變數名稱 : 要被遍歷的對象) 循環體
藉助這種語法,遍歷一個數組的操作就可以採取這樣的寫法:
清單3:遍歷數組的簡單方式
/* 建立一個數組 */
int[] integers = {1, 2, 3, 4};
/* 開始遍歷 */
for (int i : integers) {
System.out.println(i); /* 依次輸出「1」、「2」、「3」、「4」 */
}
這里所用的for循環,會在編譯期間被看成是這樣的形式:
清單4:遍歷數組的簡單方式的等價代碼
/* 建立一個數組 */
int[] integers = {1, 2, 3, 4};
/* 開始遍歷 */
for (int 變數名甲 = 0; 變數名甲 < integers.length; 變數名甲++) {
System.out.println(integers[變數名甲]); /* 依次輸出「1」、「2」、「3」、「4」 */
}
這里的「變數名甲」是一個由編譯器自動生成的不會造成混亂的名字。
而遍歷一個Collection的操作也就可以採用這樣的寫法:
清單5:遍歷Collection的簡單方式
/* 建立一個Collection */
String[] strings = {"A", "B", "C", "D"};
Collection list = java.util.Arrays.asList(strings);
/* 開始遍歷 */
for (Object str : list) {
System.out.println(str); /* 依次輸出「A」、「B」、「C」、「D」 */
}
這里所用的for循環,則會在編譯期間被看成是這樣的形式:
清單6:遍歷Collection的簡單方式的等價代碼
/* 建立一個Collection */
String[] strings = {"A", "B", "C", "D"};
Collection stringList = java.util.Arrays.asList(strings);
/* 開始遍歷 */
for (Iterator 變數名乙 = list.iterator(); 變數名乙.hasNext();) {
Object str = 變數名乙.next();
System.out.println(str); /* 依次輸出「A」、「B」、「C」、「D」 */
}
這里的「變數名乙」也是一個由編譯器自動生成的不會造成混亂的名字。
因為在編譯期間,J2SE 1.5的編譯器會把這種形式的for循環,看成是對應的傳統形式,所以不必擔心出現性能方面的問題。
不用「foreach」和「in」的原因
Java採用「for」(而不是意義更明確的「foreach」)來引導這種一般被叫做「for-each循環」的循環,並使用「:」(而不是意義 更明確的「in」)來分割循環變數名稱和要被遍歷的對象。這樣作的主要原因,是為了避免因為引入新的關鍵字,造成兼容性方面的問題――在Java語言中, 不允許把關鍵字當作變數名來使用,雖然使用「foreach」這名字的情況並不是非常多,但是「in」卻是一個經常用來表示輸入流的名字(例如 java.lang.System類里,就有一個名字叫做「in」的static屬性,表示「標准輸入流」)。
的確可以通過巧妙的設計語法,讓關鍵字只在特定的上下文中有特殊的含義,來允許它們也作為普通的標識符來使用。不過這種會使語法變復雜的策略,並沒有得到廣泛的採用。
「for-each循環」的悠久歷史
「for-each循環」並不是一個最近才出現的控制結構。在1979正式發布的Bourne shell(第一個成熟的UNIX命令解釋器)里就已經包含了這種控制結構(循環用「for」和「in」來引導,循環體則用「do」和「done」來標識)。
2、防止在循環體里修改循環變數
在默認情況下,編譯器是允許在第二種for循環的循環體里,對循環變數重新賦值的。不過,因為這種做法對循環體外面的情況絲毫沒有影響,又容易造成理解代碼時的困難,所以一般並不推薦使用。
Java提供了一種機制,可以在編譯期間就把這樣的操作封殺。具體的方法,是在循環變數類型前面加上一個「final」修飾符。這樣一來,在循環體 里對循環變數進行賦值,就會導致一個編譯錯誤。藉助這一機制,就可以有效的杜絕有意或無意的進行「在循環體里修改循環變數」的操作了。
清單7:禁止重新賦值
int[] integers = {1, 2, 3, 4};
for (final int i : integers) {
i = i / 2; /* 編譯時出錯 */
}
注意,這只是禁止了對循環變數進行重新賦值。給循環變數的屬性賦值,或者調用能讓循環變數的內容變化的方法,是不被禁止的。
清單8:允許修改狀態
Random[] randoms = new Random[]{new Random(1), new Random(2), new Random(3)};
for (final Random r : randoms) {
r.setSeed(4); /* 將所有Random對象設成使用相同的種子 */
System.out.println(r.nextLong()); /* 種子相同,第一個結果也相同 */
}
3. 類型相容問題
為了保證循環變數能在每次循環開始的時候,都被安全的賦值,J2SE 1.5對循環變數的類型有一定的限制。這些限制之下,循環變數的類型可以有這樣一些選擇:
循環變數的類型可以和要被遍歷的對象中的元素的類型相同。例如,用int型的循環變數來遍歷一個int[]型的數組,用Object型的循環變數來遍歷一個Collection等。
清單9:使用和要被遍歷的數組中的元素相同類型的循環變數
int[] integers = {1, 2, 3, 4};
for (int i : integers) {
System.out.println(i); /* 依次輸出「1」、「2」、「3」、「4」 */
}
清單10:使用和要被遍歷的Collection中的元素相同類型的循環變數
Collection< String> strings = new ArrayList< String>();
strings.add("A");
strings.add("B");
strings.add("C");
strings.add("D");
for (String str : integers) {
System.out.println(str); /* 依次輸出「A」、「B」、「C」、「D」 */
}
循環變數的類型可以是要被遍歷的對象中的元素的上級類型。例如,用int型的循環變數來遍歷一個byte[]型的數組,用Object型的循環變數來遍歷一個Collection< String>(全部元素都是String的Collection)等。
清單11:使用要被遍歷的對象中的元素的上級類型的循環變數
String[] strings = {"A", "B", "C", "D"};
Collection< String> list = java.util.Arrays.asList(strings);
for (Object str : list) {
System.out.println(str);/* 依次輸出「A」、「B」、「C」、「D」 */
}
循環變數的類型可以和要被遍歷的對象中的元素的類型之間存在能自動轉換的關系。J2SE 1.5中包含了「Autoboxing/Auto-Unboxing」的機制,允許編譯器在必要的時候,自動在基本類型和它們的包裹類(Wrapper Classes)之間進行轉換。因此,用Integer型的循環變數來遍歷一個int[]型的數組,或者用byte型的循環變數來遍歷一個 Collection< Byte>,也是可行的。
清單12:使用能和要被遍歷的對象中的元素的類型自動轉換的類型的循環變數
int[] integers = {1, 2, 3, 4};
for (Integer i : integers) {
System.out.println(i); /* 依次輸出「1」、「2」、「3」、「4」 */
}
注意,這里說的「元素的類型」,是由要被遍歷的對象的決定的――如果它是一個Object[]型的數組,那麼元素的類型就是Object,即使裡面裝的都是String對象也是如此。
可以限定元素類型的Collection
截至到J2SE 1.4為止,始終無法在Java程序里限定Collection中所能保存的對象的類型――它們全部被看成是最一般的Object對象。一直到J2SE 1.5中,引入了「泛型(Generics)」機制之後,這個問題才得到了解決。現在可以用Collection< T>來表示全部元素類型都是T的Collection。

『捌』 如何強制退出java for循環

強制退出循環可以在達到需要退出的條件時使用Java 中的中斷語句如break、return。
當使用break語句退出時,只是退出當前循環(如果是嵌套循環任然會執行該break語句外的循環體),如果循環後面還有可執行代碼任會執行;
使用return語句退出時,會退出整個方法體。

『玖』 java for循環(很簡單的)

在for循環的循環體只有一條語句的時候,大括弧是可以省略的。

按你給的例子,for(int b=1;b<=a;b++)這個循環的循環體只是System.out.print('*');這一條語句,所以可以省略x1與x3行的大括弧。

不只for循環,其它大多數的語句塊也是同理,比如if、while等等……

『拾』 用Java直接從掃描儀獲得掃描數據,然後上載到伺服器上,這樣的程序需要利用那些知識點(有關Java)

package e.ctgu.JTwacker;

import java.awt.BorderLayout;
import java.awt.Cursor;
import java.awt.Dimension;
import java.awt.Graphics;
import java.awt.Rectangle;
import java.awt.Toolkit;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import java.awt.event.WindowAdapter;
import java.awt.event.WindowEvent;
import java.awt.event.WindowListener;
import java.awt.image.BufferedImage;
import java.io.File;
import java.io.FileInputStream;

import javax.swing.JButton;
import javax.swing.JComboBox;
import javax.swing.JFrame;
import javax.swing.JPanel;
import javax.swing.JScrollPane;
import javax.swing.JToolBar;
import javax.swing.SwingUtilities;

import com.sun.image.codec.jpeg.JPEGCodec;
import com.sun.image.codec.jpeg.JPEGImageDecoder;

import e.ctgu.twain.JTwain;
/*
這是顯示掃描圖片的frame
*/
public class JTwacker extends JFrame {

class JPEGPanel extends JPanel {

/** Image for the inner class
*/
protected BufferedImage mJPEGPanelBufferedImage;

/** Pnale to diaply the image
*/
public JPEGPanel() {
// no op
}

/** Sets the bufferedimage into the class
* @param bi BufferedImage
*/
public void setBufferedImage(BufferedImage bi) {
if (bi == null) {
return;
}
mJPEGPanelBufferedImage = bi;
Dimension d = new Dimension(mJPEGPanelBufferedImage.getWidth(this),
mJPEGPanelBufferedImage.getHeight(this));
setPreferredSize(d);
revalidate();
repaint();
}

/** Paints the component.
* @param g Graphics object used for the painting
*/
public void paintComponent(Graphics g) {
super.paintComponent(g);
Dimension d = getSize();
g.setColor(getBackground());
g.fillRect(0, 0, d.width, d.height);
if (mJPEGPanelBufferedImage != null) {
g.drawImage(mJPEGPanelBufferedImage, 0, 0, this);
}
}
}

protected JPEGPanel mJpegPanel;

protected BufferedImage mBufferedImage;

protected JComboBox mSourcesCombo;

protected JToolBar mToolBar;

/** Constructor
*/
public JTwacker() {
super("測試");

mJpegPanel = new JPEGPanel();
JScrollPane ps = new JScrollPane(mJpegPanel,
JScrollPane.VERTICAL_SCROLLBAR_ALWAYS,
JScrollPane.HORIZONTAL_SCROLLBAR_ALWAYS);
getContentPane().add(ps, BorderLayout.CENTER);

WindowListener wndCloser = new WindowAdapter() {
public void windowClosing(WindowEvent e) {
System.exit(0);
}
};
addWindowListener(wndCloser);

mToolBar = new JToolBar("Twain");
mToolBar.setFloatable(false);
addButtons();
getContentPane().add(mToolBar, BorderLayout.NORTH);
setSize(800, 600);

/* Center the frame */
Dimension screenDim = Toolkit.getDefaultToolkit().getScreenSize();
Rectangle frameDim = getBounds();
setLocation(
(screenDim.width - frameDim.width) / 2,
(screenDim.height - frameDim.height) / 2
);
setVisible(true);
}

protected void addButtons(){

JButton _ab = new JButton("掃描");
_ab.addActionListener(new ActionListener() {
public void actionPerformed(ActionEvent e) {
acquireImage();
}
});
mToolBar.add(_ab);
mToolBar.addSeparator();

if (e.ctgu.twain.JTwain.getInstance().isTwainAvailble()) {
String[] twainSources = JTwain.getInstance().getAvailableSources();
if (twainSources != null) {
mSourcesCombo = new JComboBox(twainSources);
} else {
mSourcesCombo = new JComboBox();
mSourcesCombo.addItem("<NONE AVAILABLE>");
}
} else {
mSourcesCombo = new JComboBox();
mSourcesCombo.addItem("<NONE AVAILABLE>");
}
mToolBar.add(mSourcesCombo);
}

protected void acquireImage() {
if (JTwain.getInstance().isTwainAvailble()){
if (mSourcesCombo.getItemCount() > 0 ){
String _source = (String)mSourcesCombo.getSelectedItem();
if (_source != null){
String _filename = JTwain.getInstance().acquire(_source);
System.out.println(_filename);

if (_filename != null && _filename.length() > 0) {
File fChoosen = new File(_filename);
// savetofile(fChoosen);
showImage(fChoosen);
} else {
System.out.println("哎呀,怎麼出錯了!");
}
} // end if
} // end if
} // end if
}

protected void showImage(final File file) {
if (file == null || !file.exists()) {
return;
}
setCursor(Cursor.getPredefinedCursor(Cursor.WAIT_CURSOR));

Thread runner = new Thread() {
public void run() {
try {
FileInputStream in = new FileInputStream(file);
JPEGImageDecoder decoder = JPEGCodec.createJPEGDecoder(in);
mBufferedImage = decoder.decodeAsBufferedImage();
in.close();
SwingUtilities.invokeLater( new Runnable() {
public void run() {
reset();
}
});
}
catch (Exception ex) {
ex.printStackTrace();
}
setCursor(Cursor.getPredefinedCursor( Cursor.DEFAULT_CURSOR));
}
};
runner.start();
}

//把掃描得到的圖片保存為文件,然後上傳到伺服器或保存到資料庫中
protected void savetofile(final File file) {
try {
File mfile=new File("c:\\dd.jpg");
if (mfile.exists()) {
mfile.delete();
}else {
file.renameTo(mfile);
}

} catch (Exception e) {
e.printStackTrace();
// TODO: handle exception
}
}

protected void reset() {
if (mBufferedImage != null) {
mJpegPanel.setBufferedImage(mBufferedImage);

}
}

public static void main(String argv[]) {
new JTwacker();
}

}

-------------------------

package e.ctgu.twain;

/*
這是調用動態鏈接庫的類
*/
public class JTwain {

private static final JTwain mInstance = new JTwain();
protected final String DLL_NAME = "jtwain";

private JTwain() {
initLib();
}

public static JTwain getInstance(){
return mInstance;
}

public native boolean isTwainAvailble();

public native String[] getAvailableSources();

public native String acquire();

public native String acquire(String sourceName);

private void initLib(){

try {

System.loadLibrary(DLL_NAME);
}catch(Exception e) {
e.printStackTrace();
}

finally {
// System.out.println("Loading : " + DLL_NAME + ".dll");
}
}
}

閱讀全文

與twainforjava相關的資料

熱點內容
怎麼批量有順序的命名文件夾 瀏覽:209
杭州程序員健身 瀏覽:17
dvd光碟存儲漢子演算法 瀏覽:758
蘋果郵件無法連接伺服器地址 瀏覽:963
phpffmpeg轉碼 瀏覽:672
長沙好玩的解壓項目 瀏覽:145
專屬學情分析報告是什麼app 瀏覽:564
php工程部署 瀏覽:833
android全屏透明 瀏覽:737
阿里雲伺服器已開通怎麼辦 瀏覽:803
光遇為什麼登錄時伺服器已滿 瀏覽:302
PDF分析 瀏覽:486
h3c光纖全工半全工設置命令 瀏覽:143
公司法pdf下載 瀏覽:383
linuxmarkdown 瀏覽:350
華為手機怎麼多選文件夾 瀏覽:683
如何取消命令方塊指令 瀏覽:350
風翼app為什麼進不去了 瀏覽:779
im4java壓縮圖片 瀏覽:362
數據查詢網站源碼 瀏覽:151