2016-09-15 11 views
0

AFAIK chromecast не поддерживает RTP, но когда я подключаю свой один плюс один к хромоту, я получил следующий журнал, так как это кастинг?Поддерживает ли Chromecast RTP?

09-15 16:07:37.648 815-815/? I/MediaRouterService: Selected global route:Route cast409 (com.google.android.gms/.cast.media.CastRemoteDisplayProviderService:c5d0e5d940851c488853a91b1635cfde) 
09-15 16:07:37.659 255-2209/? W/APM::AudioPolicyManager: releaseOutput() releasing unknown output 320 
09-15 16:07:37.661 815-837/? D/WifiService: acquireWifiLockLocked: WifiLock{CastMediaRouteProvider type=1 [email protected]} 
09-15 16:07:37.661 815-2665/? E/native: do suspend false 
09-15 16:07:37.661 815-1554/? I/WifiDisplayController: Stopping Wifi display scan. 
09-15 16:07:37.662 2694-2694/? I/wpa_supplicant: P2P-FIND-STOPPED 
09-15 16:07:37.663 815-815/? I/MediaRouterService: Connecting to global route: Route cast409 (com.google.android.gms/.cast.media.CastRemoteDisplayProviderService:c5d0e5d940851c488853a91b1635cfde) 
09-15 16:07:37.664 3028-3028/? D/ChimeraResource: Successfully parsed resource with package name: com.google.android.gms and resource name drawable/ic_notification_cast_connecting 
09-15 16:07:37.669 255-2211/? D/audio_hw_primary: out_set_parameters: enter: usecase(4: audio-ull-playback) kvpairs: routing=2 
09-15 16:07:37.679 255-2211/? D/audio_hw_primary: start_output_stream: enter: stream(0xb5fb6fc0)usecase(4: audio-ull-playback) devices(0x2) 
09-15 16:07:37.679 255-2211/? D/audio_hw_primary: start_output_stream: enter: usecase(4: audio-ull-playback) devices(0x2) 
09-15 16:07:37.679 255-2211/? E/audio_hw_primary: voice_extn_compress_voip_is_active: COMPRESS_VOIP_ENABLED is not defined 
09-15 16:07:37.679 255-2211/? E/msm8974_platform: voice_extn_compress_voip_is_active: COMPRESS_VOIP_ENABLED is not defined 
09-15 16:07:37.680 255-2211/? D/audio_hw_primary: select_devices: out_snd_device(2: speaker) in_snd_device(0:) 
09-15 16:07:37.680 255-2211/? W/msm8974_platform: Codec backend bitwidth 16, samplerate 48000 
09-15 16:07:37.680 255-2211/? D/hardware_info: hw_info_append_hw_type : device_name = speaker 
09-15 16:07:37.680 255-2211/? I/msm8974_platform: platform_send_audio_calibration: sending audio calibration for snd_device(2) acdb_id(15) 
09-15 16:07:37.680 255-2211/? D/ACDB-LOADER: ACDB -> send_audio_cal, acdb_id = 15, path = 0 
09-15 16:07:37.680 255-2211/? D/ACDB-LOADER: ACDB -> send_adm_topology 
09-15 16:07:37.680 255-2211/? D/ACDB-LOADER: ACDB -> ACDB_CMD_GET_AUDPROC_COMMON_TOPOLOGY_ID 
09-15 16:07:37.680 255-2211/? D/ACDB-LOADER: ACDB -> send_asm_topology 
09-15 16:07:37.680 255-2211/? D/ACDB-LOADER: ACDB -> ACDB_CMD_GET_AUDPROC_STREAM_TOPOLOGY_ID 
09-15 16:07:37.680 255-2211/? D/ACDB-LOADER: ACDB -> send_audtable 
09-15 16:07:37.680 255-2211/? D/ACDB-LOADER: ACDB -> ACDB_CMD_GET_AUDPROC_COMMON_TABLE 
09-15 16:07:37.680 255-2211/? D/ACDB-LOADER: ACDB -> AUDIO_SET_AUDPROC_CAL 
09-15 16:07:37.680 255-2211/? D/ACDB-LOADER: ACDB -> send_audvoltable 
09-15 16:07:37.680 255-2211/? D/ACDB-LOADER: ACDB -> ACDB_CMD_GET_AUDPROC_GAIN_DEP_STEP_TABLE 


              [ 09-15 16:07:37.680 255: 2211 D/   ] 
              Failed to fetch the lookup information of the device 0000000F 
