cari
RumahJavajavaTutorialBagaimana cara menolak aliran video SDK kamera Hikvision ke projek VUE depan untuk main balik masa nyata?

Hikvision Camera SDK Video Streaming Live Playback dalam Vue Project

Artikel ini memperkenalkan cara menstrim video yang diperolehi oleh SDK kamera Hikvision melalui pelayan media streaming (ZLMediakit) dan akhirnya bermain dalam projek front-end Vue dalam masa nyata. Seluruh proses tidak bergantung pada perkhidmatan video awan, dan kamera disambungkan terus ke komputer tempatan.

Bagaimana untuk menolak aliran video Hikvision Camera SDK ke projek Vue Front-end untuk main balik masa nyata?

Idea Senibina dan Pelaksanaan Sistem

Sistem ini mengamalkan seni bina tiga lapisan:

  1. Kamera dan Backend Hikvision (Spring Boot): Gunakan Hikvision SDK untuk mendapatkan streaming video kamera.
  2. Server Media Streaming (ZLMediakit): Sebagai middleware, ia menerima aliran video yang ditolak oleh backend dan meneruskannya.
  3. Front-END (VUE): Tarik aliran RTSP dari ZLMediakit untuk main balik.

Butiran pelaksanaan backend (Java)

Backend menggunakan kerangka boot Spring, dan logik teras adalah untuk menolak data video hikvision sdk callback ke Zlmediakit. Coretan kod adalah seperti berikut:

 @Service
Kelas HikvisionserviceImpl melaksanakan Hikvisionservice {

    // ... kod lain ...

    @PostConstruct
    pendaftaran tidak sah awam () {
        // Inisialisasi klien HikVisionClient = HikVisionClient baru ();
        client.InitPipedStream ();
        client.clientInit ();
        client.action (); // Mulakan Pratonton dan dapatkan data aliran video melalui panggilan balik}

    // Hikvision SDK Callback Function Class RealDataCallback melaksanakan hcnetsdk.FreaLdataCallback_v30 {
        @Override
        public void invoke (int lrealhandle, int dwdatatype, bytebyReference pbuffer, int dwbufsize, penunjuk penter) {
            jika (dwdatatype == hcnetsdk.net_dvr_streamdata) {
                jika (dwbufsize> 0) {
                    ByteBuffer buffer = pbuffer.getPointer (). GetByTeBuffer (0, dwBufsize);
                    byte [] bytes = byte baru [dwbufsize];
                    buffer.rewind ();
                    buffer.get (bait);
                    executor.Execute (() -> pushTozlMediakit (bytes)); // tolak ke zlmediakit
                }
            }
        }
    }

    kekosongan peribadi pushTozlmediakit (byte [] data) {
        // Tolak data ke zlmediakit, bahagian ini perlu dilaksanakan mengikut API ZLMediakit.
        // Data mungkin perlu dikodkan (mis. H.264) dan dihantar melalui rangkaian ke pelayan ZLMediakit.
        // ... kod tolak zlmediakit ...
    }
}

Kaedah pushToZLMediaKit adalah kunci, dan data video yang diterima perlu ditolak ke alamat pelayan streaming yang ditentukan mengikut dokumen API ZLMediakit. Ini mungkin melibatkan penukaran format data (mis., Menukar data mentah ke aliran H.264).

Butiran pelaksanaan depan (VUE)

Bahagian depan menggunakan rangka kerja VUE dan menggabungkan perpustakaan pemain video yang sesuai seperti flv.js atau hls.js untuk memainkan aliran RTSP yang diperoleh dari Zlmediakit.

 // coretan kod komponen vue<template>
  <video ref="videoPlayer" autoplay></video>
</template>

<script>
import flvjs from 'flv.js'; // 或hls.js

