惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

L
LangChain Blog
T
Threatpost
aimingoo的专栏
aimingoo的专栏
Recorded Future
Recorded Future
D
DataBreaches.Net
Stack Overflow Blog
Stack Overflow Blog
Forbes - Security
Forbes - Security
Project Zero
Project Zero
C
CERT Recently Published Vulnerability Notes
Threat Intelligence Blog | Flashpoint
Threat Intelligence Blog | Flashpoint
博客园_首页
AWS News Blog
AWS News Blog
C
Cisco Blogs
AI
AI
D
Docker
T
Tenable Blog
Recent Commits to openclaw:main
Recent Commits to openclaw:main
量子位
T
Threat Research - Cisco Blogs
博客园 - Franky
Google DeepMind News
Google DeepMind News
P
Proofpoint News Feed
N
News | PayPal Newsroom
CTFtime.org: upcoming CTF events
CTFtime.org: upcoming CTF events
S
Security @ Cisco Blogs
T
The Blog of Author Tim Ferriss
G
Google Developers Blog
T
The Exploit Database - CXSecurity.com
Last Week in AI
Last Week in AI
SecWiki News
SecWiki News
L
LINUX DO - 热门话题
N
News and Events Feed by Topic
Scott Helme
Scott Helme
爱范儿
爱范儿
小众软件
小众软件
博客园 - 三生石上(FineUI控件)
C
Comments on: Blog
The Last Watchdog
The Last Watchdog
I
Intezer
Help Net Security
Help Net Security
TaoSecurity Blog
TaoSecurity Blog
freeCodeCamp Programming Tutorials: Python, JavaScript, Git & More
美团技术团队
V
V2EX
Hugging Face - Blog
Hugging Face - Blog
P
Palo Alto Networks Blog
WordPress大学
WordPress大学
H
Heimdal Security Blog
云风的 BLOG
云风的 BLOG
C
Cybersecurity and Infrastructure Security Agency CISA

Все публикации подряд на Хабре