09-15 16:07:37.680 255-2211/? E/ACDB-LOADER: Error: ACDB AudProc vol returned = -19 
09-15 16:07:37.680 255-2211/? D/ACDB-LOADER: ACDB -> AUDIO_SET_AUDPROC_VOL_CAL 
09-15 16:07:37.680 255-2211/? D/ACDB-LOADER: ACDB -> send_afe_cal 
09-15 16:07:37.680 255-2211/? D/ACDB-LOADER: ACDB -> ACDB_CMD_GET_AFE_COMMON_TABLE 


              [ 09-15 16:07:37.680 255: 2211 D/   ] 
              Failed to fetch the lookup information of the device 0000000F 
09-15 16:07:37.680 255-2211/? E/ACDB-LOADER: Error: ACDB AFE returned = -19 
09-15 16:07:37.680 255-2211/? D/ACDB-LOADER: ACDB -> AUDIO_SET_AFE_CAL 
09-15 16:07:37.686 255-2211/? D/audio_hw_primary: select_devices: done 
09-15 16:07:37.837 3028-13759/? I/CastDeviceController: [controller-0006 MRP] calling Listener.onConnected(true) 
09-15 16:07:37.845 3028-13759/? I/CastDeviceController: [controller-0006 MRP] launchApplicationInternal. id=674A0243, options=LaunchOptions(relaunchIfRunning=true, language=en-US) 
09-15 16:07:37.845 4374-4518/? D/DeviceConnectionService: client connected with version: 9452000 
09-15 16:07:38.216 3028-4268/? I/CastMediaRouteProvider: CastDeviceController.Listener.onApplicationConnected: appId=674A0243, sessionId=729D062D-A72C-4D5A-92FA-84CAEE580C8F 
09-15 16:07:38.219 3028-3028/? I/MirroringControlChannel: [instance-6] offer string; {"udpPort":2346,"supportedStreams":[{"index":0,"type":"audio_source","codecName":"aac","rtpProfile":"cast","rtpPayloadType":127,"ssrc":1,"storeTime":100,"targetDelay":100,"bitRate":128000,"sampleRate":48000,"timeBase":"1\/48000","channels":2,"rtpExtensions":["adaptive_playout_delay"],"receiverRtcpEventLog":true,"aesKey":"33ef675ea7ce18414c584ecdcfc4b442","aesIvMask":"216e2d585125e768cb6ede391a7b21f8","errorRecoveryMode":"castv2"},{"index":1,"type":"video_source","codecName":"h264","rtpProfile":"cast","rtpPayloadType":96,"ssrc":11,"storeTime":100,"targetDelay":100,"maxFrameRate":"60000\/1001","timeBase":"1\/90000","maxBitRate":6000000,"profile":"main","level":"4","resolutions":[{"height":720,"width":1280}],"rtpExtensions":["adaptive_playout_delay"],"receiverRtcpEventLog":true,"aesKey":"33ef675ea7ce18414c584ecdcfc4b442","aesIvMask":"216e2d585125e768cb6ede391a7b21f8","errorRecoveryMode":"castv2","intraRefreshEnable":false}]} 
09-15 16:07:38.454 3028-3028/? W/CastRouteController: [instance-6] createSourceOrSink, flags = 0x80000000 
09-15 16:07:38.455 3028-27897/? I/JGCastService: enable TDLS on source 
09-15 16:07:38.456 3028-27897/? I/GCastSource: config = ' 
09-15 16:07:38.457 3028-27897/? I/GCastSource: { 
09-15 16:07:38.457 3028-27897/? I/GCastSource: "extraData": { 
09-15 16:07:38.457 3028-27897/? I/GCastSource:  "maxBitrate": 6000, 
09-15 16:07:38.457 3028-27897/? I/GCastSource:  "maxFramerate": "60000\/1001", 
09-15 16:07:38.457 3028-27897/? I/GCastSource:  "minLatency": 100, 
09-15 16:07:38.457 3028-27897/? I/GCastSource:  "receiverProductName": "Chromecast", 
09-15 16:07:38.457 3028-27897/? I/GCastSource:  "receiverVersion": "5", 
09-15 16:07:38.457 3028-27897/? I/GCastSource:  "resolution": "1280x720", 
09-15 16:07:38.457 3028-27897/? I/GCastSource:  "senderBuild": "MHC19Q", 
09-15 16:07:38.457 3028-27897/? I/GCastSource:  "senderGmsCoreVersion": 9452000, 
09-15 16:07:38.457 3028-27897/? I/GCastSource:  "senderModel": "A0001", 
09-15 16:07:38.457 3028-27897/? I/GCastSource:  "senderPlatform": "Android", 
09-15 16:07:38.457 3028-27897/? I/GCastSource:  "senderVersion": "6.0.1" 
09-15 16:07:38.457 3028-27897/? I/GCastSource:  }, 
09-15 16:07:38.457 3028-27897/? I/GCastSource: "maxTargetDelay": 500, 
09-15 16:07:38.457 3028-27897/? I/GCastSource: "remoteFriendlyName": "cast409", 
09-15 16:07:38.457 3028-27897/? I/GCastSource: "sendFormats": [ 
09-15 16:07:38.457 3028-27897/? I/GCastSource:  { 
09-15 16:07:38.457 3028-27897/? I/GCastSource:   "aes-iv-mask": [redacted], 
09-15 16:07:38.457 3028-27897/? I/GCastSource:   "aes-key": [redacted], 
09-15 16:07:38.458 3028-27897/? I/GCastSource:   "bit_rate": 128000, 
09-15 16:07:38.458 3028-27897/? I/GCastSource:   "channels": 2, 
09-15 16:07:38.458 3028-27897/? I/GCastSource:   "codec_name": "aac_ld_adts", 
09-15 16:07:38.458 3028-27897/? I/GCastSource:   "index": 0, 
09-15 16:07:38.458 3028-27897/? I/GCastSource:   "receiver_events": true, 
09-15 16:07:38.458 3028-27897/? I/GCastSource:   "remote_rtp_port": 49794, 
09-15 16:07:38.458 3028-27897/? I/GCastSource:   "remote_ssrc": 2, 
09-15 16:07:38.458 3028-27897/? I/GCastSource:   "rtp_extensions": [ 
09-15 16:07:38.458 3028-27897/? I/GCastSource:    "adaptive_playout_delay" 
09-15 16:07:38.458 3028-27897/? I/GCastSource:   ], 
09-15 16:07:38.458 3028-27897/? I/GCastSource:   "rtp_payload_type": 127, 
09-15 16:07:38.458 3028-27897/? I/GCastSource:   "rtp_port": 2346, 
09-15 16:07:38.458 3028-27897/? I/GCastSource:   "rtp_profile": "cast", 
09-15 16:07:38.458 3028-27897/? I/GCastSource:   "sample_rate": 48000, 
09-15 16:07:38.458 3028-27897/? I/GCastSource:   "ssrc": 1, 
09-15 16:07:38.458 3028-27897/? I/GCastSource:   "store_time": 100, 
09-15 16:07:38.458 3028-27897/? I/GCastSource:   "time_base": 48000, 
09-15 16:07:38.458 3028-27897/? I/GCastSource:   "type": "audio_source" 
09-15 16:07:38.458 3028-27897/? I/GCastSource:  }, 
09-15 16:07:38.458 3028-27897/? I/GCastSource:  { 
09-15 16:07:38.458 3028-27897/? I/GCastSource:   "aes-iv-mask": [redacted], 
09-15 16:07:38.458 3028-27897/? I/GCastSource:   "aes-key": [redacted], 
09-15 16:07:38.458 3028-27897/? I/GCastSource:   "codec_name": "h264", 
09-15 16:07:38.458 3028-27897/? I/GCastSource:   "error_recovery_mode": "castv2", 
09-15 16:07:38.458 3028-27897/? I/GCastSource:   "index": 1, 
09-15 16:07:38.458 3028-27897/? I/GCastSource:   "key_frame_refresh_interval": 60, 
09-15 16:07:38.458 3028-27897/? I/GCastSource:   "max_bit_rate": 6000000, 
09-15 16:07:38.458 3028-27897/? I/GCastSource:   "max_frame_rate": "60000\/1001", 
09-15 16:07:38.458 3028-27897/? I/GCastSource:   "receiver_events": true, 
09-15 16:07:38.458 3028-27897/? I/GCastSource:   "remote_rtp_port": 49794, 
09-15 16:07:38.458 3028-27897/? I/GCastSource:   "remote_ssrc": 12, 
09-15 16:07:38.458 3028-27897/? I/GCastSource:   "resolutions": [ 
09-15 16:07:38.458 3028-27897/? I/GCastSource:    { 
09-15 16:07:38.458 3028-27897/? I/GCastSource:    "height": 720, 
09-15 16:07:38.458 3028-27897/? I/GCastSource:    "width": 1280 
09-15 16:07:38.458 3028-27897/? I/GCastSource:    } 
09-15 16:07:38.458 3028-27897/? I/GCastSource:   ], 
09-15 16:07:38.458 3028-27897/? I/GCastSource:   "rtp_extensions": [ 
09-15 16:07:38.458 3028-27897/? I/GCastSource:    "adaptive_playout_delay" 
09-15 16:07:38.458 3028-27897/? I/GCastSource:   ], 
09-15 16:07:38.458 3028-27897/? I/GCastSource:   "rtp_payload_type": 96, 
09-15 16:07:38.458 3028-27897/? I/GCastSource:   "rtp_port": 2346, 
09-15 16:07:38.458 3028-27897/? I/GCastSource:   "rtp_profile": "cast", 
09-15 16:07:38.458 3028-27897/? I/GCastSource:   "ssrc": 11, 
09-15 16:07:38.458 3028-27897/? I/GCastSource:   "store_time": 100, 
09-15 16:07:38.458 3028-27897/? I/GCastSource:   "time_base": 90000, 
09-15 16:07:38.458 3028-27897/? I/GCastSource:   "type": "video_source", 
09-15 16:07:38.458 3028-27897/? I/GCastSource:   "use_intra_macroblock_cyclic_mode": false 
09-15 16:07:38.458 3028-27897/? I/GCastSource:  } 
09-15 16:07:38.458 3028-27897/? I/GCastSource:  ] 
09-15 16:07:38.458 3028-27897/? I/GCastSource: } 
09-15 16:07:38.458 3028-27897/? I/GCastSource: ' 
09-15 16:07:38.458 3028-27897/? I/GCastSource: Connecting to receiver: cast409 
09-15 16:07:38.458 3028-27897/? I/GCastSource: increasing video delay to 100 ms, max unacked 6 
09-15 16:07:38.459 3028-27897/? I/GCastSource: encrypting video. 
09-15 16:07:38.459 3028-27897/? I/GCastSource: Using ADTS 
09-15 16:07:38.459 3028-27897/? I/GCastSource: increasing audio delay to 100 ms, max unacked 16 
09-15 16:07:38.459 3028-27897/? I/GCastSource: encrypting audio. 
09-15 16:07:38.459 3028-27897/? I/GCastSource: connecting RTP from 0.0.0.0:2346 to 192.168.1.6:49794 
09-15 16:07:38.459 3028-27897/? I/NetworkSession: socket 134 listening to 0.0.0.0:2346 
09-15 16:07:38.460 2694-2694/? I/wpa_supplicant: TDLS: Failed to send message (action_code=10) 
09-15 16:07:38.461 2694-2694/? I/wpa_supplicant: TDLS: Creating peer entry for 6c:ad:f8:8b:d0:26 
09-15 16:07:38.463 3028-27897/? I/Converter: initEncoder, mOutputFormat - AMessage(what = 0x00000000) = { 
               string error_recovery_mode = "castv2" 
               int32_t use_intra_macroblock_cyclic_mode = 0 
               string mime = "video/avc" 
               int32_t key_frame_refresh_interval = 60 
               int32_t width = 1280 
               int32_t height = 720 
               int32_t max-bitrate = 6000000 
               float max-fps-to-encoder = 59.940060 
               int32_t bitrate = 3000000 
               int32_t store-metadata-in-buffers = 1 
               int32_t color-format = 2130708361 
               int64_t repeat-previous-frame-after = 70000 
               int64_t max-pts-gap-to-encoder = 33333 
              } 
