를 개발했습니다...">
,需要通过父级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는 현재 제공 가능한 최고 수준의 제품들을 개발했습니다 고해상도 열화상 카메라 이 카메라는 인간의 눈으로는 감지할 수 없는 너무 뜨겁거나 너무 차가운 빛 영역에서도 이미지를 기록할 수 있습니다. 고해상도 열화상 카메라의 능력에 대해 더 알아보려면 계속 읽어보세요! 고해상도 열화상 카메라는 우리가 보이지 않는 것을 볼 수 있게 해주는 마법의 안경과 같다. 이러한 카메라는 물체에서 방출되는 열을 감지하고 이를 화면에서 볼 수 있는 영상으로 변환함으로써 작동한다. 이를 통해 건물의 균열이나 전기 장비의 과열 지점처럼 우리 눈만으로는 관찰할 수 없는 것들을 확인할 수 있다. 예전에는 고해상도 열화상 카메라가 없었기 때문에, 사람들이 너무 뜨겁거나 너무 차가워서 육안으로 확인할 수 없는 상황을 파악하려면 추측할 수밖에 없었습니다. 이제 LSJ Technology의 고해상도 열화상 카메라 덕분에 이전보다 훨씬 더 세부적인 정보를 볼 수 있게 되었습니다. 이는 우리 주변 세계를 바라보는 완전히 새로운 시각을 제공함으로써 이미징 분야에 혁명을 일으키고 있습니다. 고해상도 열화상 카메라를 적용하면 수많은 이점이 있습니다. 고해상도 열화상 카메라 그 중 가장 큰 장점 중 하나는 어둠 속에서도 볼 수 있다는 것입니다. 이는 이미지를 생성하는 데 빛이 필요하지 않기 때문이며, 대신 열을 이용하기 때문입니다. 따라서 어두운 곳이나 가방 바닥에서 무언가를 찾을 때 매우 유용합니다. 또한 고해상도 열화상 기술은 비침습적인 특징을 보여줍니다. 이를 통해 손상을 일으키지 않고 결함을 발견할 수 있습니다. 예를 들어, 벽을 부수지 않고도 파이프의 누수를 감지할 수 있습니다. 이렇게 하면 비용이 많이 드는 수리를 피할 수 있습니다. 고해상도 열화상 기술이 이제 여러분의 손끝에 닿아 있습니다. LSJ Technology의 고화질 열화상 카메라를 통해 이전에는 볼 수 없었던 것들을 볼 수 있게 되었습니다. 우리는 동물들의 열 분포 패턴을 확인하고, 어두운 곳에서 잃어버린 반려동물을 추적하며, 추운 날씨에 우리가 내쉬는 숨결까지 관찰할 수 있습니다. 가능성은 무한합니다! 고해상도 열화상 카메라 기능 우리 제품의 고해상도 열화상 카메라 초고해상도 열화상 카메라는 마치 초능력이 있는 눈과 같아서 우리가 사물을 완전히 새로운 시각으로 볼 수 있도록 도와줍니다. 이러한 카메라는 우리의 시야를 풍부하게 하여, 그렇지 않았다면 보이지 않았을 것을 명확히 드러냅니다. 또한 문제를 쉽게 그리고 신속하게 찾아내는 데 도움을 주어 궁극적으로 수리 비용과 시간을 절약할 수 있습니다. 고해상도 열화상 기술을 통해 아직 발견되지 않은 수많은 새로운 세계가 우리를 기다리고 있습니다. 고해상도 열화상 카메라 전문 기업인 당사는 고객에게 고품질 제품과 우수한 서비스를 제공하는 것이 얼마나 중요한지 잘 알고 있습니다. 따라서 당사는 1년 또는 5년의 보증 기간을 제공합니다. 이는 당사가 자사 제품의 내구성과 품질에 대한 확신을 반영한 것입니다. 당사는 제품이 최고 수준을 유지할 수 있도록 지속적인 연구개발(R&D)에 헌신하고 있습니다. 제조업체로서 당사는 원자재 조달 단계부터 최종 제품 완성까지 엄격한 품질 관리를 실시합니다. 개인 구매자이든, 유통업체이든, 입찰 참가자이든, 심지어 정부 기관이든, 귀하의 요구 사항을 충족시킬 수 있는 다양한 제품 라인업을 보유하고 있습니다. 또한 당사는 주문에 대한 신속한 납기를 보장하기 위해 원자재 및 기타 부품에 대한 대규모 재고를 확보하고 있습니다. 당사가 지정된 납기일 내에 상품을 인도하지 못할 경우, 구매 금액의 2%에서 5%를 환불해 드립니다. 당사는 제품을 쉽게 활용하실 수 있도록 상세한 사용 설명 영상 자료를 제공합니다. 또한 귀하의 구체적인 요구 사항에 맞춘 현장 교육을 위해 당사 기술 인력을 파견해 드릴 수 있으며, 이를 통해 귀하는 당사 제품을 자신 있게, 여유 있게 운영하실 수 있습니다. 고품질·고신뢰성 제품과 탁월한 고객 서비스를 원하신다면 LSJ를 선택해 주십시오. 2013년 이래, LSJ는 고해상도 열화상 카메라 및 구조 장비, 소방 장비의 개발, 제조 및 공급을 전문으로 해오고 있습니다. LSJ는 ISO9001, CE, ROHS, MSDS 인증을 획득하였으며, 30건 이상의 특허를 취득하였습니다. 선도 기업으로서, LSJ는 디자인 및 연구 부서에 막대한 투자를 지속적으로 실시하고 있습니다. LSJ는 2024년에 INTERSEC, Securika, 말레이시아에서 개최된 제18차 Defence Services Asia 및 제3차 National Security Asia, 미국의 NFPA 등 네 차례의 주요 국제 전시회에 참가하였습니다. 2025년에는 1월 14일부터 16일까지 두바이에서 개최되는 INTERSEC 2025에 참가할 예정입니다. 이번 전시회에서는 LSJ의 열화상 소방 카메라 외에도 음향·영상 감시 장치, 가스 탐지 3D 레이더 등 다양한 제품을 선보일 예정입니다. 귀사 관계자분들의 부스 방문을 진심으로 초대합니다. 11년간의 제조 경험을 바탕으로, LSJ는 고객의 실제 사용 환경에 맞춰 신제품을 재설계하고 제조하며, 기능을 지속적으로 개선하고 제품 비용을 절감하는 데 주력하고 있습니다. 또한 LSJ는 도시 탐색 및 구조(Urban Search and Rescue, USAR) 분야에서도 풍부한 실적을 보유하고 있습니다. 2023년 터키 지진 당시, LSJ의 레이더 생명 탐지기는 중국 ‘블루스카이 구조대(Blue Sky Rescue Team)’의 구조 활동에 결정적인 역할을 하였습니다. 귀사의 요구사항에 정확히 부합하는 최신 기술을 제공받기 위해 LSJ를 선택해 주십시오. LSJ는 최고 수준의 국제 기준을 충족하는 고품질 도시 탐색 및 구조 장비를 제작하는 전문 기업입니다.
사전 판매 서비스:
저희는 고객 여러분을 처음부터 지원해 드립니다. 귀하의 니즈를 정확히 파악하고 맞춤형 솔루션을 제공하기 위해 종합적인 컨설팅 서비스를 제공합니다. 또한 제품 시연과 상세한 기술 사양서를 함께 제공하여, 귀하가 현명한 결정을 내리는 데 필요한 모든 정보를 확보하실 수 있도록 돕습니다.
판매 서비스:
판매 과정에서 저희는 고해상도 열화상 카메라와 실용적인 사용 경험을 보장합니다. 자동화된 주문 시스템과 엄격한 품질 관리를 통해 귀하의 제품이 예정된 시일에 완벽한 상태로 도착하도록 보장합니다. 도어투도어(Door-to-Door) 배송도 지원합니다.
사후 서비스:
귀하께서 제품을 수령하신 후에도 LSJ와의 협력 관계는 끝나지 않습니다. 광범위한 사후 서비스에는 설치 지원, 사용자 교육, 정비 서비스가 포함됩니다. 고객 문의 및 불편 사항은 언제든지 고객 서비스 부서에서 신속히 해결해 드리며, 귀하의 전적인 만족을 약속합니다. LSJ에서 장비를 구매하시면 3년간의 품질 보증을 제공하며, 구체적인 사후 서비스도 받으실 수 있습니다.
LSJ를 선택한다는 것은 신뢰, 품질, 그리고 차별화된 지원을 선택하는 것입니다. LSJ는 도시 탐색 및 구조 분야뿐 아니라 소방 분야에서도 귀하의 신뢰할 수 있는 파트너가 되기를 기대합니다. 저희는 고해상도 열화상 카메라 부서를 비롯하여 공공안전 서비스 및 도시 탐색·구조 팀(Urban Search and Rescue Teams)에 대한 서비스를 제공합니다. LSJ는 다양한 분야에서 탐색·구조, 소방, 폭발성 대기 환경 작업을 위한 첨단 장비를 제공합니다.
소방용 열화상 카메라: 당사 팀은 해상도가 256×192, 384×288, 640×512인 세 가지 옵션을 갖춘 두 종류의 열화상 카메라를 개발하고 테스트했습니다. 이 카메라는 최대 2000°C까지 온도를 측정할 수 있습니다.
탐색·구조 장비: 당사는 가스 탐지기, 구조 안정성 모니터링 장치, 이동 감지 시스템 등 여러 제품을 제공합니다.
산업용 열화상 카메라: LSJ의 열화상 카메라는 소방 활동에만 국한되지 않으며, 건물 점검, 전자기기 수리, 누수 탐지, HVAC(난방·환기·공조) 시스템 점검 등에도 활용됩니다.
열화상 조준경(Thermal Scopes): 당사의 야간 투시 광학 장치는 야간 시야 확보에 이상적이며, 사냥꾼들 사이에서도 인기가 높습니다. 이 장치는 소총에 쉽게 장착할 수 있습니다.
LSJ는 다양한 산업 분야의 요구사항을 충족시키기 위해 고품질 열화상 영상 장비 및 구조 장비를 제공하는 데 전념하고 있으며, 모든 산업 분야의 안전성과 효율성을 향상시키고자 합니다. LSJ는 가장 안전하고 현대적인 솔루션을 제공합니다.
도시 탐색·구조 분야에서 귀사의 주요 파트너로서 LSJ를 믿어 주십시오. 저작권 © 베이징 LSJ 테크놀로지 디벨롭먼트 코., 리미티드. 모든 권리 보유
-
개인정보 처리방침
고해상도 열화상 카메라
고해상도 열화상 카메라가 이미징을 혁신하는 방법

고해상도 열화상 카메라의 장점

고해상도 열화상 이미징을 통해 세상 탐험하기

고해상도 열화상 카메라로 시야 향상시키기
Why choose LSJ Technology 고해상도 열화상 카메라?
품질과 적시 배송 보장: LSJ의 고객 만족 약속
고성능 수색 구조 장비 제조업체 혁신
왜 LSJ가 당신의 프라이머 제조업체 및 공급업체가 될 수 있는지?
완벽한 도시 구조물 탐색 및 구조 장비 공급망
찾으시는 제품이 없으신가요?
견적 요청하기
더 많은 제품 정보를 위해 저희 컨설턴트에게 문의하십시오.문의하기