Ловим музу за клавиатуру: как айтишнику стать автором Что умеет Midjourney в 2026? Мой немного грустный разбор этого шикарного инструмента Никто не любит писать тесты, но ИИ может исправить это IPv8 выглядит как мечта. Поэтому почти наверняка не взлетит Производители вернули в продажу материнки с DDR3. Что происходит? Управление агентом с телефона через Telegram теперь в KodaCode От координации к лидерству: как меняется роль руководителя разработки Я сделала родителям бизнес вместо пенсии: зарабатываем 70 тысяч, мама не даёт продать В три раза быстрее приемка товара и оптимизация трудозатрат на 73%: как «РСТ-Инвент» помог Gulliver Group ИИ-шечный мир победил? О влиянии искусственного интеллекта на игропром Кремль снижает давление на Телеграмм пока Европа строит интернет по паспорту Как CEO, CTO и CIO за 8 часов собрали ИИ-директора, который умеет держать позицию под давлением Как (не) потерять домен за выходные Вместо 8 разных VPS: как я организовал практику студентам на одном сервере Почему твой Open Source проект не замечают? R&D: искусство управления неопределенностью в разработке AI-дефляция: вакансий для разработчиков больше, а рост зарплат — худший за 15 лет Мы отдали управление роботами OpenClaw. Что из этого вышло Галактический ID: система идентификации для всех форм разумной жизни Кто решает судьбу вашего проекта? Разбираем заинтересованные стороны. BABOK #1 Код-ревью, в котором дело не в коде Данные переехали. Команда — нет Системной подход к сдаче OSWE в 2025 Почему комната управления реактором покрашена в цвет морской пены 4 YAML-файла вместо PySpark: как аналитикам строить пайплайны без разработчиков LLM-агент для поиска свободных доменов: автоматизируем подбор Когда, зачем и как правильно начинать новую сессию в Claude Code? Как я заставил нейросеть писать макросы для FreeCAD Анатомия ИИ‑агента для подбора персонала. От тысячи резюме к топ‑10 за минуты Опыт разработчика как экономика внимания Автономность как точка невозврата: кто будет субъектом в цифровом будущем Обучение ИИ в «диких» условиях: как рутинные действия превращаются в датасеты Как измерить LLM для задач кибербеза: обзор открытых бенчмарков Где хранить код? Сравнение GitHub, GitLab и Bitbucket Математика объясняет, почему нормальное распределение встречается повсюду Почему ваш FinOps не работает: 12 тезисов от практиков Как подписать проектную документацию УКЭП с использованием бесплатных лицензий Pilot Адаптивное администрирование Sigla Vision Я грузил уран в бочки, а потом 20 лет строил ИТ в атомной отрасли Чем позвонить с Эвереста? История и обзор спутниковой связи. Часть 2 Как языковая модель помогает контролировать качество инструктажей по охране труда в металлургии Как не передать на desktop свой IP в РКН Анатомия SAP Privileges: как устроено управление правами в macOS MoneyDev: Сказка про три главных слова Обновлённый токенизатор видео K-VAE 2.0 от Сбера Как сделать диспетчеризацию дома на 1284 квартиры почти бесплатно Как мы разогнали железную дорогу Мы дали агентам рутину. Теперь надо решить — что делать с освободившимся временем Токсичный контент, промпт-хакинг и защита ИИ — всё о Guardrails для LLM Умный город начинается с точного взгляда: как «Фалькон Тех» меняет пространство к лучшему Навайбкодил приложение для анализа графов Почему Дюну так интересно читать? Упрощаем работу с рутиной или как стать Гендальфом Белым Деконструкция Go: CPU, RAM и что там происходит. Go Assembler база. Часть 1.1 Какие профессии исчезнут из-за ИИ, а какие появятся? И что с этим делать Как мы построили IT-отдел, где хочется расти: архитектурные встречи, прозрачные метрики и книжные подарки Rufler: Делаем из Claude Code автономный рой через один YAML-конфиг Sing-box и белый список приложений Как построить надёжный обмен сообщениями в микросервисах: лучшие практики для enterprise OpenAI строит MLM-пирамиду, а McKinsey и Accenture помогают ей в этом Дом, который не построил Фишер (Часть 2) «Сверхзвуковой математик» против «Вдумчивого логиста»: битва алгоритмов 3D-упаковки Мультимодальные модели – грубый и дорогой инструмент Разговоры ничего не стоят. Код тоже Проверки физических лиц: с кого начнет ФНС Топ-10 бесплатных нейросетей для создания видео в 2026 году Первые слои кода: как наши решения сегодня определяют архитектуру ИИ на десятилетия Разработка нового статического анализатора: PVS-Studio JavaScript Поиск уязвимостей ПО: базовый минимум или роскошный максимум Почему оценка персонала не работает как инструмент управления Как мы разработали ИИ-ассистента и сократили рутину продуктовой команды на 50% Как я ушел из найма, нажарил косточек и продал на маркетплейсах на 168 млн в год Когда 1С:ERP уже внедрена, а нормального производственного плана всё ещё нет Как я сделал Claude мультимодальным, подключив к нему Qwen Omni Как приглашение на вакансию мечты превращается в атаку Infrastructure as Code: философия и лучшие практики IaC Тестируем Yandex Code Assistant на задаче, в которой нужно хранить секреты nxs-universal-chart v3.0: новое поколение универсального Helm-чарта Callback Injection: Техника, которая отправила Microsoft Defender в глухой нокаут «Все идеи на стол»: митап как способ вывести проект из тупика Сегодня я узнал нечто новое о GPU благодаря багу в своей игре Как заставить LLM ̶ ̶г̶а̶л̶л̶ю̶ ̶ эволюционировать Карта событий как фундамент аналитики: практический кейс для E-commerce Что выбрать для AI: x86, ARM или RISC-V? Дайджест железа за март Роль соматических мутаций в развитии аутоиммунных заболеваний: путь к избирательной терапии Mythos от Anthropic — тревожный сигнал для всех, а не только для банков Guardrails для LLM на Java: как приручить промпт‑инъекции и токсичные ответы Green-VLA: как мы собрали VLA-модель для реального антропоморфного робота и не потеряли обобщение Финансовая гонка вооружений: почему умные люди добровольно в ней участвуют Эра ИИ-агентов наступила: выбираем лучшего цифрового сотрудника # Практический опыт внедрения WinCC Redundancy на производственном предприятии Сделал MVP за 3 дня, а потом неделю прикручивал оплату. Оно того стоило? Физика против Маска: почему Starship V3 может оказаться ещё одной катастрофой Нефть Венесуэлы: крупнейшие запасы в мире, но не крупнейшая нефтяная держава JPA 4. Переосмысление Hibernate Почему зеркальная фотокамера Nikon D5 десятилетней давности идеально подошла для миссии «Артемида-2» Проект «Уровень-Спутник» или как мы сделали платформу для гидрологов «Замедлиться, чтобы ускориться»: почему ИИ повышает цену ошибок в требованиях и архитектуре Как с нуля поднять трафик IT-компании на 1657% при бюджете 55 тыс. и выжить Pixel-perfect Downsampling — идеальная отрисовка 50 миллионов точек без потерь
Pico 4: установка и откат версии PICO Connect
suroviy001 · 2026-06-14 · via Все публикации подряд на Хабре

