当前位置: 首页 > article >正文

iOS剪贴板同步到Windows剪贴板(无需安装软件的方案)

摘要

剪贴板同步能够提高很多的效率,免去复制、发送、复制、粘贴的步骤,只需要在手机上复制,就可以直接在电脑上 ctrl+v 粘贴,这方面在 Apple 设备中是做的非常好的,Apple 设备之间的剪贴板同步功能(Universal Clipboard)确实非常方便,它可以在 iPhone、iPadMac 之间无缝传输剪贴板内容,从而大大提高工作效率。

但是,iPhone 如何和 Windows 剪贴板同步呢?其实方案有很多,有些是通过安装软件来实现,还有一些是通过输入法自带的剪贴板同步功能来实现,例如微信输入法就有剪贴板同步的功能

本文主要讲的是自己去实现一个单向同步,因为我还没实现双向同步,如果后面有方案我会更新本文。

技术原理

iPhone 中有一个叫做 快捷指令 的APP,这个APP提供了一些方法去操作你的 iPhone ,通过里面提供的API可以创建一个自动化脚本,这个脚本就可以获取剪贴板内容,既然能够获取到 iPhone 的剪贴板内容,那么就可以将剪贴板内容通过 快捷指令 的另一个API发送给 Windows 系统,然后在 Windows 系统通过一个 Python 脚本来实时监控 iPhone 的剪贴板更新,获取到新的剪贴板内容则自动设置 Windows 剪贴板。

捷径指令

快捷指令的截图如下:

在这里插入图片描述

创建个人自动化,设定一个触发条件,触发条件是当打开或者关闭某个APP的时候,执行这个自动化脚本。

自动化脚本的顺序是:

  1. 获取剪贴板;
  2. 对剪贴板的内容进行 URL 编码;
  3. 使用文本将局域网的 HTTP接口 和经过 URL编码的剪贴板内容 进行拼接;
  4. 使用 获取URL内容 这个API将剪贴板内容发送给局域网API;
  5. 结束。

Windows Python脚本

在本地开启一个 php 服务器,通过一个简单的 php 脚本来保存剪贴板的内容。

<?php

$content = $_GET['content'];
file_put_contents('./content.txt', $content);
echo '<h1>OK</h1>';

例如在本地服务器 clipboard 目录下创建 index.php 将上面代码复制进去。

快捷指令发送数据过来的时候,就会将剪贴板内容保存在 content.txt 里面。

然后本地开启 Python 脚本去循环读取这个 content.txt 是否有新内容,如果有则设置到剪贴板。

clipboard.py

import requests
import time
import pyperclip
import tkinter as tk
from tkinter import messagebox

def fetch_content(url):
    try:
        response = requests.get(url)
        response.raise_for_status()
        response.encoding = 'utf-8'
        return response.text
    except requests.RequestException as e:
        print(f"Error fetching content: {e}")
        return None

def show_floating_notification(message):
    # 创建一个透明窗口靠近鼠标指针
    root = tk.Tk()
    root.overrideredirect(True)  # 去掉窗口边框
    root.attributes("-topmost", True)  # 窗口置顶
    root.attributes("-alpha", 0.8)  # 设置透明度
    root.geometry(f"220x30+{root.winfo_pointerx()}+{root.winfo_pointery()}")  # 设置窗口大小和位置
    
    label = tk.Label(root, text=message, bg="#eee", fg="#666", font=("Arial", 11))
    label.pack(expand=True, fill='both')
    
    # 自动关闭窗口
    root.after(2000, root.destroy)  # 3秒后自动关闭窗口
    root.mainloop()

def monitor_content(url, interval=1):
    last_content = None
    while True:
        current_content = fetch_content(url)
        if current_content is not None and current_content != last_content:
            print("New content detected:")
            print(current_content)
            pyperclip.copy(current_content)  # 将内容复制到剪贴板
            print("Content has been copied to the clipboard.")
            show_floating_notification("来自iPhone13的剪贴板内容")
            last_content = current_content
        time.sleep(interval)  # 间隔指定的秒数再检查

if __name__ == "__main__":
    url = "http://192.168.2.112/clipboard/content.txt"
    monitor_content(url)

其它说明

本方案仅为初次实验和研究是可行的,可进行深度优化,会变得更好用。

作者

TANKING


http://www.kler.cn/a/294437.html

相关文章:

  • Python数据预处理
  • 漏洞挖掘 | 某医院小程序支付漏洞+越权
  • LeetCode 40-组合总数Ⅱ
  • 【Java开发】Vue的那些小事(一)
  • 【NOIP普及组】摆花
  • excel功能
  • vue2结合element-ui使用tsx格式实现formily自定义组件
  • 匹配电子邮件地址的正则表达式
  • 人生苦短我用Python Excel文件基本操作
  • 【60天备战软考高级系统架构设计师——第九天:面向对象设计原则】
  • [SUCTF 2018]annonymous1
  • 移动UI:成就勋章页面该如何设计,用例子说明。
  • 大数据决策分析平台建设方案(56页PPT)
  • SpringBoot2:请求处理原理分析-RESTFUL风格接口
  • 交换机自动化备份配置(H3C_无人值守)
  • 前端小白操作指南:如何删除项目中 pre-commit 的提交限制?
  • 【机器人工具箱Robotics Toolbox开发笔记(十五)】六自由度机器人笛卡尔空间轨迹规划仿真实例
  • 过去十年中,深度学习领域经历了许多重要的算法创新和突破。以下是一些关键的深度学习算法,按照时间顺序排列:
  • ChatGPT在医疗行业的应用前景与挑战探析
  • GraphRAG入门:基本概念、应用场景及学习方法
  • 2024国赛数学建模A题B题C题D题E题思路资料模型
  • yolov5 +gui界面+单目测距 实现对图片视频摄像头的测距
  • AI基础 L1 Introduction to Artificial Intelligence
  • Prometheus + Grafana + nVisual 实现运维监控全面可视化
  • 【区块链 + 物联网】基于电子标签的区块链溯源系统 | FISCO BCOS应用案例
  • QT Android开发之Android端usb调试模式设置与问题解决