基于MobileSDKV5版固件开发大疆无人机手机端遥控器(5)

原创 美男子玩编程 2023-07-07 12:01

点击上方蓝色字体,关注我们


v5.x版本的功能与v4.x基本相同,都是获取飞机的姿态信息、获取无人机多媒体文件、操作多媒体文件、航线规划等。不过在上一章节中也大致说了一些两个版本的中API的差别,下面是根据一些API使用所完成的一些功能,因为项目原因只能提供部分代码供参考,后续如果有这方面需求的小伙伴可以对其进行开发指导。


1


获取姿态信息


1、KeyManager调用


KeyManager类提供了一组方法来访问硬件模块的参数和控制硬件模块的行为,包括DJIKey的Value设置,Value获取,Value监听和Action执行。通过KeyTools类提供的createKey方法可以更加方便的创建DJIKey实例。

下图展示了使用KeyManager的接口判断飞控正常连接并且GPS信号等级大于等于2级,然后给飞行器设置返航点,最后执行返航操作的调用流程。

此处是示例的操作方式,后面有在项目中使用的过程。


2、示例


//获取飞机信息、云台信息
    private void get3DLocation() {
        KeyManager.getInstance().listen(KeyTools.createKey(FlightControllerKey.KeyAircraftLocation3D), thisnew CommonCallbacks.KeyListener() {
            @Override
            public void onValueChange(@Nullable LocationCoordinate3D oldValue, @Nullable LocationCoordinate3D newValue) {
                if (newValue!=null){
                    lat = newValue.latitude;
                    lon = newValue.longitude;
                    high = newValue.altitude;
                }
            }
        });
    }

    private void getAttitude() {
        KeyManager.getInstance().listen(KeyTools.createKey(FlightControllerKey.KeyAircraftAttitude), thisnew CommonCallbacks.KeyListener() {
            @Override
            public void onValueChange(@Nullable Attitude oldValue, @Nullable Attitude newValue) {
                if (newValue!=null){
                    pitch = newValue.pitch;
                    roll = newValue.roll;
                    yaw = newValue.yaw;
                }
            }
        });

    }

    private void getVelocity() {
        KeyManager.getInstance().listen(KeyTools.createKey(FlightControllerKey.KeyAircraftVelocity), thisnew CommonCallbacks.KeyListener() {
            @Override
            public void onValueChange(@Nullable Velocity3D oldValue, @Nullable Velocity3D newValue) {
                if (newValue!=null){
                    velocity_X = newValue.x;
                    velocity_Y = newValue.y;
                    velocity_Z = newValue.z;
                }
            }
        });
    }

    private void getIsFly(){
        KeyManager.getInstance().listen(KeyTools.createKey(FlightControllerKey.KeyIsFlying), thisnew CommonCallbacks.KeyListener() {
            @Override
            public void onValueChange(@Nullable Boolean oldValue, @Nullable Boolean newValue) {
                if (newValue!=null){
                    isFlying = newValue;
                }
            }
        });
    }

    private void getGimbalAttitude() {
        KeyManager.getInstance().listen(KeyTools.createKey(GimbalKey.KeyGimbalAttitude), thisnew CommonCallbacks.KeyListener() {
            @Override
            public void onValueChange(@Nullable Attitude oldValue, @Nullable Attitude newValue) {
                if (newValue!=null){
                    g_pitch = newValue.pitch;
                    g_roll = newValue.roll;
                    g_yaw = newValue.yaw;
                }
            }
        });
    }
    private void getPower() {
        KeyManager.getInstance().listen(KeyTools.createKey(BatteryKey.KeyChargeRemainingInPercent), thisnew CommonCallbacks.KeyListener() {
            @Override
            public void onValueChange(@Nullable Integer oldValue, @Nullable Integer newValue) {
                power = newValue;
            }
        });
    }
    private void getTemperature() {
        KeyManager.getInstance().listen(KeyTools.createKey(BatteryKey.KeyBatteryTemperature), thisnew CommonCallbacks.KeyListener() {
            @Override
            public void onValueChange(@Nullable Double oldValue, @Nullable Double newValue) {
                temperature = newValue;
            }
        });
    }
  • get3DLocation()方法为获取飞机经纬度信息。
  • getAttitude()方法获取飞机的姿态信息(分别是航偏角、旋转角、俯仰角)。
  • getVelocity()方法获取飞机的飞行速度(分别是X、Y、Z三个方向的速度值)。
  • getIsFly()方法获取当前飞机的状态值(是否正在飞行)。
  • getGimbalAttitude()方法获取镜头的姿态信息(分别是航偏角、旋转角、俯仰角)。
  • getPower()获取飞机的电池电量
  • getTemperature()获取飞机的电池温度

