Autore Topic: Errore nel tentativo di inserire le librerie awt di Java in un progetto Android?  (Letto 370 volte)

Offline AndreaNobili

  • Utente junior
  • **
  • Post: 75
  • Respect: 0
    • Mostra profilo
Salve a tutti,
tempo fà mi ero divertito a creare una semplicissima applicazioncina Java che prendeva un'immagine JPG in input e gli applicava un filtro di blurring (una cavolata...il filtro è generato da una semplice matricetta...)

Ora per fare questa cosa devo usare per forza la libreria awt di Java da quello che ho capito (non mi pare che in Android siano incluse classi analoghe).

Allora ho provato a fare la seguente cosa: in Eclipse sono andato su: mio progetto --> Properties --> Libraries --> Add Library ed ho aggiunto JRE System Libraries (che appunto dovrebbe contenere le awt...almeno credo...)

Questo è il codice della mia Activity (che di fatto ricalca il codice della mia applicazione Java funzionante...):

Codice: [Seleziona]
package andrea.classi;

import java.io.File;
import java.io.IOException;
import java.awt.image.BufferedImage;
import java.awt.image.BufferedImageOp;
import java.awt.image.ConvolveOp;

import java.awt.image.Kernel;

import javax.imageio.ImageIO;

import android.app.Activity;
import android.os.Bundle;

public class FiltriAndroidActivity extends Activity {
    /** Called when the activity is first created. */
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);
       
        File inputFile = new File("/home/andrea/workspace2/blur1/img/", "pesce-pagliaccio.jpg");
        System.out.println("inputFile punta a: " + inputFile.toString());
               
        // KERNEL:
                float[] matrix = {
                                0.111f, 0.111f, 0.111f,
                            0.111f, 0.111f, 0.111f,
                            0.111f, 0.111f, 0.111f,
                 };
               
                BufferedImageOp op = new ConvolveOp(new Kernel(3, 3, matrix));                // Ho creato l'operatore di convoluzione basato sulla matrice definita
               
                BufferedImage originalImg = null;
                try {
                        originalImg = ImageIO.read(inputFile);
                } catch (IOException e) {
                        // TODO Auto-generated catch block
                        e.printStackTrace();
                }                                                                        // Mette dentro image una BufferedImage contenuta nel file
                BufferedImage destImg = null;
                try {
                        destImg = ImageIO.read(inputFile);
                } catch (IOException e) {
                        // TODO Auto-generated catch block
                        e.printStackTrace();
                }
                 
                BufferedImage blurredImage = op.filter(originalImg, destImg);
               
                File outputFile = new File("/home/andrea/workspace2/blur1/img/", "pesce-pagliaccio-output2.jpg");                // Creo il file di output
                try {
                        ImageIO.write(blurredImage, "jpg", outputFile);
                } catch (IOException e) {
                        // TODO Auto-generated catch block
                        e.printStackTrace();
                }                                                                                // Salvo l'immagine filtrata nel file appena creato                                                               
               
       
    }
}

Nell'editor di Eclipse non dà errori di codice...come se avesse visto la libreria aggiunta...ma quando vado ad eseguire l'applicazione mi si blocca dicendo:

Sorry. This application FiltriAndroid (process andrea.classi) has stopped unexpectly. Please try again

Nello stacktrace appare il seguente messaggio di errore:

