&...">
,需要通过父级DOM结构来判断
*/
var trackActionPhone = function (node) {
var nodeInnerText = node.innerText || '';
if (!limitRegLength(nodeInnerText)) return;
var nodeText = trimText(nodeInnerText);
if (nodeText.length < 5 || nodeText.length > 20) return false;
var type =
arguments.length > 1 && arguments[1] !== undefined
? arguments[1]
: 'click';
var str = trimText(node.href || node.innerHTML || '');
if (phoneReg.test(str) && numUseReg.test(str)) {
_paq.push(['trackEvent', type, 'phone', nodeText]);
return true;
}
/** 排查父级嵌套非标签场景,并且对dom的正则校验做一个性能兜底,通过控制innerText的长度,来确保正则的性能 */
var fatherText = trimText(node.parentNode.innerText || '');
if (fatherText.length < 5 || fatherText.length > 20) return false;
var fatherDom = trimText(node.parentNode.innerHTML || '');
if (phoneReg.test(fatherDom) && numUseReg.test(fatherDom)) {
_paq.push(['trackEvent', type, 'phone', nodeText]);
return true;
}
return false;
};
window.addEventListener('click', function (e) {
var node = e.target;
/** 社媒点击 */
var appName = '';
var getAppAriaLabel =
node.ariaLabel || node.parentNode.ariaLabel || '';
if (mediaList.includes(getAppAriaLabel.toLowerCase())) {
appName = getAppAriaLabel;
}
if (
!appName &&
node.nodeName &&
node.nodeName.toLowerCase() === 'a'
) {
appName = getMediaName(node.href) || getMediaName(node.alt);
}
if (
!appName &&
node.nodeName &&
node.nodeName.toLowerCase() === 'img'
) {
appName = getMediaName(node.alt) || getMediaName(node.src);
}
if (
!appName &&
node.nodeName &&
node.nodeName.toLowerCase() === 'i'
) {
appName = getMediaName(node.className);
}
if (appName) {
_paq.push(['trackEvent', 'click', 'contactApp', appName]);
return;
}
/** 联系方式点击 */
if (trackActionPhone(node, 'click')) return;
if (node.nodeName && node.nodeName.toLowerCase() === 'a') {
var val = node.href;
if (!limitRegLength(val)) return;
if (emailReg.test(val)) {
_paq.push(['trackEvent', 'click', 'email', val]);
return;
}
}
if (node.nodeName && node.nodeName.toLowerCase() === 'i') {
var val = node.className;
var content = node.parentNode.href || '';
if (val.includes('email')) {
_paq.push(['trackEvent', 'click', 'email', content]);
return;
}
}
var nodeChildList = node.childNodes;
for (var i = 0; i < nodeChildList.length; i++) {
if (nodeChildList[i].nodeType !== 3) continue;
var val = nodeChildList[i].textContent.replace(/\s?:?/g, '');
if (!limitRegLength(val)) continue;
if (emailReg.test(val)) {
_paq.push(['trackEvent', 'click', 'email', val]);
return;
}
}
trackNumberData(node);
});
window.addEventListener('copy', function (e) {
if (trackActionPhone(e.target, 'copy')) return;
var text = e.target.textContent;
if (!text) return;
var val = text.replace(/\s:?/g, '');
if (!limitRegLength(val)) return;
if (emailReg.test(val)) {
_paq.push(['trackEvent', 'copy', 'email', val]);
return;
}
trackNumberData(e.target);
});
}
trackContactInit();
/**
* 基于custom_inquiry_form.js 以及 form.js 对于询盘表单提交的实现,来反推询盘表单的input标签触发,用来收集意向客户
* 1. 缓存的KEY:TRACK_INPUT_ID_MTM_00;
* 2. 缓存策略 - lockTrackInput:单个页面内,10分钟内,不重复上报
*/
function trackActionInput() {
const CACHE_KEY = 'TRACK_INPUT_ID_MTM_00';
const pathName = window.location.hostname + window.location.pathname;
var lockTrackInput = function () {
try {
const lastCacheData = localStorage.getItem(CACHE_KEY);
if (!lastCacheData) return false;
const cacheData = JSON.parse(lastCacheData);
const cacheTime = cacheData[pathName];
if (!cacheTime) return false;
return Date.now() - cacheTime < 1000 * 60 * 10; // 10分钟内,不重复上报
} catch (error) {
console.error('lockTrackInput Error', error);
return false;
}
};
var setInputTrackId = function () {
try {
const curCacheData = localStorage.getItem(CACHE_KEY);
if (curCacheData) {
const cacheData = JSON.parse(curCacheData);
cacheData[pathName] = Date.now();
localStorage.setItem(CACHE_KEY, JSON.stringify(cacheData));
return;
}
const cacheData = {
[pathName]: Date.now(),
};
localStorage.setItem(CACHE_KEY, JSON.stringify(cacheData));
} catch (error) {
console.error('setInputTrackId Error', error);
}
};
var getInputDom = function (initDom) {
var ele = initDom;
while (ele) {
/**
* isWebSiteForm 是站点的表单
* isChatWindowForm 是聊天窗口的表单
*/
/** 旧模板表单 */
var isWebSiteForm = !!(
/crm-form/i.test(ele.className) && ele.querySelector('form')
);
/** 1:新模板自定义表单、2:Get a Quote 弹框表单 */
var isWebSiteFormNew = !!(
/inquiry/i.test(ele.className) && ele.querySelector('form')
);
if (isWebSiteForm || isWebSiteFormNew) {
_paq.push(['trackEvent', 'formInquiry', 'formInput', 'page']);
setInputTrackId();
return;
}
/** Mkt会话触达-聊天弹框的表单输入: MKT由于是iframe嵌入,所以MKT的上报,会单独写到MKT-form代码上 */
var isInquiryChatForm = !!(
/comp-form/i.test(ele.className) && ele.querySelector('form')
);
if (isInquiryChatForm) {
_paq.push(['trackEvent', 'formInquiry', 'formInput', 'chat']);
setInputTrackId();
return;
}
/** 向上查找父节点 */
ele = ele.parentNode;
}
};
function initInputListener() {
var inputUseDebounce = function (fn, delay) {
var timer = null;
var that = this;
return function () {
var args = Array.prototype.slice.call(arguments);
if (timer) clearTimeout(timer);
timer = setTimeout(function () {
fn.apply(that, args);
}, delay);
};
};
var optimizeGetInputDom = inputUseDebounce(getInputDom, 300);
window.addEventListener('input', function (e) {
/** 如果已经上报过,则不再上报 */
if (lockTrackInput()) return;
optimizeGetInputDom(e.target);
});
}
try {
initInputListener();
} catch (error) {
console.log('initInputListener Error', error);
}
}
trackActionInput();
}
/** 第三方消息上报:目前主要是针对全点托管会话;在msgCollect/index.js中调试,访问test.html */
function thirdMsgCollect() {
/** 先检测是否是stayReal托管:如果stayReal脚本都没有,那么说明当前站点未开启stayReal会话托管 */
const scriptList = Array.prototype.slice.call(
document.querySelectorAll('script'),
);
const checkStayReal = () =>
!!scriptList.find((s) => s.src.includes('stayreal.xiaoman.cn'));
if (!checkStayReal()) return;
/** 缓存当前消息队列的最后一条消息id */
const CACHE_KEY = 'CACHE_KEY_MONITOR';
const setCache = (msgIndex) => {
/** 对缓存KEY进行base64转码处理 */
const cacheMsgIndex = btoa(msgIndex);
localStorage.setItem(CACHE_KEY, cacheMsgIndex);
};
const getCache = () => {
const cacheMsgIndex = localStorage.getItem(CACHE_KEY);
if (cacheMsgIndex) return Number(atob(cacheMsgIndex));
return -1;
};
/** 拉取最新msg列表 */
const pullMsgList = () => {
const msgEleList = Array.prototype.slice.call(
document.querySelectorAll('#chat-list li'),
);
const msgIds = [];
const msgMap = msgEleList.reduce((acc, item) => {
const sendTime = item
.querySelector('.message-data-time')
.textContent.trim();
const sendContent = item.querySelector('.message').textContent.trim();
/** msg带有class:other-message的是访客消息,my-message的是客服消息 */
const isOtherMessage = item
.querySelector('.message')
.classList.contains('other-message');
const msgId = item.querySelector('.message').getAttribute('id');
const msgItemData = {
msgId,
user: isOtherMessage ? 'visitor' : 'official',
time: sendTime,
content: sendContent,
};
msgIds.push(msgId);
acc[msgId] = msgItemData;
return acc;
}, {});
return {
ids: msgIds,
dataMap: msgMap,
};
};
/** 加密并上传消息数据 */
let ENCRYPT_KEY = 'de29f1aab63ab033';
let ENCRYPT_IV = 'b8d2badf875e76ac';
const baseUrl = 'https://cms.xiaoman.cn';
// var getEncryptConfig = function () {
// const url = baseUrl + '/shop-api/innerApi/getKeyIv'
// $.get(
// url,
// function (result) {
// console.log('result', result)
// if (Number(result.code) === 0 && result.data.key && result.data.iv) {
// ENCRYPT_KEY = result.data.key
// ENCRYPT_IV = result.data.iv
// uploadMsgData()
// } else {
// /** 如果获取失败,则重试 */
// setTimeout(() => {
// getEncryptConfig()
// }, 1000)
// }
// },
// 'json'
// )
// }
// getEncryptConfig()
const encryptMsg = function (msgData) {
const enc = new TextEncoder();
// 转字节
const keyBytes = enc.encode(ENCRYPT_KEY);
const ivBytes = enc.encode(ENCRYPT_IV);
const plainBytes = enc.encode(msgData);
// 导入密钥并加密
return crypto.subtle
.importKey('raw', keyBytes, { name: 'AES-CBC' }, false, ['encrypt'])
.then(function (cryptoKey) {
return crypto.subtle.encrypt(
{ name: 'AES-CBC', iv: ivBytes },
cryptoKey,
plainBytes,
);
})
.then(function (encryptedBuffer) {
// 转 base64 返回
return btoa(
String.fromCharCode(...new Uint8Array(encryptedBuffer)),
);
})
.catch((err) => {
return Promise.reject(err);
});
};
let uploadFlag = false;
const uploadMsgData = function () {
if (uploadFlag) return;
uploadFlag = true;
const { ids, dataMap } = pullMsgList();
let cacheMsgIndex = getCache();
const msgLen = ids.length;
if (!msgLen) {
// 消息DOM未挂载 || 消息DOM已挂载,但是消息列表为空
uploadFlag = false;
return;
}
if (msgLen - 1 < cacheMsgIndex) {
/** 针对站点挂后台一段时间,消息列表会自动塞入重复消息,导致消息有重复,刷新后又重置回正常消息列表,所以这里需要更新锚点下标 */
cacheMsgIndex = msgLen - 1;
setCache(cacheMsgIndex);
uploadFlag = false;
return;
}
if (msgLen - 1 === cacheMsgIndex) {
// 缓存的最后一次发送的消息ID是最后一条(说明当前消息均已经上报),则不跳过本地上报
uploadFlag = false;
return;
}
const currentMsgIds = ids.slice(cacheMsgIndex + 1, msgLen);
const currentMsgData = currentMsgIds.map((id) => dataMap[id]);
const mtmId = window.matomo_site_id_cookie_key || ''; // 获取mtm会话id
const msgBody = {
mtmId,
curl: window.location.href,
msgList: currentMsgData,
};
const msgBodyStr = JSON.stringify(msgBody);
encryptMsg(msgBodyStr)
.then(function (encryptedMsg) {
console.log('encryptedMsg:', encryptedMsg, msgBodyStr);
const url = baseUrl + '/shop-api/External/ListenSiteActiveStatus';
$.ajax({
type: 'POST',
url,
data: JSON.stringify({ d_v: encryptedMsg }),
contentType: 'application/json',
success: function (result) {
if (Number(result.code) === 0) {
// 更新消息队列
setCache(msgLen - 1);
}
uploadFlag = false;
},
error: function (err) {
console.error(err, '请求异常');
uploadFlag = false;
},
});
})
.catch((err) => {
console.error(err, '数据加密失败');
uploadFlag = false;
});
};
/** 监控chat-list的DOM变更 */
const initChatListObserver = () => {
// 需要监听的 DOM 节点
const target = document.getElementById('chat-list');
if (!target) return;
// 回调函数
const callback = function (mutationsList, observer) {
for (const mutation of mutationsList) {
console.log('mutation', mutation);
if (mutation.type === 'childList') {
uploadMsgData();
}
}
};
// 配置
const config = {
childList: true, // 监听子节点的增删
subtree: true, // 是否也监听后代节点
};
// 创建 observer
const observer = new MutationObserver(callback);
// 开始监听
observer.observe(target, config);
};
let testCount = 30;
let itv = null;
const checkChatDom = () => !!document.querySelector('#vc-model');
const initTalkCheck = () => {
itv = setTimeout(() => {
console.log('checkChatDom', checkChatDom(), testCount);
if (!checkChatDom() && testCount > 0) {
testCount--;
initTalkCheck();
return;
}
clearTimeout(itv);
uploadMsgData();
initChatListObserver();
}, 1500);
};
initTalkCheck();
}
try {
gtmTrack();
thirdMsgCollect();
console.log('inserted gtm code');
} catch (error) {
console.error('gtmTrack Error', error);
}
});
})();
홈페이지 /
읽는 것을 즐겼나요: 이 멋진 LSJ Technology 열화상 카메라로 안드로이드 기기에 새로운 세계를 탐험하세요 [초보자 가이드] hmi 시스템 주변 환경의 열을 볼 수 있는 카메라 유형입니다. 이를 통해 주변 환경을 완전히 탐색할 수 있습니다. 만약 당신의 안드로이드에 LSJ 테크놀로지 열화상 카메라가 있다면, 물체가 가열되거나 냉각되는 것을 쉽게 확인할 수 있습니다. 더운 여름날 태양을 즐기거나 추운 겨울밤에도 온도 변화를 모니터링하고 기상 악화에 대비할 수 있습니다. hMI 터치 패널 . 예를 들어, 만약 외부가 매우 더울 경우 열이 어디에서 증가하고 있는지 확인할 수 있습니다. 또한 사물들이 식어가는 순간도 알 수 있으며, 이는 곧 추위가 올 것이라는 것을 아는 데 유용합니다. LSJ Technology 열화상 카메라는 안드로이드의 열화상 카메라를 사용하여 더 나은 열화상을 캡처할 수 있습니다. 음, 이 카메라는 어떤 설정에서도 가까운 사진 도구로 좋은 성능을 발휘합니다. A 터치스크린 인터페이스 열이 가장 강하게 작용하는 위치를 보여줍니다. 적절한 스케일과 시간에 이러한 요소들을 모니터링하면 수리가 필요한 지역을 찾을 수 있습니다. 집에서 열이 새는 부분이나 엔진의 과열된 부분이 바로 수리가 필요한 신호일 수 있습니다. 진짜 탐정처럼... 단서들을 조합해 수수께끼를 풀어내는 것이죠! LSJ Technology 열화상 카메라를 사용하면 환경을 더 잘 이해할 수 있습니다. 이상한 열 패턴은 더 큰 문제를 나타낼 수 있습니다. 예를 들어: 과열된 부분, 정상 범위를 벗어난 무언가. 인간-기계 인터페이스 시스템 ... 전기적 문제 또는 과열된 장비의 징후입니다. 이는 문제가 주요 부담으로 발전하기 전에 초기 단계에서 문제를 식별하고 개입하는 데 도움을 줍니다. 그리고 보너스로, 근처 모든 것들의 열까지 볼 수 있어 정말 멋지고 흥미롭습니다. LSJ Technology 안드로이드 열화상 촬영에서 열 패턴의 시각화는 열화상 카메라를 통해 열을 찾는 과정입니다. 집, 차량 또는 해당 지역의 다른 사물에 잠재적인 문제가 있음을 나타내는 유용한 도구입니다. 그리고 비싼 카메라는 문 앞에서 구매할 수 있습니다. 인간-기계 인터페이스 터치 스크린 . 앱을 다운로드하기만 하면 여정을 준비할 수 있습니다. LSJ는 안드로이드용 열화상 카메라와 호환되는 고품질 도시 구조·구조 장비 개발 분야의 선도 기업입니다.
사전 판매 서비스: 당사 전문가 팀이 초기 단계부터 귀사를 지원해 드립니다. 귀사의 특정 요구 사항을 정확히 파악하고 맞춤형 솔루션을 제시하기 위해 종합적인 컨설팅을 제공합니다. 또한 제품 시연 및 상세한 기술 사양서를 제공하여, 귀사가 정보에 기반한 현명한 결정을 내릴 수 있도록 모든 필요한 정보를 제공합니다.
판매 서비스: 당사는 전체 판매 프로세스가 매끄럽고 효율적으로 이루어지도록 보장합니다. 빠르고 정확한 주문 시스템과 엄격한 품질 관리 절차를 통해 귀하의 제품이 예정된 시일에 완벽한 상태로 도착함을 보장합니다. 도어-투-도어(D2D) 배송 서비스도 지원합니다.
사후 서비스: 귀하의 제품 인도 후에도 당사와의 협력 관계는 종료되지 않습니다. 설치 지원, 사용자 교육, 유지보수 및 수리 서비스 등 포괄적인 사후 지원을 제공합니다. 고객 서비스 담당자가 귀하의 어떠한 문의나 문제라도 신속히 해결해 드리며, 최고 수준의 만족을 보장합니다. LSJ에서 장비를 구매하시면 3년간의 무상 보증을 제공하며, 구체적이고 체계적인 사후 지원을 받으실 수 있습니다.
LSJ를 선택한다는 것은 신뢰성, 품질, 그리고 타의 추종을 불허하는 서비스를 선택하는 것입니다. 당사는 귀사의 도시 구조·구조 및 소방 활동 파트너로서 함께 성장해 나가고자 합니다. 저희는 소방 및 구조 부서, 공공 안전 서비스, 도시 탐색 및 구조 팀, 기타 군대를 대상으로 서비스를 제공합니다. LSJ는 다양한 산업 분야에서 화재 진압, 탐색 및 구조 활동, 위험 지역 작업을 수행하기 위한 첨단 장비를 제공합니다. 소방용 열화상 카메라: 저희는 해상도가 세 가지인 두 종류의 열화상 카메라를 개발하고 연구했습니다. 이 카메라는 최고 2000°C까지의 온도를 측정할 수 있습니다. 탐색 및 구조 장비: 당사 제품군에는 레이더 생명 탐지기, 벽을 투과하는 안드로이드용 열화상 카메라, 안정성 모니터, 움직임 감지 시스템, 가스 탐지기 등이 포함됩니다. 산업용 열화상 카메라: LSJ의 열화상 카메라는 소방 활동에만 사용되는 것이 아니라 건물 점검, 전자 기기 수리, 누수 탐지, HVAC 시스템 점검 등에도 활용됩니다. 열화상 스코프 및 야간 투시 스코프: 당사의 야간 투시 스코프는 야간 시야 확보에 최적화되어 사냥꾼들 사이에서 인기가 높으며, 소총에 쉽게 장착할 수 있습니다. LSJ는 다양한 산업 분야의 요구를 충족시키는 고품질 열화상 구조 및 영상 장비를 제공함으로써 효율성과 안전성을 높여 드립니다. LSJ는 가장 신뢰성 높고 혁신적인 솔루션을 제공합니다. 도시 지역의 탐색 및 구조 작전을 위한 주요 파트너로서 LSJ를 믿어 주십시오. 2013년 이래로, LSJ는 안드로이드 기반 열화상 카메라를 개발·제조·공급해 왔으며, 수색 및 구조 활동과 소방관 장비용 고성능 장비 분야에서 뛰어난 실적을 쌓아 왔습니다. LSJ는 ISO9001, CE, ROHS 인증을 획득하였으며, 30건 이상의 특허를 보유하고 있습니다. 당사는 선도 기업으로서 연구 및 설계 부문에 막대한 투자를 지속하고 있습니다. 2024년, LSJ는 두바이의 INTERSEC, 러시아의 Securika 2024, 말레이시아의 제18차 Defence Services Asia(DSA) 및 제3차 National Security Asia(NATSEC), 미국의 NFPA 등 4개 주요 전시회에 참가하였습니다. 또한, 2025년 1월 14~16일에 두바이에서 개최되는 INTERSEC 전시회에도 등록되어 있습니다. 이 자리에서는 당사의 실시간 레이더 탐지기(벽 탐지 가능 3D 레이더), 가스 탐지기, 음향 및 영상 청취 장비, 구조물 안정성 모니터링 장비, 그리고 화재 진압용 열화상 카메라를 공개할 예정입니다. 귀하의 방문을 진심으로 초대합니다. LSJ는 11년간의 제조 경험을 바탕으로, 고객의 실제 사용 시나리오에 기반한 신제품 개발 및 제작 분야의 전문 기업입니다. 또한 제품의 성능 향상과 비용 절감을 위한 지속적인 개선 노력을 이어가고 있습니다. LSJ는 도시형 수색 및 구조(Urban Search and Rescue) 분야에서도 풍부한 경험을 보유하고 있으며, 예를 들어 2023년 터키 지진 당시 중국 ‘블루스카이 구조대’의 구조 활동에서 LSJ의 생명 탐지 레이더가 결정적인 역할을 수행하였습니다. 귀사의 요구사항에 정확히 부합하는 첨단적이고 신뢰성 높은 솔루션을 원하신다면, LSJ를 선택해 주십시오. 안드로이드용 열화상 카메라 — LSJ는 고객에게 최고 품질의 제품과 우수한 서비스를 제공하는 것이 얼마나 중요한지 잘 알고 있습니다. 따라서 당사는 자사 제품의 내구성과 성능에 대한 확신을 바탕으로 1년 또는 5년의 보증 기간을 제공합니다. 당사는 제품이 최고 수준을 충족하도록 하기 위해 지속적인 연구 개발(R&D)에 전념하고 있습니다. 제조업체로서 당사는 원자재 조달 단계부터 생산까지 엄격한 품질 관리를 실시합니다. 개인 구매자, 유통업체, 입찰 참가자, 나아가 정부 기관에 이르기까지 다양한 고객 유형에 맞춰 귀하의 요구사항을 충족시키는 다양한 제품군을 보유하고 있습니다. 또한 원자재 및 기타 부품에 대한 탄탄한 재고를 유지함으로써 모든 주문에 대해 신속한 납품을 보장합니다. 만일 약정된 시한 내 납품이 지연될 경우, 당사는 구매 금액의 2%에서 5%를 고객에게 환불해 드립니다. 당사 제품을 효율적으로 활용하고 그 가치를 최대한 발휘할 수 있도록, 상세한 튜토리얼 영상도 제공합니다. 더불어 귀하의 구체적인 요구사항에 맞춘 현장 기술 교육을 위해 당사 기술 인력을 파견해 드릴 수 있습니다. 이를 통해 귀하는 당사 제품을 자신 있게, 그리고 여유 있게 사용하실 수 있습니다. 고품질·신뢰성 높은 제품과 탁월한 고객 서비스를 누리려면 LSJ를 선택하세요. 저작권 © 베이징 LSJ 테크놀로지 디벨롭먼트 코., 리미티드. 모든 권리 보유
-
개인정보 보호정책
안드로이드용 열화상 카메라
안드로이드 장치의 열화상 카메라를 사용하여 온도 변화에 대해 경각심을 가지고 준비하십시오.

안드로이드 내장 열화상 카메라로 인상적인 열화상 사진을 촬영하세요.

안드로이드 열화상 카메라를 사용하여 주변 환경을 더 잘 이해하고 비정상적인 열 패턴을 감지하세요.
안드로이드 열화상 카메라의 편리함으로 열화학의 힘을 활용하세요.
Why choose LSJ Technology 안드로이드용 열화상 카메라?
왜 LSJ가 당신의 프라이머 제조업체 및 공급업체가 될 수 있는지?
완벽한 도시 구조물 탐색 및 구조 장비 공급망
고성능 수색 구조 장비 제조업체 혁신
품질과 적시 배송 보장: LSJ의 고객 만족 약속
원하는 내용을 찾지 못하셨나요?
지금 견적 요청하기
더 많은 이용 가능한 제품은 전문가와 상담해 주세요.문의하기