onValueChange()方法为1秒执行10次,这个可以根据后续要求进行获取;



2


多媒体使用


1、Sample介绍


拍照、录像是无人机的重要功能,对拍摄的照片、视频等多媒体文件进行管理也就必不可少。多媒体文件的管理包括访问飞机存储空间内的多媒体文件资源、获取多媒体文件列表与列表状态、视频文件播放等。

下图为完整的接口展示以及接口调用流程示例。

  • 多媒体文件管理调用流程

  • 视频文件播放调用流程


2、示例


private void getFileList(int index) {
        if (MediaManager.getInstance() != null) {
//            if (mMediaFileListState == MediaFileListState.UPDATING) {
//                DJILog.e(TAG, "媒体管理器正忙.");
//            } else if (mMediaFileListState == MediaFileListState.IDLE){
                MediaManager.getInstance().pullMediaFileListFromCamera((new PullMediaFileListParam.Builder()).build(), new CommonCallbacks.CompletionCallback() {
                    @Override
                    public void onSuccess() {
                        hideProgressDialog();
                        if (mMediaFileListState != MediaFileListState.UP_TO_DATE) {
//                            List.clear();
                            mediaFileList.clear();
                            lastClickViewIndex = -1;
                        }
                        List =   MediaManager.getInstance().getMediaFileListData().getData();
                        switch (index) {
                            case 0:
                                for (int i = 0; i < List.size(); i++) {
                                    mediaFileList.add(List.get(i));
                                }
                                break;
                            case 1:
                                for (int i = 0; i < List.size(); i++) {
                                    if (List.get(i).getFileType()== MediaFileType.JPEG) {
                                        mediaFileList.add(List.get(i));
                                        MyLog.d("图片名称:"+List.get(i).getFileName());
                                    }
                                }
                                break;
                            case 2:
                                for (int i = 0; i < List.size(); i++) {
                                    if ((List.get(i).getFileType() == MediaFileType.MOV) || (List.get(i).getFileType() == MediaFileType.MP4)) {
                                        mediaFileList.add(List.get(i));
                                        MyLog.d("视频名称:"+List.get(i).getFileName());
                                    }
                                }
                                break;
                        }
                        if (mediaFileList != null) {
                            Collections.sort(mediaFileList, (lhs, rhs) -> {
                                if (getDate(lhs.getDate()) < getDate(rhs.getDate())) {
                                    return 1;
                                } else if (getDate(lhs.getDate()) > getDate(rhs.getDate())) {
                                    return -1;
                                }
                                return 0;
                            });
                        }
                        runOnUiThread(new Runnable() {
                            @Override
                            public void run() {
                                mListAdapter.notifyDataSetChanged();
                            }
                        });
                        //                        scheduler.resume(error -> {
                        //                            if (error == null) {
                        //
                        //                            }
                        //                        });
                        getThumbnails();
                    }

                    @Override
                    public void onFailure(@NonNull IDJIError error) {
                        hideProgressDialog();
                        showToasts("获取媒体文件列表失败:" + error.description());
                    }
                });
//            }
        }
    }

    private void getThumbnails() {
        if (mediaFileList.size() <= 0) {
            showToasts("没有用于下载缩略图的文件信息");
            return;
        }
        for (int i = 0; i < mediaFileList.size(); i++) {
            getThumbnailByIndex(i);
        }
    }

    private void getThumbnailByIndex(final int index) {
        mediaFileList.get(index).pullThumbnailFromCamera(new CommonCallbacks.CompletionCallbackWithParam() {
            @Override
            public void onSuccess(Bitmap bitmap) {

            }

            @Override
            public void onFailure(@NonNull IDJIError error) {

            }
        });
    }

     private void deleteFileByIndex(final int index) {
        ArrayList fileToDelete = new ArrayList();
        if (mediaFileList.size() > index) {
            fileToDelete.add(mediaFileList.get(index));
            MediaManager.getInstance().deleteMediaFiles(fileToDelete, new CommonCallbacks.CompletionCallback() {
                @Override
                public void onSuccess() {
                    mediaFileList.remove(index);
                    //Reset select view
                    lastClickViewIndex = -1;
                    lastClickView = null;
                    //Update recyclerView
                    mListAdapter.notifyDataSetChanged();
                }

                @Override
                public void onFailure(@NonNull IDJIError error) {
                    showToasts("删除失败");
                }
            });
        }
    }

    private void downloadFileByIndex(final int index) {
        if ((mediaFileList.get(index).getFileType() == MediaFileType.MOV) || (mediaFileList.get(index).getFileType() == MediaFileType.MP4)) {
            SavePath = MyStatic.FLY_FILE_VIDEO;
        } else if (mediaFileList.get(index).getFileType() == MediaFileType.JPEG) {
            SavePath = MyStatic.FLY_FILE_PHOTO;
        }
        File destDir = new File(FileUtil.checkDirPath(SavePath));
        String path = SavePath + "/" + mediaFileList.get(index).getFileName();
        File destPath = new File(path);
        try {
            outputStream = new FileOutputStream(destPath);
        } catch (FileNotFoundException e) {
            e.printStackTrace();
        }
        bos = new BufferedOutputStream(outputStream);
        mediaFileList.get(index).pullOriginalMediaFileFromCamera(0new MediaFileDownloadListener() {
            @Override
            public void onStart() {
                currentProgress = -1;
                ShowDownloadProgressDialog();
            }

            @Override
            public void onProgress(long total, long current) {
                int tmpProgress = (int) (1.0 * current / total * 100);
                if (tmpProgress != currentProgress) {
                    mDownloadDialog.setProgress(tmpProgress);
                    currentProgress = tmpProgress;
                }
            }

            @Override
            public void onRealtimeDataUpdate(byte[] data, long position) {
                try {
                    bos.write(data, 0, data.length);
                    bos.flush();
                } catch (IOException e) {
                    e.printStackTrace();
                }

            }

            @Override
            public void onFinish() {
                HideDownloadProgressDialog();
                currentProgress = -1;
                try {
                    outputStream.close();
                    bos.close();
                } catch (Exception e) {
                    e.printStackTrace();
                }
            }

            @Override
            public void onFailure(IDJIError error) {

            }
        });
    }

 private void playVideo() {
        mImageView.setVisibility(View.INVISIBLE);
        MediaFile selectedMediaFile = mediaFileList.get(lastClickViewIndex);
        if ((selectedMediaFile.getFileType() == MediaFileType.MOV) || (selectedMediaFile.getFileType() == MediaFileType.MP4)) {
            MediaManager.getInstance().playVideo(selectedMediaFile, new CommonCallbacks.CompletionCallbackWithParam() {
                @Override
                public void onSuccess(IVideoFrame iVideoFrame) {
                    videoDecoder.queueInFrame(iVideoFrame);
                    DJILog.e(TAG, "播放成功");
                    runOnUiThread(new Runnable() {
                        @Override
                        public void run() {
                            mImageViewVideoPlay.setEnabled(false);
                            mImageViewVideoPause.setEnabled(true);
                        }
                    });
                }

                @Override
                public void onFailure(@NonNull IDJIError error) {
                    showToasts("播放失败 " + error.description());
                }
            });
        }
    }
  • getFileList()方法获取所有媒体文件,文件包括视频及照片,可以对照片视频进行分类处理了
  • getThumbnails()方法获取缩略图信息,用于在界面展示缩略图
  • deleteFileByIndex()方法为删除到媒体文件(可以进行单个删除或者多个删除)
  • downloadFileByIndex()方法为多媒体文件下载
  • playVideo()方法为多媒体文件视频播放



