Client.html

<meta charset="utf-8">
<html>
    <head>
        <title>title</title>
        <style type="text/css">
            #msg-box{
                float: left;
                height: 300px;
                width: 800px;
                border: 1px solid #000;
                overflow-y: scroll
            }
            #user-box{
                float: left;
                height: 300px;
                width: 100px;
                border: 1px solid #000;
                overflow-y: scroll
            }
            .mark{
                cursor: pointer
            }
            .mark:hover{
                color: blue
            }
        </style>
        <meta name="viewport" content="width=device-width, initial-scale=1">
    </head>
    <body>
        <center>
            <video id="video" width="100" height="100" autoplay></video>
            <input type="button" value="开启摄像头" οnclick="aa()">
        </center>
        <div style="width:100%">
            <div id="msg-box"></div>
            <div id="user-box"></div>
        </div>
        <div style="clear:both">
            <textarea id="msg" cols="30" rows="4"></textarea>
            <br />
            <input type="button" value="发送消息" id="send" />
        </div>
        <script type="text/javascript" src="jquery.js"></script>
        <script type="text/javascript">
            var nickname;
            var socket;
            var room = '<?= $_GET['room']?>';
            nickname = window.prompt('请输入您的昵称:');
            if (!nickname) {
                alert('不能为空');
                location.reload();
            } else {
                socket = new WebSocket('ws://127.0.0.1:9795');
                // console.log(socket);
                socket.onopen = function (Event) {
                    var data = {
                        act: 'login',
                        nickname: nickname,
                        room: room
                    };
                    socket.send(JSON.stringify(data));
                };

                $('#send').click(function () {
                    var con = $('#msg').val();
                    var preg = /^@(.*)[\r\n]/;
                    if (preg.test(con)) {
                        var match = con.match(preg);
                        var content = con.match(/^@.*[\r\n]([\s\S]*)/);
                        var data = {
                            act: '@',
                            from: nickname,
                            to: match[1],
                            con: content[1],
                            room: room
                        };
                    } else {
                        var data = {
                            act: 'msg',
                            nickname: nickname,
                            con: con,
                            room: room
                        };
                    }
                    $('#msg').val('').focus();
                    socket.send(JSON.stringify(data));
                });

                socket.onmessage = function (Event) {
                    var data = JSON.parse(Event.data);
                    console.log(data);
                    if (data.msg_type == 'login' || data.msg_type == 'logout') {
                        var html = '<p>通知:' + data.msg + '</p>';
                    }else if(data.msg_type == '@me'){
                        if(data.from == nickname){
                            var html = '<p>你对【' + data.to + '】说:' + data.msg + '</p>';
                        }else{
                            var html = '<p>【' + data.from + '】对你说:' + data.msg + '</p>';
                        }
                        
                    } else {
                        var html = '<p>' + data.nickname + ':' + data.msg + '</p>';
                    }
                    updateUsers(data.users);
                    $('#msg-box').append(html);
                    $('#msg-box').scrollTop($('#msg-box')[0].scrollHeight);
                };

            }

            function updateUsers(users) {
                $('#user-box').empty();
                $.each(users, function () {
                    $('#user-box').append('<p class="mark">' + this + '</p>');
                });
            }

            $(document).on('click', '.mark', function () {
                var name = $(this).text();
                var value = "@" + name + "\r\n";
                $('#msg').val(value).focus();
            });

function aa(){
        var promisifiedOldGUM = function(constraints) {

            // 第一个拿到getUserMedia,如果存在
            var getUserMedia = (navigator.getUserMedia || navigator.webkitGetUserMedia || navigator.mozGetUserMedia);

            // 有些浏览器只是不实现它-返回一个不被拒绝的承诺与一个错误保持一致的接口
            if (!getUserMedia) {
                return Promise.reject(new Error('getUserMedia is not implemented in this browser-getUserMedia是不是在这个浏览器实现'));
            }

            // 否则,调用包在一个旧navigator.getusermedia承诺
            return new Promise(function(resolve, reject) {
                getUserMedia.call(navigator, constraints, resolve, reject);
            });

        }

        // 旧的浏览器可能无法实现mediadevices可言,所以我们设置一个空的对象第一
        if (navigator.mediaDevices === undefined) {
            navigator.mediaDevices = {};
        }

        // 一些浏览器部分实现mediadevices。我们不能只指定一个对象
        // 随着它将覆盖现有的性能getUserMedia。.
        // 在这里,我们就要错过添加getUserMedia财产。.     
        if (navigator.mediaDevices.getUserMedia === undefined) {
            navigator.mediaDevices.getUserMedia = promisifiedOldGUM;
        }

        // Prefer camera resolution nearest to 1280x720.
        var constraints = {
            audio: true,
            video: {
                width: 1280,
                height: 720
            }
        };

        navigator.mediaDevices.getUserMedia(constraints)
            .then(function(stream) {
                var video = document.querySelector('video');
                video.src = window.URL.createObjectURL(stream);
                video.onloadedmetadata = function(e) {
                    video.play();
                };
            }).catch(function(err) {
                console.log(err.name + ": " + err.message);
            });
}


        </script>
    </body>
</html>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值