export default {
  mounted() {
    this.initPlayer();
  },
  methods: {
    initPlayer() {
      const rtspUrl = '/api/rtspStream'; // 后端提供的RTSP流地址接口
      fetch(rtspUrl)
        .then(response => response.json())
        .then(data => {
          const flvPlayer = flvjs.createPlayer({
            type: 'flv',
            url: data.rtspUrl // 获取到的RTSP流地址
          });
          flvPlayer.attachMediaElement(this.$refs.videoPlayer);
          flvPlayer.load();
          flvPlayer.play();
        })
        .catch(error => console.error('Error fetching RTSP URL:', error));
    }
  }
};
</script>

/api/rtspStream adalah antara muka backend yang mengembalikan alamat aliran RTSP yang dihasilkan di ZLMediakit.

Suplemen penyelesaian lengkap

Untuk mencapai streaming video yang stabil, backend mungkin perlu menggunakan FFMPEG untuk transcoding untuk menukar output aliran video asal oleh Hikvision SDK ke format yang disokong oleh ZLMediakit (seperti FLV). Backend perlu terus menulis data ke aliran respons, sementara frontend parses dan bermain melalui perpustakaan seperti flv.js. Ini memerlukan pemprosesan yang teliti terhadap penghantaran rangkaian dan penimbunan data untuk memastikan main balik video yang lancar. Pengendalian ralat dan pelepasan sumber juga penting.

Atas ialah kandungan terperinci Bagaimana cara menolak aliran video SDK kamera Hikvision ke projek VUE depan untuk main balik masa nyata?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Prestasi jvm vs bahasa lainPrestasi jvm vs bahasa lainMay 14, 2025 am 12:16 AM

JVM'sperformanceiscompetitiveWithotherRuntimes, menawarkanbalanceofspeed, keselamatan, dan produktiviti.1) jvmusesjitcompilationfordynamiciptimizations.2) c menawarkanSnativePerformanceButLacksjvm'sSafetyFeatures.3) pythonissloweSiSiSiSiSiSiS.3) pythonissloweSiSiSiSiSiS.3) pythonissloweSiSiSiSiSiS.3)

Kemerdekaan Platform Java: Contoh PenggunaanKemerdekaan Platform Java: Contoh PenggunaanMay 14, 2025 am 12:14 AM

Javaachievesplatformindependencethroughthejavavirtualmachine (jvm), membenarkancodetorunonanyplatformwithajvm.1) codeiscompiledintobytecode, notmachine-specificcode.2) byteCodeisinterpretedbybspretedbspretedbspretedbspretedbspretspretedbspretspret

Senibina JVM: menyelam mendalam ke mesin maya JavaSenibina JVM: menyelam mendalam ke mesin maya JavaMay 14, 2025 am 12:12 AM

TheJVMisanabstractcomputingmachinecrucialforrunningJavaprogramsduetoitsplatform-independentarchitecture.Itincludes:1)ClassLoaderforloadingclasses,2)RuntimeDataAreafordatastorage,3)ExecutionEnginewithInterpreter,JITCompiler,andGarbageCollectorforbytec

JVM: Adakah JVM berkaitan dengan OS?JVM: Adakah JVM berkaitan dengan OS?May 14, 2025 am 12:11 AM

Jvmhasacloserelationshipwiththeosasittranslatesjavabytecodeintomachine-specificinstructions, managesmemory, andhandlesgarbagecollection.Thisrelationshipallowsjavatorunonvariousosenvi,

Java: Tulis sekali, jalankan di mana sahaja (wora) - menyelam mendalam ke dalam kemerdekaan platformJava: Tulis sekali, jalankan di mana sahaja (wora) - menyelam mendalam ke dalam kemerdekaan platformMay 14, 2025 am 12:05 AM

Pelaksanaan Java "Tulis Sekali, Jalankan Di Mana -mana" disusun menjadi bytecode dan dijalankan pada mesin maya Java (JVM). 1) Tulis kod Java dan menyusunnya ke dalam bytecode. 2) Bytecode berjalan pada mana -mana platform dengan JVM dipasang. 3) Gunakan antara muka asli Java (JNI) untuk mengendalikan fungsi khusus platform. Walaupun terdapat cabaran seperti konsistensi JVM dan penggunaan perpustakaan khusus platform, Wora sangat meningkatkan kecekapan pembangunan dan fleksibiliti penempatan.