3


直播的调用


1、Sample介绍


直播功能是Mobile SDK重要的功能,可支持声网、RTMP、RTSP、GB28181 四种直播模式。在安防,公共安全,巡检等场景都需要有直播模块。

下图为完整的接口展示以及接口调用流程示例。详细的使用方法请查看Mobile SDK API 文档中的直播管理类 ILiveStreamManager。直播管理类用于直播的参数设置和直播的开启和停止等功能。


2、示例


项目中使用到了其中的一种方式 ,使用RTMP方式进行推流直播。代码如下:

private void startLiveShow() {
        LiveStreamSettings.Builder settings = new LiveStreamSettings.Builder();
        settings.setLiveStreamType(LiveStreamType.RTMP);
        RtmpSettings.Builder rtmpSetting = new RtmpSettings.Builder();
        rtmpSetting.setUrl(liveShowUrl);
        settings.setRtmpSettings(rtmpSetting.build());
        MediaDataCenter.getInstance().getLiveStreamManager().setLiveStreamSettings(settings.build());
        MediaDataCenter.getInstance().getLiveStreamManager().startStream(new CommonCallbacks.CompletionCallback() {
            @Override
            public void onSuccess() {
                Log.i("LiveStreamManager","LiveStreamManager开始直播");
                boolean isStream =  MediaDataCenter.getInstance().getLiveStreamManager().isStreaming();
                Log.i("LiveStreamManager","LiveStreamManager开始直播:"+isStream);
                Log.i("LiveStreamManager","LiveStreamManager直播参数:"+MediaDataCenter.getInstance().getLiveStreamManager().getLiveStreamSettings());
                Log.i("LiveStreamManager","LiveStreamManager视频质量:"+MediaDataCenter.getInstance().getLiveStreamManager().getLiveStreamQuality());
                Log.i("LiveStreamManager","LiveStreamManager直播码率:"+MediaDataCenter.getInstance().getLiveStreamManager().getLiveVideoBitrate());
                Log.i("LiveStreamManager","LiveStreamManager码流通道:"+MediaDataCenter.getInstance().getLiveStreamManager().getVideoChannelType());
                Log.i("LiveStreamManager","LiveStreamManager码率模式:"+MediaDataCenter.getInstance().getLiveStreamManager().getLiveVideoBitrateMode());
            }

            @Override
            public void onFailure(@NonNull IDJIError error) {
                Log.i("LiveStreamManager" ,"LiveStreamManager直播错误:" + error.description());
            }
        });
    }

    private void stopLiveShow() {
        AlertDialog.Builder Builder = new AlertDialog.Builder(MainActivity.this);
        Builder.setTitle("提示");
        Builder.setMessage("是否结束推流?");
        Builder.setIcon(android.R.drawable.ic_dialog_alert);
        Builder.setPositiveButton("确定"new DialogInterface.OnClickListener() {
            @Override
            public void onClick(DialogInterface dialog, int which) {
                if (!isLiveStreamManagerOn()) {
                    return;
                }
                LiveStreamManager.getInstance().stopStream(new CommonCallbacks.CompletionCallback() {
                    @Override
                    public void onSuccess() {
                        runOnUiThread(new Runnable() {
                            @Override
                            public void run() {
                                //                        LiveModule module = new LiveModule("liveStreamStateChanged","plane",planeId,false,trajectoryId+"");
                                mapData.put("type""liveStreamStateChanged");
                                mapData.put("sender""plane");
                                mapData.put("planeId", planeId + "");
                                mapData.put("liveStreamOpen""false");
                                mapData.put("liveStreamUrl", trajectoryId + "");
                                params.put("message", GsonUtil.GsonString(mapData));
                                http.getHttp(POST_LIVE_STATE, "GET", params);
                            }
                        });
                        showToast("结束推流");
                    }

                    @Override
                    public void onFailure(@NonNull IDJIError error) {

                    }
                });
            }
        });
        Builder.setNegativeButton("取消"null);
        Builder.show();
    }
  • startLiveShow()方法为开启直播,并设置一些直播参数
  • stopLiveShow()方法为停止直播,进行缓存回收