Разрабатываю VR-игру на Unity с использованием SteamVR Plugin, и в ней реализовано отслеживание кистей рук без контроллеров. Решил протестировать эту механику в PCVR-режиме на своём PICO 4 и сразу упёрся в проблему: стандартная актуальная версия PICO Connect эту функцию не поддерживает.

На форуме PICO нашёлся пост с конкретной рабочей связкой версий: PICO Connect 10.4.55 для ПК и Connect 10.4.5 для шлема.

Проблема в том, что версия на ПК ставится без проблем обычным установщиком, а вот версию в шлеме просто так не поставить, особенно если там уже стоит более новая. Пришлось разбираться с ADB, откатом обновлений и чисткой драйверов в SteamVR, чтобы всё это в итоге заработало. Подробная инструкция, как повторить этот процесс у себя - ниже!

1. Общая схема

Для работы отслеживания кистей в PCVR используются две части PICO Connect:

  • На компьютере: PICO Connect для Windows

  • В шлеме: Android-приложение Connect

Для режима передачи костей кистей применяется связка:

  • ПК: PICO Connect 10.4.55

  • Шлем: Connect 10.4.5

Приложение в шлеме имеет системный пакет:

com.picovr.picostreamassistant

Версия на компьютере устанавливается обычным .exe-файлом. Версия в шлеме устанавливается через ADB.

2. Подготовка ADB

2.1. Установка Platform-Tools

Скачать Android SDK Platform-Tools для Windows и распаковать архив, например, в папку:

C:\Tools\platform-tools

Проверить наличие файла:

C:\Tools\platform-tools\adb.exe

2.2. Подготовка APK

Создать папку:

C:\Temp

Скопировать нужный APK-файл в эту папку и переименовать его:

C:\Temp\PICOConnect-beta.apk

2.3. Включение отладки на шлеме

В настройках PICO 4 включить режим разработчика и параметр:

Отладка по USB
USB debugging

Подключить шлем к компьютеру кабелем USB-C.

При появлении запроса в шлеме разрешить отладку для подключённого компьютера. Рекомендуется отметить вариант постоянного разрешения.

3. Подготовка командной строки

Открыть командную строку:

Win + R
→ cmd

Задать переменные:

set "ADB=C:\Tools\platform-tools\adb.exe"
set "PKG=com.picovr.picostreamassistant"
set "APK=C:\Temp\PICOConnect-beta.apk"
set "VRPATHREG=E:\steam\steamapps\common\SteamVR\bin\win64\vrpathreg.exe"

Проверить подключение шлема:

"%ADB%" devices

Нормальный вывод:

List of devices attached
PA821CMGH2100058G    device

Если устройство имеет статус:

unauthorized

нужно подтвердить запрос отладки в шлеме и повторить команду.

4. Проверка установленной версии в шлеме