Codice: [Seleziona]
09-26 19:47:43.935: ERROR/dalvikvm(648): Could not find class 'java.awt.image.ConvolveOp', referenced from method andrea.classi.FiltriAndroidActivity.onCreate
09-26 19:47:44.216: ERROR/AndroidRuntime(648): FATAL EXCEPTION: main
09-26 19:47:44.216: ERROR/AndroidRuntime(648): java.lang.NoClassDefFoundError: java.awt.image.ConvolveOp
09-26 19:47:44.216: ERROR/AndroidRuntime(648):     at andrea.classi.FiltriAndroidActivity.onCreate(FiltriAndroidActivity.java:33)
09-26 19:47:44.216: ERROR/AndroidRuntime(648):     at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047)
09-26 19:47:44.216: ERROR/AndroidRuntime(648):     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1586)
09-26 19:47:44.216: ERROR/AndroidRuntime(648):     at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1638)
09-26 19:47:44.216: ERROR/AndroidRuntime(648):     at android.app.ActivityThread.access$1500(ActivityThread.java:117)
09-26 19:47:44.216: ERROR/AndroidRuntime(648):     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:928)
09-26 19:47:44.216: ERROR/AndroidRuntime(648):     at android.os.Handler.dispatchMessage(Handler.java:99)
09-26 19:47:44.216: ERROR/AndroidRuntime(648):     at android.os.Looper.loop(Looper.java:123)
09-26 19:47:44.216: ERROR/AndroidRuntime(648):     at android.app.ActivityThread.main(ActivityThread.java:3647)
09-26 19:47:44.216: ERROR/AndroidRuntime(648):     at java.lang.reflect.Method.invokeNative(Native Method)
09-26 19:47:44.216: ERROR/AndroidRuntime(648):     at java.lang.reflect.Method.invoke(Method.java:507)
09-26 19:47:44.216: ERROR/AndroidRuntime(648):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:839)
09-26 19:47:44.216: ERROR/AndroidRuntime(648):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597)
09-26 19:47:44.216: ERROR/AndroidRuntime(648):     at dalvik.system.NativeStart.main(Native Method)
09-26 19:47:48.436: ERROR/CheckinTask(285): Checkin failed: https://android.clients.google.com/checkin (request #0)
09-26 19:47:48.436: ERROR/CheckinTask(285): org.apache.http.conn.ConnectTimeoutException: Connect to /209.85.169.113:443 timed out
09-26 19:47:48.436: ERROR/CheckinTask(285):     at org.apache.http.conn.scheme.PlainSocketFactory.connectSocket(PlainSocketFactory.java:121)
09-26 19:47:48.436: ERROR/CheckinTask(285):     at org.apache.http.impl.conn.DefaultClientConnectionOperator.openConnection(DefaultClientConnectionOperator.java:143)
09-26 19:47:48.436: ERROR/CheckinTask(285):     at org.apache.http.impl.conn.AbstractPoolEntry.open(AbstractPoolEntry.java:164)
09-26 19:47:48.436: ERROR/CheckinTask(285):     at org.apache.http.impl.conn.AbstractPooledConnAdapter.open(AbstractPooledConnAdapter.java:119)
09-26 19:47:48.436: ERROR/CheckinTask(285):     at org.apache.http.impl.client.DefaultRequestDirector.execute(DefaultRequestDirector.java:348)
09-26 19:47:48.436: ERROR/CheckinTask(285):     at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:555)
09-26 19:47:48.436: ERROR/CheckinTask(285):     at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:487)
09-26 19:47:48.436: ERROR/CheckinTask(285):     at android.net.http.AndroidHttpClient.execute(AndroidHttpClient.java:248)
09-26 19:47:48.436: ERROR/CheckinTask(285):     at com.google.android.common.http.GoogleHttpClient.executeWithoutRewriting(GoogleHttpClient.java:203)
09-26 19:47:48.436: ERROR/CheckinTask(285):     at com.google.android.common.http.GoogleHttpClient.execute(GoogleHttpClient.java:245)
09-26 19:47:48.436: ERROR/CheckinTask(285):     at com.google.android.common.http.GoogleHttpClient.execute(GoogleHttpClient.java:313)
09-26 19:47:48.436: ERROR/CheckinTask(285):     at com.google.android.gsf.checkin.CheckinTask.sendRequest(CheckinTask.java:254)
09-26 19:47:48.436: ERROR/CheckinTask(285):     at com.google.android.gsf.checkin.CheckinTask.doInBackground(CheckinTask.java:150)
09-26 19:47:48.436: ERROR/CheckinTask(285):     at com.google.android.gsf.checkin.CheckinService$1.doInBackground(CheckinService.java:221)
09-26 19:47:48.436: ERROR/CheckinTask(285):     at com.google.android.gsf.checkin.CheckinService$1.doInBackground(CheckinService.java:214)
09-26 19:47:48.436: ERROR/CheckinTask(285):     at android.os.AsyncTask$2.call(AsyncTask.java:185)
09-26 19:47:48.436: ERROR/CheckinTask(285):     at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:306)
09-26 19:47:48.436: ERROR/CheckinTask(285):     at java.util.concurrent.FutureTask.run(FutureTask.java:138)
09-26 19:47:48.436: ERROR/CheckinTask(285):     at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1088)
09-26 19:47:48.436: ERROR/CheckinTask(285):     at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:581)
09-26 19:47:48.436: ERROR/CheckinTask(285):     at java.lang.Thread.run(Thread.java:1019)

E' come se non trovasse la classe java.awt.image.ConvolveOp (ma allora perchè nell'editor di Eclipse non me lo segna come errore?)

Googlando ho trovato questo riferimento all'androidjavadoc:
ConvolveOp
e pare che la classe sia proprio quella...

Cosa sbaglio? Come posso usare queste classi all'interno di un progetto Android?

Grazie mille
Andrea