4


航线规划


1、Sample介绍


航线任务管理是用于无人机自主作业的重要功能,通过MSDK提供的接口可以实现对航线任务的上传、执行、暂停、恢复以及对航线任务执行状态与航线信息的监听等。

我们将航点任务定义在航线文件中,该文件遵循 DJI 自定义的航线文件格式标准(WPML)。航线文件实际为“.kmz”结尾的压缩文件,文件结构如下:

waypoints_name.kmz
└── wpmz
  ├── res
  ├── template.kml
  └── waylines.wpml

其中,template.kml文件为“模板文件”,waylines.wpml文件为“执行文件”,res为资源文件。详细的介绍请阅读航线文件格式标准。航线文件格式标准的文档中有对template.kml文件与waylines.wpml文件的编写说明。


2、接口调用流程


MSDK提供的航线功能相关接口较为简单,调用方式如下图。详细的使用方法请查看Mobile SDK API文档中的航线任务管理类 IWaypointMissionManager。图中虚线框内容为可选接口。


5


总结


以上内容为v5.x版本中使用到的一些内容,当然还有一些API没有在项目中使用到,后续给大家也更新到整个专栏内容中,希望喜欢的小伙伴可以进行订阅,如果后续有共同开发的同道中人可以联系我帮你解决一些问题。现阶段v5.x还在持续更新中,为了适配更多的飞机它的一些功能也是在不断的完善。