09-15 16:07:38.466 3028-27901/? I/OMXClient: Using client-side OMX mux. 
09-15 16:07:38.470 3028-27897/? I/Converter: using video bitrate of 3000000 bps 
09-15 16:07:38.470 3028-27897/? I/Converter: Optmized for quality/video - not using IntraRefreshCyclic 
09-15 16:07:38.471 255-12601/? E/OMXNodeInstance: getParameter(55:qcom.encoder.avc, ParamConsumerUsageBits(0x6f800004)) ERROR: UnsupportedIndex(0x8000101a) 
09-15 16:07:38.472 255-2219/? W/OMXNodeInstance: [55:qcom.encoder.avc] component does not support metadata mode; using fallback 
09-15 16:07:38.472 3028-27901/? E/ACodec: [OMX.qcom.video.encoder.avc] storeMetaDataInBuffers (output) failed w/ err -1010 
09-15 16:07:38.472 3028-27901/? W/ACodec: do not know color format 0x7fa30c04 = 2141391876 
09-15 16:07:38.472 3028-27901/? W/ACodec: do not know color format 0x7f000789 = 2130708361 
09-15 16:07:38.474 3028-27901/? I/FFMPEGSoftCodec: Decoder will be in frame by frame mode 
09-15 16:07:38.477 3028-27901/? I/ACodec: setupVideoEncoder succeeded 
09-15 16:07:38.478 3028-27901/? W/ACodec: do not know color format 0x7f000789 = 2130708361 
09-15 16:07:38.482 255-2219/? E/OMXNodeInstance: getParameter(55:qcom.encoder.avc, ParamConsumerUsageBits(0x6f800004)) ERROR: UnsupportedIndex(0x8000101a) 
09-15 16:07:38.494 255-255/? D/r_submix: adev_open_input_stream(addr=0) 
09-15 16:07:38.495 255-255/? D/r_submix: Non-NULL shut down sink when opening input stream, releasing, refcount=4 
09-15 16:07:38.495 255-255/? D/r_submix: submix_audio_device_release_pipe_l(idx=9) addr=0 
09-15 16:07:38.495 255-255/? D/r_submix: submix_audio_device_create_pipe_l(addr=0, idx=9) 
09-15 16:07:38.495 255-255/? D/r_submix: now using address 0 for route 9 
09-15 16:07:38.495 255-27909/? I/AudioFlinger: AudioFlinger's thread 0xad940000 ready to run 
09-15 16:07:38.495 255-27909/? I/r_submix: in_standby() 
09-15 16:07:38.496 255-27909/? I/r_submix: in_standby() 
09-15 16:07:38.498 3028-27897/? I/Converter: initEncoder, mOutputFormat - AMessage(what = 0x00000000) = { 
               string mime = "audio/mp4a-latm" 
               int32_t sample-rate = 48000 
               int32_t channel-count = 2 
               int32_t bitrate = 128000 
               int32_t max-input-size = 7680 
              } 
