3

ピアツーピアチャットユーザー間で画像を送信する必要があるチャットアプリを開発しています。今のところ画像を送信できず、filereceiverもリクエストを受け入れてファイルの受信を開始します。

ただし、印刷ステータスは常に印刷を継続します: ログ: 進行状況:0.0&ステータス:進行中

そして、スレッドを終了した後- ログ###ファイル転送が完了していません。ステータス:進行中

このスレッドを実行してカウントを削除すると、印刷が続行されます-進行状況:0.0&ステータス:進行中

時々完全な画像が後で受け取られます..それは長い時間がかかり、何倍も半分またはサイズ0です。

private ServiceDiscoveryManager sdm;    
 if (sdm == null)
                    sdm = new ServiceDiscoveryManager(connection);
                Log.v("---fileReceive----","after discover connectin.....");
                sdm.addFeature("http://jabber.org/protocol/disco#info");
                sdm.addFeature("jabber:iq:privacy");

                ProviderManager.getInstance().addIQProvider("query","http://jabber.org/protocol/bytestreams", new BytestreamsProvider());
                ProviderManager.getInstance().addIQProvider("query","http://jabber.org/protocol/disco#items", new DiscoverItemsProvider());
                ProviderManager.getInstance().addIQProvider("query","http://jabber.org/protocol/disco#info", new DiscoverInfoProvider());
                ProviderManager.getInstance().addIQProvider("si", "http://jabber.org/protocol/si", new StreamInitiationProvider());
                ProviderManager.getInstance().addIQProvider("query", "http://jabber.org/protocol/bytestreams", new BytestreamsProvider());                    
                ProviderManager.getInstance().addIQProvider("open", "http://jabber.org/protocol/ibb", new OpenIQProvider());
                ProviderManager.getInstance().addIQProvider("data", "http://jabber.org/protocol/ibb", new DataPacketProvider());
                ProviderManager.getInstance().addIQProvider("close", "http://jabber.org/protocol/ibb", new CloseIQProvider());
                ProviderManager.getInstance().addExtensionProvider("data", "http://jabber.org/protocol/ibb", new DataPacketProvider());

                sdm = ServiceDiscoveryManager.getInstanceFor(connection);


                FileTransferNegotiator.setServiceEnabled(connection, true);
                FileTransferNegotiator.IBB_ONLY = true; 
                manager = new FileTransferManager(connection);
                // Create the listener
                //  fListner=new FileTransferListener() {
                manager.addFileTransferListener(new FileTransferListener() {
                    @Override
                    public void fileTransferRequest(FileTransferRequest request) {
                        // TODO Auto-generated method stub
                        Log.v("----Recieve File",
                                "new file transfere requesttttt------------");

                        Log.v("-----file request","from" + request.getRequestor());

                        // Accept it

                        try {
                            IncomingFileTransfer transfer = request.accept();
                            Log.v("----transfer--","accepted");

                            double percents = 0.0;
                            int currentCycle = 0;
                            transfer.recieveFile(new File( Environment.getExternalStorageDirectory().getPath()+"/"+transfer.getFileName()));


                              while(!transfer.isDone() && currentCycle < 100) {
                                    if(transfer.getStatus().equals(Status.in_progress)) {
                                        percents = ((int) (transfer.getProgress()*10000)) / 100.0;
                                                  //percents is 100.0 after 1 cycle
                                        Log.i(LOG, "Filetransfer Progress: "+percents + " Status: "+transfer.getStatus().toString());
                                    } else if (transfer.getStatus().equals(Status.error)) {
                                        Log.e(LOG, "FileTransfer ERROR"+transfer.getError().getMessage());
                                        break;
                                    } 
                                    currentCycle ++;
                                    try {
                                        Thread.sleep(1000);
                                    } catch (InterruptedException e) {
                                        e.printStackTrace();
                                    }
                                }

                                if(transfer.getStatus().equals(Status.complete)) {
                                    if (onFileReceivedListener != null) {
                                       onFileReceivedListener.onFileReceived(transfer);
                                    }
                                }else{
                                    Log.e(LOG, "###Filetransfer not complete. Status:" + transfer.getStatus().toString());
                                                        //FILE IS HERE  
                                }
                        } catch (XMPPException e) {
                            e.printStackTrace();
                        }
                    }
                }); `

ヒントや助けをいただければ幸いです。

4

1 に答える 1

0

私は最近asmackとsmackxの経験が少しありましたが、それらについてあまり前向きになることはできません。

あなたの問題がどこから来ているのか正確にはわかりませんが、それは正常であると言えます。進行状況が実際に開始する前に、最初に進行状況の負荷=0を取得します。送信する小さなファイルの場合は、送信が非常に速いため、実際の進行状況はありません。

ただし、より大きなファイルを正常に送信できれば、この関数はかなりうまく機能し、大まかな進行状況が得られます。

結局、この機能は単にバグがあり、独自のファイル転送xmppメッセージを制限して実装し、独自のサーバー経由での送信を処理するためのものであると結論付けました。そのように、グループ(MUC)でオフラインの人にファイルを送信し、両側(送信と受信)で適切な進捗状況を示すこともできます。

于 2013-03-14T10:37:11.627 に答える