pushclient+webrtc实现临时p2p点对点音视频通话文字聊天大文件发送接收代码

代码语言:html

所属分类:其他

代码描述:pushclient+webrtc实现临时p2p点对点音视频通话文字聊天大文件发送接收代码,打开页面会显示一个分享二维码与链接,对方扫码或打开链接后就能建立基于webrtc的p2p链接,可以音频通话、视频通话、文件发送、文字聊天,针对临时的2人p2p的通讯需求,无服务器,点对点通讯。

代码标签: pushclient webrtc 临时 p2p 点对点 视频 通话 文字 聊天 文件 发送

下面为部分代码预览,完整代码请点击下载或在bfwstudio webide中打开

<!DOCTYPE html>
<html lang="zh-CN">
<head>
  <meta charset="utf-8" />
  <meta name="viewport" content="width=device-width,initial-scale=1.0"/>
  <title>P2P 通信套件 (文件·聊天·音视频) </title>
<link type="text/css" rel="stylesheet" href="//repo.bfw.wiki/bfwrepo/css/all.6.7.0.css">
  <script src="https://repo.bfw.wiki/bfwrepo/js/qrcode.js"></script>
  <script type="text/javascript" src="//repo.bfw.wiki/bfwrepo/js/pushclient.js"></script>
  <style>
    :root{--primary:#007bff;--secondary:#28a745;--danger:#dc3545;--bg:#f8f9fa;--surface:#fff;--border:#dee2e6;--text:#212529;--muted:#6c757d;}
    
    html, body{margin:0;padding:0;height:100%;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;background-color:#e9ecef;overflow:hidden;}

    /* --- App Container --- */
    .app-container{width:100%;height:100%;display:flex;align-items:center;justify-content:center;padding:1rem;}
    .app-window{width:100%;height:100%;max-width:800px;max-height:90vh;background:var(--surface);border-radius:16px;box-shadow:0 12px 28px rgba(0,0,0,.1), 0 2px 4px rgba(0,0,0,.05);display:flex;flex-direction:column;overflow:hidden;position:relative;}

    /* --- Initial Connection View --- */
    #initial-connection-view{margin:auto;}
    .connection-panel{text-align:center;padding:2rem;max-width:340px;}
    .connection-panel h2{margin:0 0 1rem;color:var(--text);font-size:1.5rem;font-weight:600;}
    .connection-panel p{margin:6px 0 1rem;color:var(--muted);font-size:14px;}
    #qrcode{margin:1rem auto;padding:1rem;background:#fff;border-radius:12px;box-shadow:0 4px 16px rgba(0,0,0,.06);width:fit-content;display:flex;align-items:center;justify-content:center;}
    .link-box{display:flex;margin:1rem 0;border:1px solid var(--border);border-radius:8px;overflow:hidden;}
    #share-link{flex:1;border:none;padding:10px 12px;font-size:14px;outline:none;color:var(--text);background:#f8f9fa;}
    #copy-link-btn{background:var(--primary);color:#fff;border:none;padding:0 1.25rem;cursor:pointer;font-weight:500;display:inline-flex;align-items:center;gap:8px;}
    #copy-link-btn:hover{background:#0069d9;}

    /* --- Main Chat View --- */
    #main-chat-view{display:none;flex-direction:column;width:100%;height:100%;}
    
    /* Header */
    .chat-header{padding:0.75rem 1.25rem;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:10px;flex-shrink:0;}
    .chat-header h3{margin:0;font-size:1.1rem;font-weight:600;}
    .status-indicator{width:10px;height:10px;border-radius:50%;background-color:var(--secondary);}
    
    /* Log Area */
    .chat-log-container{flex:1;overflow-y:auto;padding:1rem;background:var(--bg);}
    .chat-log{display:flex;flex-direction:column;gap:12px;}
    .bubble{max-width:75%;padding:10px 16px;border-radius:18px;line-height:1.5;word-wrap:break-word;font-size:15px;}
    .bubble.me{align-self:flex-end;background:var(--primary);color:#fff;border-bottom-right-radius:4px;}
    .bubble.peer{align-self:flex-start;background:#e9ecef;color:#222;border:1px solid #e3e3e3;border-bottom-left-radius:4px;}
    .bubble.system{align-self:center;background:#ced4da;color:var(--surface);font-size:12px;padding:4px 12px;border-radius:12px;}
    .bubble.media{padding:6px; back.........完整代码请登录后点击上方下载按钮下载查看

网友评论0