百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

利用 Fluid 自制 Mac 版 Overcast 应用

zhezhongyun 2025-07-06 18:01 3 浏览

我喜爱收听播客,健身、上/下班途中,工作中,甚至是忙着做家务时。大多数情况下我会用 Marco Arment开发的Overcast(Freemium)在 iPhone 上收听,这是我目前最喜爱的 Podcast 应用之一1,我享受 Overcast「杀手级」功能 Smart Speed(智能加速)2和 Voice Boost(声音均衡器)3所带来的收听效率以及更棒的音质。

虽然 Overcast 有 Web App,可每日在浏览器中为其独立打开一个标签页总会感到厌烦,一不小心把浏览器关闭了,还得重新打开浏览器输入网址或者点击「个人收藏」上的标签重新开启。我一直渴望 Overcast 的桌面客户端能尽早登陆 OS X 平台,尤其是在 instacast 母公司Vemedio 宣布终止 Instacast 项目之后,期望更加强烈。

于是,我决定着手解决这件事,利用 Fluid把 Overcast Web App 创建成 Fake Mac App,方便日常使用。

关于 Fluid

Fluid.app 可以把任意 Web App 创建成独立的 Mac App,支持「Pin to Status Bar」功能(需付费解锁),方便用户在 Menu Bar 上对所创建的 Mac App 进行直接操作。

Fluid.app 的基础功能是免费的,用户可以免费下载安装。支付 4.99 美元可获得完整版,解锁额外的功能:

  • 创建的 Mac App 可以使用单独的 Cookie (Preferences → Security → Cookie Storage);
  • Pin 创建的 Mac App 到 Menu Bar (Fluid.app Menu → Pin to Status Bar…);
  • 创建的 Mac App 可以自定义 Userscripts 和 Userstyles (Window → Userscripts/Userstyles);
  • 全屏模式 (View → Enter Full Screen)。

创建 Overcast Mac App

Part 1:

这一步十分简单,开启 Fluid.app 后在 URL中填写 Overcast Web App 的地址:https://overcast.fmName按自己喜好填写,如:OvercastLacation选择存放路径;Icon添加一个自己喜欢的 icon。如果留空,Fluid.app 会自动从 Web App 上抓取一个 icon。

Part 2:

点击「Create」即可完成 Overcast Mac App 的创建。开启 Overcast Mac App 后做如下设置:

Preferences → General
  • Home page: https://overcast.fm
  • Global shortcut: O(全局 Hotkey 快捷操作,可按自己的喜好设置)

Preferences → Security
  • Enable plug-ins
  • Enable Javascript
  • Accept Cookies: Only from sites I visit
  • Cookie Storage: Shared with Safari (需付费解锁)

Preferences → Whitelist
  • Allowbrowsing to URLs matching these
  • Patterns: *overcast.fm*

完成上述设置后,基于免费版 Fluid.app 所创建的 Overcast Mac App 已完成,如果你想让 Overcast Mac App 拥有更为完善的功能,接近完美的用户界面,则需要付费解锁完整版,才可按下列步骤继续操作。

Pin It

把 Overcast Mac App 的工作界面 Pin 到 Menu Bar 上4Overcast Menu → Pin to Status Bar…,「Pin to Status Bar」后 Overcast Mac App 支持基本的 Hotkey 快捷操作,如:(前进)和(后退)。

Userscripts

利用 @DannyBres编写的脚本添加自定义 Hotkey 快捷方式,在 Menu Bar 上右键(U)Overcast Mac App 的 icon,点选 Userscripts。

复制如下脚本,按上图所标注步骤创建一个新的 Userscripts,Pattern:*overcast.fm*

var episodeBody = $('#episode_body').text;

if (showUnreadNumberOnDock == false){
 window.fluid.dockBadge = ""; 
} else {
 var pathname = window.location.pathname;
 if (pathname == "/podcasts" && showUnreadNumberOnDock == true) {
 var numberOfUnread = $('.episodecell').length;
 window.fluid.dockBadge = numberOfUnread;
 }
}