Kemerdekaan Platform Java: Keserasian dengan OS yang berbezaKemerdekaan Platform Java: Keserasian dengan OS yang berbezaMay 13, 2025 am 12:11 AM

Javaachievesplatformindependencethroughthejavavirtualmachine (JVM), membenarkancodetorunondifferentoperatingsystemswithoutmodification.thejvmcompilesjavacodeintoplatform-bebastbytecode, yang mana-mana

Ciri -ciri apa yang menjadikan Java masih kuatCiri -ciri apa yang menjadikan Java masih kuatMay 13, 2025 am 12:05 AM

Javaispowerfulduetoitsplatformindantrectence, orientednature orientednature, richstandardlibrary, perfanksapabilities, andstrongSecurityfeatures.1) PlatformIndendenceAllowsApplicationStorAnanydeviceViceViceViceViceViceViceViceViceViceViceViceViceViceViceViceViceViceViceViceViceViceViceViceViceViceViceViceViceViceViceDeviceViceDeviceViceViceViceViceViceViceViceViceViceViceViceViceViceViceViceViceViceD

Ciri -ciri Java Teratas: Panduan Komprehensif untuk PemajuCiri -ciri Java Teratas: Panduan Komprehensif untuk PemajuMay 13, 2025 am 12:04 AM

Fungsi Java teratas termasuk: 1) pengaturcaraan berorientasikan objek, menyokong polimorfisme, meningkatkan fleksibiliti kod dan pemeliharaan; 2) mekanisme pengendalian pengecualian, meningkatkan keteguhan kod melalui blok percubaan-catch-finally; 3) pengumpulan sampah, memudahkan pengurusan memori; 4) generik, meningkatkan keselamatan jenis; 5) Ekspresi AMBDA dan pengaturcaraan berfungsi untuk menjadikan kod lebih ringkas dan ekspresif; 6) Perpustakaan standard yang kaya, menyediakan struktur data dan algoritma yang dioptimumkan.

See all articles

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

Video Face Swap

Video Face Swap

Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Artikel Panas

Nordhold: Sistem Fusion, dijelaskan
4 minggu yang laluBy尊渡假赌尊渡假赌尊渡假赌
Mandragora: Whispers of the Witch Tree - Cara Membuka Kunci Cangkuk Bergelut
3 minggu yang laluBy尊渡假赌尊渡假赌尊渡假赌

Alat panas

Pelayar Peperiksaan Selamat

Pelayar Peperiksaan Selamat

Pelayar Peperiksaan Selamat ialah persekitaran pelayar selamat untuk mengambil peperiksaan dalam talian dengan selamat. Perisian ini menukar mana-mana komputer menjadi stesen kerja yang selamat. Ia mengawal akses kepada mana-mana utiliti dan menghalang pelajar daripada menggunakan sumber yang tidak dibenarkan.

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

Persekitaran pembangunan bersepadu PHP yang berkuasa

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

DVWA

DVWA

Damn Vulnerable Web App (DVWA) ialah aplikasi web PHP/MySQL yang sangat terdedah. Matlamat utamanya adalah untuk menjadi bantuan bagi profesional keselamatan untuk menguji kemahiran dan alatan mereka dalam persekitaran undang-undang, untuk membantu pembangun web lebih memahami proses mengamankan aplikasi web, dan untuk membantu guru/pelajar mengajar/belajar dalam persekitaran bilik darjah Aplikasi web keselamatan. Matlamat DVWA adalah untuk mempraktikkan beberapa kelemahan web yang paling biasa melalui antara muka yang mudah dan mudah, dengan pelbagai tahap kesukaran. Sila ambil perhatian bahawa perisian ini