09-15 16:07:38.499 3028-27910/? I/OMXClient: Using client-side OMX mux. 
09-15 16:07:38.579 3028-27897/? I/Converter: using audio bitrate of 128000 bps 
09-15 16:07:38.583 255-12601/? I/AudioFlinger: openOutput(), module 12 Device 8000, SamplingRate 48000, Format 0x000001, Channels 3, flags 0 
09-15 16:07:38.583 255-12601/? D/r_submix: adev_open_output_stream(address=0) 
09-15 16:07:38.583 255-12601/? D/r_submix: submix_audio_device_create_pipe_l(addr=0, idx=9) 
09-15 16:07:38.583 255-12601/? D/r_submix: now using address 0 for route 9 
09-15 16:07:38.583 255-12601/? I/AudioFlinger: AudioStreamOut::open(), mHalFormatIsLinearPcm = 1 
09-15 16:07:38.583 255-12601/? I/AudioFlinger: HAL output buffer size 1024 frames, normal sink buffer size 1024 frames 
09-15 16:07:38.584 255-27918/? I/AudioFlinger: AudioFlinger's thread 0xadb40000 ready to run 
09-15 16:07:38.585 255-27918/? I/r_submix: out_standby() 
09-15 16:07:38.587 255-12601/? I/AudioFlinger: HAL output buffer size 1024 frames, normal sink buffer size 1024 frames 
09-15 16:07:38.588 255-27919/? I/AudioFlinger: AudioFlinger's thread 0xadbc0000 ready to run 
09-15 16:07:38.597 255-2208/? D/audio_hw_primary: adev_set_parameters: enter: 0=;connect=32768 
09-15 16:07:38.597 255-2208/? E/voice: voice_extn_compress_voip_set_parameters: COMPRESS_VOIP_ENABLED is not defined 
09-15 16:07:38.597 255-2208/? E/bt_a2dp_hw: adev_set_parameters: ERROR: set param called even when stream out is null 
09-15 16:07:38.599 815-4743/? I/DisplayManagerService: Display device added: DisplayDeviceInfo{"cast409": uniqueId="virtual:com.google.android.gms,10018,cast409,0", 1280 x 720, modeId 7, defaultModeId 7, supportedModes [{id=7, width=1280, height=720, fps=60.0}], colorTransformId 0, defaultColorTransformId 0, supportedColorTransforms [], density 213, 213.0 x 213.0 dpi, appVsyncOff 0, presDeadline 16666666, touch NONE, rotation 0, type VIRTUAL, state ON, owner com.google.android.gms (uid 10018), FLAG_SECURE, FLAG_PRESENTATION} 
09-15 16:07:38.606 815-3564/? D/WifiService: acquireWifiLockLocked: WifiLock{CastMirroringProvider type=1 [email protected]} 
09-15 16:07:38.607 3028-3028/? D/CastMirroringProvider: No Notifier 
09-15 16:07:38.607 815-2665/? E/native: do suspend false 
09-15 16:07:38.607 815-3560/? D/WifiService: acquireWifiLockLocked: WifiLock{CastRemoteDisplayProvider type=1 [email protected]} 
09-15 16:07:38.607 815-2665/? E/native: do suspend false 
09-15 16:07:38.608 3028-3028/? D/ChimeraResource: Successfully parsed resource with package name: com.google.android.gms and resource name drawable/ic_notification_cast_on 
09-15 16:07:38.608 815-815/? I/MediaRouterService: Connected to global route: Route cast409 (com.google.android.gms/.cast.media.CastRemoteDisplayProviderService:c5d0e5d940851c488853a91b1635cfde) 
09-15 16:07:38.625 245-245/? I/SurfaceFlinger: EGL information: 
09-15 16:07:38.625 245-245/? I/SurfaceFlinger: vendor : Android 
09-15 16:07:38.625 245-245/? I/SurfaceFlinger: version : 1.4 Android META-EGL 
09-15 16:07:38.625 245-245/? I/SurfaceFlinger: extensions: EGL_KHR_get_all_proc_addresses EGL_ANDROID_presentation_time EGL_KHR_swap_buffers_with_damage EGL_KHR_image EGL_KHR_image_base EGL_KHR_lock_surface EGL_KHR_gl_texture_2D_image EGL_KHR_gl_texture_3D_image EGL_KHR_gl_texture_cubemap_image EGL_KHR_gl_renderbuffer_image EGL_KHR_fence_sync EGL_KHR_create_context EGL_EXT_create_context_robustness EGL_ANDROID_image_native_buffer EGL_KHR_wait_sync EGL_ANDROID_recordable EGL_KHR_partial_update 
09-15 16:07:38.625 245-245/? I/SurfaceFlinger: Client API: OpenGL_ES 
09-15 16:07:38.625 245-245/? I/SurfaceFlinger: EGLSurface: 8-8-8-8, config=0x5 
09-15 16:07:38.643 3028-27897/? I/GCastBase: updating NTP offset, accuracy +/- 2931 us 