$('body').keydown(function(event) {
 if (event.keyCode == 80) {
 toggleAudio;
 }
 if (event.keyCode == 70) {
 skipForwards;
 }
 if (event.keyCode == 66) {
 skipBackwards;
 }
 if (event.keyCode == 71) {
 goFaster;
 }
 if (event.keyCode == 83) {
 goSlower;
 }
 console.log(event.keyCode)
});
function toggleAudio {
 if (!$('#audioplayer').get(0).paused) {
 $('#audioplayer').get(0).pause;
 } else {
 $('#audioplayer').get(0).play;
 } 
}
function skipForwards {
 $('#audioplayer').get(0).currentTime+=forwardSkipDuration;
}
function skipBackwards {
 $('#audioplayer').get(0).currentTime-=backwardSkipDuration;
}
function goFaster {
 $('#audioplayer').get(0).playbackRate+=speedIncrease;
 updatePlaybackDisplay;
}
function goSlower {
 if($('#audioplayer').get(0).playbackRate - speedDecrease > 0) $('#audioplayer').get(0).playbackRate-=speedDecrease;
 updatePlaybackDisplay;
}
function updatePlaybackDisplay {
 if ($('#audioplayer').get(0).playbackRate == 1) {
 var textForBody = episodeBody;
 } else {
 var textForBody = 'Playback speed: ' + $('#audioplayer').get(0).playbackRate.toFixed(2) + " - "+episodeBody;
 }
 $('#episode_body').text(textForBody);
}

此脚本所对应的 Hotkey 5快捷方式如下:

  • P— [Play] 暂停或播放当前播客;
  • F— [Forwards] 向前快进 30 秒;
  • B— [Backwards] 向后倒退 30 秒;
  • G— [Go Faster] 提高 0.1 倍播放速度6;
  • S— [Slower] 降低 0.1 倍播放速度。

Userstyles

Overcast Mac App 工作界面在 OS X 10.10+ 上有点格格不入,利用 @thanland所编写的Userstyles和手动收缩窗口重新布局 Overcast Mac App 的工作界面,并新增一条 2px 橙色滚动条7,使之更有原生 Mac App 的范儿。

复制如下脚本,按上图所标注步骤创建一个新的 Userstyles,Pattern 同为:overcast.fm

/* Custom scroll bar */
html {
    overflow: auto;
}
 
body {
    position: absolute;
    top: 10px;
    left: 0;
    bottom: 10px;
    right: 10px;
    padding: 30px 20px 30px 30px; 
    overflow-y: scroll;
    overflow-x: hidden;
}
 
::-webkit-scrollbar {
    width: 2px;
}
 
::-webkit-scrollbar-track {
    background: #eee;
}
 
::-webkit-scrollbar-thumb {
    -webkit-border-radius: 10px;
    border-radius: 10px;
    background: rgba(252,126,15,0.8); 
}
 
::-webkit-scrollbar-thumb:window-inactive {
    background: rgba(252,126,15,0.4); 
}
 
/* Page layout tweaks */
.nav {
    padding-top: 0 !important;
}
 
.container h2:first-child {
    margin-top: 0 !important;
}
 
#audioplayer {
    margin-bottom: 1em !important;
}

按上述步骤操作完毕后,一款功能完善功能,界面美观的 Fake Overcast Mac App 便创建完成。Enjoy it!

结语

以上内容只是抛砖引玉,如果感兴趣还可以利用 Fluid.app + Web App 创建你所需要的 Fake Mac App,对应的 Userscripts/Userstyles 脚本可在 GitHub Gist上查找或者自行编写。

  1. 另一款是 Supertop 团队开发 Castro,界面美观,交互新颖。
  2. 缩短播客中出现的间歇时间(如主播说话间的停顿),以节省收听时间,并且尽量不会让收听者察觉到有何不同。
  3. 调整播客播放的音量,使音量过低或过高的内容通过算法平衡到一个正常水平。让播客在嘈杂的环境中更具可听性。
  4. 需要注意的是,工作界面下方的 Status Bar 不会自动隐藏,需手动按下 Hotkey:/让其隐藏。
  5. 对应的 Hotkey 可按需自行修改,其 keyCode 值可参考:css-tricks.com
  6. 需要注意的是,使用该 Hoykey 操作时 Speed 项中的阀值不会随之改变。倍速值纯靠心中默念。: )
  7. 默认值为 1px,多次调试后我个人认为 2px 更为美观。

相关推荐

激光手术矫正视力对眼睛到底有没有伤害?

