SelectBox in Frame

SelectBox in Frame

首先,建立Frameset帧结构,为每个frame页面起名(红色部分):

<FRAMESET COLS="134,*" FRAMEBORDER="0">
<FRAME SRC="nav.htm" SCROLLING="NO" name="left">
<FRAME SRC="main.htm" name="right">
</FRAMESET>

以上请自己调整适应自己的页面。

下面是左侧的页面nav.htm的代码:

<HTML>
<HEAD>
<TITLE></TITLE>
</HEAD>

<SCRIPT LANGUAGE="JavaScript">
<!--
function selectbox(indexbox) {

parent.right.location.href = document.selectform.select.options[indexbox].value;
}
//-->
</SCRIPT>

<BODY BGCOLOR="WHITE">

<FORM name="selectform">
<div align="center">
<SELECT onChange="selectbox(this.selectedIndex);" SIZE=6 name="select">
<OPTION VALUE="link1.htm">连接页面1
<OPTION VALUE="link2.htm">连接页面2
<OPTION VALUE="link3.htm">连接页面3
<OPTION VALUE="link4.htm">连接页面4
<OPTION VALUE="link5.htm">连接页面5
<OPTION VALUE="link6.htm">连接页面6 //一共6个连接页面,与上面的数字一致。
</SELECT>
</div>
</FORM>

</BODY>
</HTML>

右侧的页面随便。注意:颜色相同部分要一致。right是左侧的frame的名字啊。

如果不需要在FRAME中打开页面,用location替换parent.right.location.href 即可在全页面打开连接,当然不必再建立FRAMESET了。

import cv2 import torch import argparse from pathlib import Path from models.experimental import attempt_load from utils.general import non_max_suppression, scale_coords from utils.torch_utils import select_device # 定义命令行参数 parser = argparse.ArgumentParser() parser.add_argument('--source', type=str, default='e:/pythonproject/pythonproject/runs/detect/exp2/test1.mp4', help='视频文件路径') parser.add_argument('--weights', type=str, default='e:/pythonproject/pythonproject/best.pt', help='YOLOv5 模型权重文件路径') parser.add_argument('--conf-thres', type=float, default=0.25, help='预测置信度阈值') parser.add_argument('--iou-thres', type=float, default=0.45, help='NMS 的 IoU 阈值') parser.add_argument('--device', default='0', help='使用的 GPU 编号,或者 -1 表示使用 CPU') args = parser.parse_args() # 加载 YOLOv5 模型 device = select_device(args.device) model = attempt_load(args.weights, device=device).to(device).eval() # 加载视频 vid_path = args.source vid_name = Path(vid_path).stem vid_writer = None if vid_path != '0': vid_cap = cv2.VideoCapture(vid_path) else: vid_cap = cv2.VideoCapture(0) assert vid_cap.isOpened(), f'无法打开视频:{vid_path}' # 视频帧循环 while True: # 读取一帧 ret, frame = vid_cap.read() if not ret: break # 对图像进行目标检测 img = torch.from_numpy(frame).to(device) img = img.permute(2, 0, 1).float().unsqueeze(0) / 255.0 pred = model(img)[0] pred = non_max_suppression(pred, args.conf_thres, args.iou_thres, classes=None, agnostic=False) # 处理检测结果 boxes = [] for i, det in enumerate(pred): if len(det): det[:, :4] = scale_coords(img.shape[2:], det[:, :4], frame.shape).round() for xyxy, conf, cls in reversed(det): label = f'{model.names[int(cls)]} {conf:.2f}' boxes.append((int(xyxy[0]), int(xyxy[1]), int(xyxy[2]), int(xyxy[3]), label)) # 绘制矩形框 if len(boxes) > 0: for box in boxes: x1, y1, x2, y2, label = box cv2.rectangle(frame, (x1, y1), (x2, y2), (0, 255, 0), 2) cv2.putText(frame, label, (x1, y1 - 10), cv2.FONT_HERSHEY_SIMPLEX, 0.5, (0, 255, 0), 2) # 显示帧 cv2.imshow(vid_name, frame) # 写入输出视频 if vid_writer is None: fourcc = cv2.VideoWriter_fourcc('mp4v') vid_writer = cv2.VideoWriter(f'{vid_name}_output.mp4', fourcc, 30, (frame.shape[1], frame.shape[0]), True) vid_writer.write(frame) # 按下 q 键退出 if cv2.waitKey(1) == ord('q'): break # 释放资源 vid_cap.release() if vid_writer is not None: vid_writer.release() cv2.destroyAllWindows(),请指出这段代码的错误
05-23
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值