2017-11-25 13 views
-1

WhatsappのようにAndroidとsocket.ioの機能に基づいてグループチャットアプリケーションを作成したいと思います。Androidでソケットioを使用してグループチャットを作成する

+0

このスタックオーバーフローのためにはそれほど広すぎますが、かなり完全な答えを受け取ったようですどうしたのですか?それ以来いくつかの質問がありましたようです。 – halfer

答えて

1

私は本当にその質問を理解していないと思いますが、ここ2、3年前にsocket.ioで書いた非常に小さな単純なチャットルームです。私はあなたのブラウザでsocket.ioを使ってチャットグループを構築する方法を学ぶことができます。このページで

<body><ul id="Messages"></ul> 
<form action=""> 
    <input id="Message" autocomplete="off"> 
    <input type="button" id="Send" value="Send"> 
</form> 


<script src="http://code.jquery.com/jquery-1.11.1.js"></script> 
<script> 
    $.getScript('socket.io/socket.io.js', function() { 
     initSocket(); 
    }); 

    var initSocket = function() { 
     var socket = io(); 

     $('#Send').click(function() { 
     var userNameTag = $('#UserNameTag'); 
     var nameTag = userNameTag.html(); 
     if (nameTag) { 
      socket.emit('ioChatMessage', { text: nameTag + ': ' + $('#Message').val(), style: userNameTag[0].style }); 
     } else { 
      socket.emit('ioChatMessage', { text: $('#Message').val() }); 
     } 

     $('#Message').val(''); 
     return false; 
    }); 

    socket.on('ioChatMessage', function (msg) { 
     $('#Messages').append($('<li>').text(msg.text).css(msg.style)); 
    }); 

    window.onbeforeunload = function() { 
     socket.disconnect(); 
    }; 
}; 
    </script> 
</body> 

App.js

var app = require('express')(); 
var http = require('http').Server(app); 
var socket = require('socket.io')(http); 

app.get('*', function(req, res){ 
    res.sendFile(__dirname + '/index.html'); 
}); 

socket.on('connection', function (io) { 
    io.on('ioChatMessage', function (msg) { 
     socket.emit('ioChatMessage', msg); 
    }); 
}); 

http.listen(process.env.PORT); 
+0

これはもちろんあなたが既にノード/ウェブサーバーのセットアップを持っていることを前提としています – Jesse

1

..あなたはスケルトンとしてそれを使用することを願って:

https://socket.io/get-started/chat/

マイrecomendationあなたはそれがAndroidアプリになりたい場合は、チュートリアルで見るようにそれを行うと、それがアンドロイドアプリ誰でもインストールできる作るためのApache Cordovaのを使用することです。

あなたはここからダウンロードできます。

https://cordova.apache.org/

最終index.htmlには、次のようになります。

<!doctype html> 
<html> 
    <head> 
    <title>Socket.IO chat</title> 
    <style> 
     * { margin: 0; padding: 0; box-sizing: border-box; } 
     body { font: 13px Helvetica, Arial; } 
     form { background: #000; padding: 3px; position: fixed; bottom: 0; width: 100%; } 
     form input { border: 0; padding: 10px; width: 90%; margin-right: .5%; } 
     form button { width: 9%; background: rgb(130, 224, 255); border: none; padding: 10px; } 
     #messages { list-style-type: none; margin: 0; padding: 0; } 
     #messages li { padding: 5px 10px; } 
     #messages li:nth-child(odd) { background: #eee; } 
     #messages { margin-bottom: 40px } 
    </style> 
    </head> 
    <body> 
    <ul id="messages"></ul> 
    <form action=""> 
     <input id="m" autocomplete="off" /><button>Send</button> 
    </form> 
    <script src="https://cdn.socket.io/socket.io-1.2.0.js"></script> 
    <script src="https://code.jquery.com/jquery-1.11.1.js"></script> 
    <script> 
     $(function() { 
     var socket = io(); 
     $('form').submit(function(){ 
      socket.emit('chat message', $('#m').val()); 
      $('#m').val(''); 
      return false; 
     }); 
     socket.on('chat message', function(msg){ 
      $('#messages').append($('<li>').text(msg)); 
      window.scrollTo(0, document.body.scrollHeight); 
     }); 
     }); 
    </script> 
    </body> 
</html> 

そしてindex.js:

var app = require('express')(); 
var http = require('http').Server(app); 
var io = require('socket.io')(http); 
var port = process.env.PORT || 3000; 

app.get('/', function(req, res){ 
    res.sendFile(__dirname + '/index.html'); 
}); 

io.on('connection', function(socket){ 
    socket.on('chat message', function(msg){ 
    io.emit('chat message', msg); 
    }); 
}); 

http.listen(port, function(){ 
    console.log('listening on *:' + port); 
}); 
関連する問題