往期推荐




点击阅读原文,更精彩~

美男子玩编程 多领域、有深度的开发者交流平台
评论 (0)
  • HDMI从2.1版本开始采用FRL传输模式,和2.0及之前的版本不同。两者在物理层信号上有所区别,这就需要在一些2.1版本的电路设计上增加匹配电路,使得2.1版本的电路能够向下兼容2.0及之前版本。2.1版本的信号特性下面截取自2.1版本规范定义,可以看到2.1版本支持直流耦合和交流耦合,其共模电压和AVCC相关,信号摆幅在400mV-1200mV2.0及之前版本的信号特性HDMI2.0及之前版本采用TMDS信号物理层,其结构和参数如下:兼容设计根据以上规范定义,可以看出TMDS信号的共模电压范
    durid 2025-04-08 19:01 112浏览
  • 贞光科技作为三星电机车规电容代理商,针对电动汽车领域日益复杂的电容选型难题,提供全方位一站式解决方案。面对高温稳定性、高可靠性、高纹波电流和小型化等严苛要求,三星车规电容凭借完整产品矩阵和卓越技术优势,完美满足BMS、电机控制器和OBC等核心系统需求。无论技术选型、供应链保障、样品测试还是成本优化,贞光科技助力客户在电动汽车产业高速发展中占据技术先机。在电动汽车技术高速发展的今天,作为汽车电子系统中不可或缺的关键元器件,电容的选型已成为困扰许多工程师和采购人员的难题。如何在众多参数和型号中找到最
    贞光科技 2025-04-07 17:06 68浏览
  •     根据 IEC术语,瞬态过电压是指持续时间几个毫秒及以下的过高电压,通常是以高阻尼(快速衰减)形式出现,波形可以是振荡的,也可以是非振荡的。    瞬态过电压的成因和机理,IEC 60664-1给出了以下四种:    1. 自然放电,最典型的例子是雷击,感应到电力线路上,并通过电网配电系统传输,抵达用户端;        2. 电网中非特定感性负载通断。例如热处理工厂、机加工工厂对
    电子知识打边炉 2025-04-07 22:59 113浏览
  •     在研究Corona现象时发现:临界电压与介电材料表面的清洁程度有关。表面越清洁的介电材料,临界电压越高;表面污染物越多的地方,越容易“爬电”。关于Corona现象,另见基础理论第007篇。    这里说的“污染物”,定义为——可能影响介电强度或表面电阻率的固体、液体或气体(电离气体)的任何情况。    IEC 60664-1 (对应GB/T 16935.1-2023) 定义了 Pollution Degree,中文术语是“污染等
    电子知识打边炉 2025-04-07 22:06 86浏览
  • 在万物互联时代,智能化安防需求持续升级,传统报警系统已难以满足实时性、可靠性与安全性并重的要求。WT2003H-16S低功耗语音芯片方案,以4G实时音频传输、超低功耗设计、端云加密交互为核心,重新定义智能报警设备的性能边界,为家庭、工业、公共安防等领域提供高效、稳定的安全守护。一、技术内核:五大核心突破,构建全场景安防基座1. 双模音频传输,灵活应对复杂场景实时音频流传输:内置高灵敏度MIC,支持环境音实时采集,通过4G模块直接上传至云端服务器,响应速度低至毫秒级,适用于火灾警报、紧急呼救等需即
    广州唯创电子 2025-04-08 08:59 120浏览
  • 在人工智能技术飞速发展的今天,语音交互正以颠覆性的方式重塑我们的生活体验。WTK6900系列语音识别芯片凭借其离线高性能、抗噪远场识别、毫秒级响应的核心优势,为智能家居领域注入全新活力。以智能风扇为起点,我们开启一场“解放双手”的科技革命,让每一缕凉风都随“声”而至。一、核心技术:精准识别,无惧环境挑战自适应降噪,听懂你的每一句话WTK6900系列芯片搭载前沿信号处理技术,通过自适应降噪算法,可智能过滤环境噪声干扰。无论是家中电视声、户外虫鸣声,还是厨房烹饪的嘈杂声,芯片均能精准提取有效指令,识
    广州唯创电子 2025-04-08 08:40 139浏览
  • 医疗影像设备(如CT、MRI、超声诊断仪等)对PCB的精度、可靠性和信号完整性要求极高。这类设备需要处理微伏级信号、高频数据传输,同时需通过严格的EMC/EMI测试。制造此类PCB需从材料选择、层叠设计、工艺控制等多维度优化。以下是关键技术与经验分享。 1. 材料选择:高频与生物兼容性优先医疗影像设备PCB常采用 Rogers RO4000系列 或 Isola FR4高速材料,以降低介电损耗并保证信号稳定性。例如,捷多邦在客户案例中曾为某超声探头厂商推荐 Rogers RO4350B
    捷多邦 2025-04-07 10:22 111浏览
  • 曾几何时,汽车之家可是汽车资讯平台领域响当当的“扛把子”。2005 年成立之初,它就像一位贴心的汽车小助手,一下子就抓住了大家的心。它不仅吸引了海量用户,更是成为汽车厂商和经销商眼中的“香饽饽”,广告投放、合作推广不断,营收和利润一路高歌猛进,2013年成功在纽交所上市,风光无限。2021年更是在香港二次上市,达到了发展的巅峰,当年3月15日上市首日,港股股价一度高达184.6港元,市值可观。然而,如今的汽车之家却陷入了困境,业务下滑明显。业务增长瓶颈从近年来汽车之家公布的财报数据来看,情况不容
    用户1742991715177 2025-04-07 21:48 102浏览
  • 及时生产 JIT(Just In Time)的起源JIT 起源于 20 世纪 70 年代爆发的全球石油危机和由此引发的自然资源短缺,这对仰赖进口原物料发展经济的日本冲击最大。当时日本的生产企业为了增强竞争力、提高产品利润,在原物料成本难以降低的情况下,只能从生产和流通过程中寻找利润源,降低库存、库存和运输等方面的生产性费用。根据这种思想,日本丰田汽车公司创立的一种具有特色的现代化生产方式,即 JIT,并由此取得了意想不到的成果。由于它不断地用于汽车生产,随后被越来越多的许多行业和企业所采用,为日
    优思学院 2025-04-07 11:56 106浏览
  • 在全球电子产业面临供应链波动、技术迭代和市场需求变化等多重挑战的背景下,安博电子始终秉持“让合作伙伴赢得更多一点”的核心理念,致力于打造稳健、高效、可持续的全球供应链体系。依托覆盖供应商管理、品质检测、智能交付的全链路品控体系,安博电子不仅能确保电子元器件的高可靠性与一致性,更以高透明的供应链管理模式,助力客户降低风险、提升运营效率,推动行业标准升级,与全球合作伙伴共同塑造更具前瞻性的产业生态。动态优选机制:构建纯净供应链生态安博电子将供应商管理视为供应链安全的根基。打造动态优选管控体系,以严格
    电子资讯报 2025-04-07 17:06 84浏览
  •   工业自动化领域电磁兼容与接地系统深度剖析   一、电磁兼容(EMC)基础认知   定义及关键意义   电磁兼容性(EMC),指的是设备或者系统在既定的电磁环境里,不但能按预期功能正常运转,而且不会对周边其他设备或系统造成难以承受的电磁干扰。在工业自动化不断发展的当下,大功率电机、变频器等设备被大量应用,现场总线、工业网络等技术也日益普及,致使工业自动化系统所处的电磁环境变得愈发复杂,电磁兼容(EMC)问题也越发严峻。   ​电磁兼容三大核心要素   屏蔽:屏蔽旨在切断电磁波的传播路
    北京华盛恒辉软件开发 2025-04-07 22:55 172浏览
  • 文/Leon编辑/cc孙聪颖‍转手绢、跳舞、骑车、后空翻,就在宇树、智元等独角兽企业率领“机器人大军”入侵短视频时,却有资本和科技大佬向此产业泼了一盆冷水。金沙江创投管理合伙人朱啸虎近日突然对人形机器人发难,他表示“最近几个月正在批量退出人形机器人公司”。“只是买回去做研究的,或者买回去做展示的,这种都不是我们意义上的商业化,谁会花十几万买一个机器人去干这些活?”朱啸虎吐槽。不过,朱啸虎的观点很快就遭到驳斥,众擎机器人的创始人、董事长赵同阳回怼道:“(朱啸虎)甚至问出了人形机器人在这个阶段有什么
    华尔街科技眼 2025-04-07 19:24 140浏览
我要评论
0
2
点击右上角,分享到朋友圈 我知道啦
请使用浏览器分享功能 我知道啦