Update

Что касается Али Naddaf ответа моего беспокойства, что я думал так же, но при записи видео с помощью mediacodec и Muxer апи, его атом Moov не написан в начале файла, поэтому он не воспроизводится до тех пор, пока запись не будет завершена (т. е. не может быть передана потоком), а затем как встроенное приложение одновременно создает и передает потоки, также если вы проверяете журналы, они в значительной степени упоминают ключевое слово RTP, что это такое?

Я задал этот вопрос для создания файла, используя мультиплексор раньше, но ответ не удовлетворителен BTW вот предыдущая ссылка вопроса

Android Mediamuxer moov atom

Также попытался презентация API дема, но он разбился https://github.com/googlecast/CastRemoteDisplay-android

EDIT для них Презентационная демонстрация не работает, демонстрация не будет работать с CastMediaControlIntent.DEFAULT_MEDIA_RECEIVER_APPLICATION_ID

вам необходимо создать APP-идентификатор от https://cast.google.com/publish

ответ

-2

Chromecast не поддерживает RTP.

Вы можете использовать API-интерфейсы RemoteDiaplay, как показывает журнал, который в основном «зеркалирует» представление из вашего приложения в хрометре, но в этом сценарии, с точки зрения хромографа, он в основном воспроизводит фильм (что ваш телефон имеет закодированы и собраны вместе с назначенным представлением и передаются в хромист). Опять же, chromecast не поддерживает RTP изначально

+0

Это не совсем ответит: «Как это делается?» –

+0

@AliNaddaf Я думал так же, но когда вы записываете видео с помощью mediacodec и мультиплеера api, его атом moov не записывается в начале файла, поэтому он не воспроизводится, пока запись не будет закончена (т. Е. Не может быть передана потоком), а затем как встроенное приложение создает и передает в одно и то же время, также если вы проверяете журналы, они в значительной степени упоминают ключевое слово RTP, что это такое? – ingsaurabh

+0

@AliNaddaf Tried Presentation demo работает, но как я могу использовать экран устройства, используя любые входы? – ingsaurabh