因为大家询问到很多关于“基质不能完全愈合”的问题,有必要在这里再详细解释一下。谢谢@珍惜年少时光提出的疑问:因为手头刚好在看组织学,其中提到:”角膜基质约占角膜的全厚度的90%,主要成分是胶原板层,...

OneCode核心概念解析——View(视图)

什么是视图?在前面的章节中介绍过,Page相关的概念,Page是用户交互的入口,具有Url唯一性。但Page还只是一个抽象的容器,而View则是一个具备了具体业务能力的特殊的Page,它可以是一个...

精品博文图文详解Xilinx ISE14.7 安装教程

在软件安装之前,得准备好软件安装包,可从Xilinx官网上下载:http://china.xilinx.com/support/download/index.html/content/xilinx/z...

卡片项目管理(Web)(卡片设计的流程)

简洁的HTML文档卡片管理,简单框架个人本地离线使用。将个人工具类的文档整理使用。优化方向:添加图片、瀑布式布局、颜色修改、毛玻璃效果等。<!DOCTYPEhtml><html...

GolangWeb框架Iris项目实战-JWT和中间件(Middleware)的使用EP07

前文再续,上一回我们完成了用户的登录逻辑,将之前用户管理模块中添加的用户账号进行账号和密码的校验,过程中使用图形验证码强制进行人机交互,防止账号的密码被暴力破解。本回我们需要为登录成功的用户生成Tok...

sitemap 网站地图是什么格式?有什么好处?

sitemap网站地图方便搜索引擎发现和爬取网页站点地图是一种xml文件,或者是txt,是将网站的所有网址列在这个文件中,为了方便搜索引擎发现并收录的。sitemap网站地图分两种:用于用户导...

如何在HarmonyOS NEXT中处理页面间的数据传递?

大家好,前两天的Mate70的发布,让人热血沸腾啊,不想错过,自学的小伙伴一起啊,今天分享的学习笔记是关于页面间数据伟递的问题,在HarmonyOSNEXT5.0中,页面间的数据传递可以有很多种...

从 Element UI 源码的构建流程来看前端 UI 库设计

作者:前端森林转发链接:https://mp.weixin.qq.com/s/ziDMLDJcvx07aM6xoEyWHQ引言由于业务需要,近期团队要搞一套自己的UI组件库,框架方面还是Vue。而业界...

jq+ajax+bootstrap改了一个动态分页的表格

最近在维护一个很古老的项目,里面是用jq的dataTable方法实现一个分页的表格,不过这些表格的分页是本地分页。现在想要的是点击分页去请求数据。经过多次的修改,以失败告终。分页的不准确,还会有这个错...

学习ES6- 入门Vue(大量源代码及笔记,带你起飞)

ES6学习网站:https://es6.ruanyifeng.com/箭头函数普通函数//普通函数this指向调用时所在的对象(可变)letfn=functionfn(a,b){...

青锋微服务架构之-Ant Design Pro 基本配置

青锋(msxy)-Gitee.com1、更换AntDesignPro的logo和名称需要修改文件所在位置:/config/defaultSetting.jsconstproSett...

大数据调度服务监控平台(大数据调度服务监控平台官网)

简介SmartKettle是针对上述企业的痛点,对kettle的使用做了一些包装、优化,使其在web端也能具备基础的kettle作业、转换的配置、调度、监控,能在很大一定程度上协助企业完成不同...

Flask博客实战 - 实现博客首页视图及样式

本套教程是一个Flask实战类教程,html/css/javascript等相关技术栈不会过多的去详细解释,那么就需要各位初学者尽可能的先去掌握这些基础知识,当然本套教程不需要你对其非常精通,但最起码...

Web自动化测试:模拟鼠标操作(ActionChains)

在日常的测试中,经常会遇到需要鼠标去操作的一些事情,比如说悬浮菜单、拖动验证码等,这一节我们来学习如何使用webdriver模拟鼠标的操作首页模拟鼠标的操作要首先引入ActionChains的包fro...

DCS F-16C 中文指南 16.9ILS仪表降落系统教程

10–ILS教程我们的ILS(仪表着陆进近)将到达Batumi巴统机场。ILS频率:110.30跑道航向:120磁航向/126真航向无线电塔频率:131.0001.设置雷达高度表开关打开(前)并...