Перед любыми изменениями проверить путь установленного приложения:

"%ADB%" shell pm path %PKG%

Проверить версии:

"%ADB%" shell dumpsys package %PKG% | findstr /i "versionName versionCode codePath flags"

Обычно вывод содержит две версии.

Пример:

codePath=/data/app/com.picovr.picostreamassistant-.../
versionName=10.6.6
flags=[ SYSTEM ... UPDATED_SYSTEM_APP ]

codePath=/system/app/StreamingAssistant
versionName=9.4.7

Это означает:

  • /data/app/... → активное обновление приложения

  • /system/app/StreamingAssistant → базовая версия, встроенная в прошивку шлема

Базовую системную версию удалять не требуется.

5. Обычная установка новой версии

Если устанавливаемая версия новее текущей, выполнить:

"%ADB%" install -r "%APK%"

Параметр:

-r

позволяет заменить установленную версию приложения.

При успешной установке появится:

Performing Streamed Install
Success

После установки проверить версию:

"%ADB%" shell dumpsys package %PKG% | findstr /i "versionName versionCode codePath"

Для нужной версии ожидается:

versionName=10.4.5
versionCode=1000405001

После установки перезагрузить шлем.

6. Установка более старой версии

Если в шлеме уже установлена более новая версия, обычная установка завершится ошибкой:

INSTALL_FAILED_VERSION_DOWNGRADE

Для проверки можно выполнить:

"%ADB%" install -r -d "%APK%"

Параметр:

-d

разрешает попытку установки более старой версии.

Для обычного релизного приложения этого обычно недостаточно. Если снова появилась ошибка:

INSTALL_FAILED_VERSION_DOWNGRADE

нужно удалить только активное обновление Connect и вернуть встроенную системную версию.

7. Откат обновления Connect

Перед откатом ещё раз проверить текущее состояние:

"%ADB%" shell pm path %PKG%
"%ADB%" shell dumpsys package %PKG% | findstr /i "versionName versionCode codePath flags"

Если активный путь начинается с:

/data/app/

а в выводе присутствует:

UPDATED_SYSTEM_APP

значит поверх встроенной версии установлено обновление.

Удалить активное обновление:

"%ADB%" uninstall %PKG%

После этого обязательно проверить результат:

"%ADB%" shell pm path %PKG%
"%ADB%" shell dumpsys package %PKG% | findstr /i "versionName versionCode codePath flags"

Ожидаемый результат:

package:/system/app/StreamingAssistant/...
versionName=9.4.7

После возврата к встроенной версии установить нужный APK:

"%ADB%" install -r "%APK%"

Проверить установленную версию:

"%ADB%" shell dumpsys package %PKG% | findstr /i "versionName versionCode codePath"

Ожидаемый результат:

versionName=10.4.5
versionCode=1000405001

После установки перезагрузить PICO 4.

8. Команды, которые не следует использовать

Не выполнять команду:

"%ADB%" shell cmd package uninstall-system-updates %PKG%

На некоторых версиях прошивки PICO она работает нестандартно: вместо отката одного приложения пытается удалить обновления сразу у нескольких системных пакетов.

Также не выполнять без необходимости:

"%ADB%" shell pm uninstall --user 0 %PKG%

Эта команда может скрыть системное приложение для текущего пользователя вместо нормального возврата к встроенной версии.

9. Установка версии PICO Connect на компьютере

Версия на компьютере устанавливается без ADB.

Закрыть:

  • SteamVR

  • PICO Connect

  • Unity

  • VR-приложение

Открыть список установленных программ:

Win + R
→ appwiz.cpl

Удалить текущую версию:

PICO Connect

Установить:

PICO Connect 10.4.55

После запуска проверить номер версии в левом нижнем углу окна:

V10.4.55

10. Удаление старого Streaming Assistant с компьютера

Если ранее использовался Streaming Assistant, его нужно удалить полностью. Иначе SteamVR может видеть два драйвера PICO одновременно.

Открыть список программ:

Win + R
→ appwiz.cpl

Удалить:

Streaming Assistant

Проверить остаточную папку:

if exist "C:\Program Files\Streaming Assistant" (echo ПАПКА ОСТАЛАСЬ) else (echo ПАПКА УДАЛЕНА)

Если папка осталась, удалить её:

rmdir /s /q "C:\Program Files\Streaming Assistant"

Если Windows сообщает, что файлы заняты, определить процесс:

tasklist /m driver_pico.dll

Пример вывода:

steam.exe    21968    driver_pico.dll

Завершить найденный процесс:

taskkill /F /PID 21968 /T

Подождать несколько секунд:

timeout /t 3

Проверить повторно:

tasklist /m driver_pico.dll

После освобождения файлов удалить папку:

rmdir /s /q "C:\Program Files\Streaming Assistant"

11. Очистка драйверов PICO в SteamVR

После удаления старого Streaming Assistant проверить список внешних драйверов SteamVR:

"%VRPATHREG%" show

Проблемный вариант:

External Drivers:
        pico : C:/Program Files/PICO Connect/openvr_driver/
        pico : C:/Program Files/Streaming Assistant/driver

При наличии двух драйверов с одинаковым именем pico не следует удалять их по одному. Точечное удаление может затронуть не ту запись.

Удалить все регистрации драйвера pico:

"%VRPATHREG%" removedriverswithname pico

Проверить:

"%VRPATHREG%" show

После очистки блок внешних драйверов должен быть пустым.

Добавить только драйвер актуального PICO Connect:

"%VRPATHREG%" adddriver "C:/Program Files/PICO Connect/openvr_driver/"

Проверить итог:

"%VRPATHREG%" show

Ожидаемый результат:

External Drivers:
        pico : C:/Program Files/PICO Connect/openvr_driver/

12. Итоговая конфигурация

На компьютере:

PICO Connect 10.4.55

В шлеме:

Connect 10.4.5

Пакет в шлеме:

com.picovr.picostreamassistant

В SteamVR зарегистрирован один драйвер:

pico : C:/Program Files/PICO Connect/openvr_driver/

Старая папка отсутствует:

C:\Program Files\Streaming Assistant

После завершения настройки перезагрузить:

  • компьютер

  • PICO 4

Запускать программы в порядке:

  1. PICO Connect

  2. Подключение PICO 4

  3. SteamVR

  4. Проверка отслеживания рук без контроллеров

  5. VR-приложение

Краткая памятка команд

Задать путь к ADB

set "ADB=C:\Tools\platform-tools\adb.exe"

Задать имя пакета Connect

set "PKG=com.picovr.picostreamassistant"

Задать путь к APK

set "APK=C:\Temp\PICOConnect-beta.apk"

Задать путь к vrpathreg

set "VRPATHREG=E:\steam\steamapps\common\SteamVR\bin\win64\vrpathreg.exe"

Проверить подключение шлема

"%ADB%" devices

Проверить путь установленного пакета

"%ADB%" shell pm path %PKG%

Проверить установленную версию

"%ADB%" shell dumpsys package %PKG% | findstr /i "versionName versionCode codePath flags"

Установить APK поверх текущей версии

"%ADB%" install -r "%APK%"

Проверить возможность установки более старой версии

"%ADB%" install -r -d "%APK%"

Удалить активное обновление Connect

"%ADB%" uninstall %PKG%

Проверить возврат к встроенной версии

"%ADB%" shell pm path %PKG%

Повторно установить нужный APK

"%ADB%" install -r "%APK%"

Проверить список драйверов SteamVR

"%VRPATHREG%" show

Удалить все регистрации драйвера pico

"%VRPATHREG%" removedriverswithname pico

Добавить драйвер PICO Connect

"%VRPATHREG%" adddriver "C:/Program Files/PICO Connect/openvr_driver/"

Найти процесс, который блокирует старый драйвер

tasklist /m driver_pico.dll

Завершить найденный процесс

taskkill /F /PID 21968 /T

Удалить остаточную папку Streaming Assistant

rmdir /s /q "C:\Program Files\Streaming Assistant"