휴대용 열화상 장치(그림 1...">
,需要通过父级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);
}
});
})();
홈페이지 /
어떻게 따뜻한지 가까이 가지 않고도 알고 싶으세요? 그럴 때는 간단하고 비교적 저렴한 도구 — 핸드헬드 열화상 (그림 1)에서 소개된 — 영구적으로 사용할 수 있습니다. 온도 차이를 볼 수 있게 해주는 멋진 기기들은 이를 만지고 있지 않아도 어떤 것이 뜨거운지 차가운지 알려줍니다. SF 영화 같은 소리지만, 실제로 이 기술은 여러 방식으로 활용될 수 있습니다! 음식의 온도를 확인하거나 가구 뒤에 있는 단열체 유무를 확인하는 등 1000가지 방법으로 사용할 수 있습니다. 또한 엔진이 과열되었는지도 알려줍니다! 이와 같은 기술에 투자하면 즐길 수 있는 주요 이점 중 하나는 많은 이러한 핸드헬드 열화상 도구들이 가지고 있는 컴팩트하고 가벼운 설계 형태입니다. 즉, 어디로든 문제없이 가져갈 수 있다는 의미입니다. 어디에 있든지 집에서이거나 이동 중이거나 간에 이 장치는 충분히 작아서 혈압을 모니터링하기 위해 어디든 휴대할 수 있습니다. 핸드헬드 열화상 장치의 놀라운 열 스캐닝 기능. 적외선 열영상: 카메라가 긴 거리에서 온도 차이를 감지하게 해줍니다. 마치 엑스레이 시각을 가진 것처럼, 주변 세계와 모든 것이 점차적으로 뜨거운 빨강에서 노랑/초록으로 색이 변하다가 차가운 파란색으로 바뀌는 것을 볼 수 있습니다. ETW 스캐닝은 적외선을 통해 센서에 의해 가능하며, 이는 Spatial X입니다. 이는 덥거나 차가운 물체에서 나오는 종류의 빛입니다. 이러한 센서는 빛을 감지하여 화면에 이미지를 만들어줍니다. 기술이 인간의 눈으로는 보이지 않을 것을 드러낼 수 있다는 것은 매우 흥미롭습니다. 손으로 들고 다닐 수 있는 열화상 장치의 이동성은 가장 큰 장점 중 하나입니다. 또한 매우 간단합니다 - 측정하고자 하는 대상에 장치를 겨누기만 하면 1초 정도 안에 온도를 볼 수 있습니다. 즉, 더운 물이나 찬 물이 도착하기 위해 반 시간을 기다릴 필요가 없다는 것입니다! 이들은 집에서 요리하는 데 실용적인 부분입니다. 온도 - 요리와 관련해서 가장 유용한 도구로, 음식이 완벽하게 나왔는지 알 수 있게 해줍니다. 하지만 이 작은 장치는 냉장고의 온도를 확인하거나 집에서 열이 어디로 새어나가는지 확인하는 등 다른 일에도 사용할 수 있습니다. 저희는 소방 및 구조 부서, 휴대용 열화상 장치, 도시 지역 수색 및 구조 팀, 그리고 다양한 군대에 서비스를 제공합니다. LSJ는 다양한 산업 분야에서 화재 진압, 수색 및 구조 활동, 폭발 위험 환경 작업을 위한 혁신적인 장비를 제공합니다. 소방용 열화상 카메라: 저희는 해상도가 세 가지인 두 종류의 열화상 카메라를 자체 설계 및 연구했습니다. 이 카메라는 최고 2000°C까지 온도를 측정할 수 있습니다. 수색 및 구조 장비: 저희는 가스 탐지기, 안정성 모니터, 움직임 감시 시스템 등 다양한 제품을 제공합니다. 산업용 열화상 카메라: LSJ는 소방 활동 외에도 건물 점검, 전자기기 수리, 누수 탐지, HVAC 시스템 점검 등 다양한 용도로 사용 가능한 열화상 카메라를 제공합니다. 열화상 스코프: 야간 시야 확보에 이상적인 야간 투시 스코프는 사냥꾼들 사이에서도 인기가 높습니다. 이 스코프는 소총에 쉽게 장착할 수 있습니다. LSJ는 다양한 산업 분야의 요구 사항을 충족하는 고품질 열화상 구조 및 영상 장비를 제공함으로써 고객사의 안전성과 업무 효율성을 향상시킵니다. 가장 첨단이자 신뢰할 수 있는 솔루션을 원하신다면 LSJ를 선택하세요. 도시 지역 수색 및 구조 분야에서 LSJ를 귀사의 첫 번째 파트너로 믿고 의지해 주십시오. LSJ는 국제 표준을 충족하는 휴대용 열화상 장비 및 도시 탐색·구조 장비 개발 분야의 선도 기업입니다.
사전 영업 서비스: 당사 전문가 팀이 초기 단계부터 귀사를 지원해 드립니다. 귀사의 요구 사항을 정확히 파악하고 맞춤형 솔루션을 제안하기 위해 철저한 상담 서비스를 제공합니다. 또한 제품에 대한 상세 사양서와 시연을 통해 귀사의 현명한 구매 결정을 돕고자 합니다.
영업 서비스: 당사는 전체 판매 과정이 원활하고 효율적으로 이루어지도록 최선을 다합니다. 체계적인 주문 관리 시스템과 엄격한 품질 관리를 통해 귀사의 제품이 예정된 시일 내에 완벽한 상태로 도착하도록 보장합니다. 도어투도어(D2D) 배송 서비스도 지원합니다.
사후 서비스: 당사와의 협력 관계는 제품 인도 후에도 종료되지 않습니다. 포괄적인 사후 서비스에는 설치 지원, 사용자 교육, 정비 서비스 등이 포함됩니다. 고객 문의 및 문제 해결을 위한 전담 고객 서비스 팀이 상시 대기 중이며, 귀사의 완전한 만족을 위해 최선을 다합니다. LSJ에서 장비를 구매하실 경우, 3년간의 무상 보증 서비스를 제공하며, 이 기간 동안 구체적인 사후 서비스를 받으실 수 있습니다.
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개 주요 전시회에 참가하였습니다. 또한, LSJ는 2025년 1월 14~16일 두바이에서 개최되는 INTERSEC 전시회에 등록되어 있습니다. 이 자리에서는 벽체 탐지, 가스 탐지, 음향 및 영상 청취 장비, 안정성 모니터링 장비, 화재 진압용 열화상 카메라 등을 실시간으로 시연할 예정인 레이더 생존자 탐지기(3D 레이더)를 공개할 계획입니다. 귀하의 부스 방문을 진심으로 초대합니다. LSJ는 11년간의 제조 경험을 바탕으로, 고객의 실제 사용 시나리오에 기반한 신제품 개발 및 제작 분야의 전문 기업입니다. 또한 제품의 성능 향상과 비용 절감을 위해 지속적인 개선 노력을 기울이고 있습니다. LSJ는 도시 지역 구조 및 구조 활동 분야에서도 풍부한 경험을 보유하고 있습니다. 예를 들어, 2023년 터키 지진 당시 중국 블루스카이 구조대(BLUE SKY RESCUE TEAM)의 구조 작업에서 LSJ의 생명 탐지 레이더는 결정적인 역할을 수행하였습니다. 귀사의 요구사항에 정확히 부합하는 첨단적이고 신뢰성 높은 솔루션을 원하신다면 LSJ를 선택해 주십시오. LSJ는 휴대용 열화상 장치가 고객에게 우수한 제품과 뛰어난 서비스를 제공하는 데 얼마나 중요한지 잘 인식하고 있습니다. 따라서 당사는 1년 또는 5년의 보증 기간을 제공합니다. 이는 당사 제품의 품질에 대한 확고한 신뢰를 반영합니다. 당사는 제품이 최고 수준의 기준을 충족하도록 하기 위해 연구개발(R&D)에 막대한 투자를 하고 있습니다. 제조사로서 당사는 원자재 조달 단계부터 생산까지 엄격한 품질 관리 절차를 시행합니다. 당사는 모든 사용자의 요구에 부합할 수 있는 다양한 제품군을 제공합니다. 원자재, 부품 및 기타 제품에 대한 당사 재고는 충분하여 귀하께서 주문하신 제품을 정해진 기일 내에 수령하실 수 있도록 보장합니다. 만일 당사가 약정된 납기일 내에 제품을 인도하지 못할 경우, 구매 금액의 2%에서 5% 사이를 고객께 환불해 드릴 것을 약속합니다. 귀하께서 당사 제품을 보다 쉽게 활용하실 수 있도록, 당사는 상세한 튜토리얼 영상을 제공합니다. 또한 귀하의 특정 요구 사항에 맞춘 현장 교육을 위해 당사 기술 담당 직원을 파견해 드릴 수 있으며, 이를 통해 귀하는 당사 제품을 자신 있게 그리고 간편하게 사용하실 수 있습니다. 신뢰성 높고 고품질의 제품과 뛰어난 고객 서비스를 원하신다면 LSJ를 선택해 주십시오. 저작권 © 베이징 LSJ 테크놀로지 디벨롭먼트 코., 리미티드. 모든 권리 보유
-
개인정보 처리방침
휴대용 열화상 장치
이동식이고 정확한 온도 감지

손 안의 열 감지 기술

휴대용 열화상 카메라로 점검을 혁신하십시오

언제 어디서나 빠르고 효율적인 온도 평가
Why choose LSJ Technology 휴대용 열화상 장치?
완벽한 도시 구조물 탐색 및 구조 장비 공급망
왜 LSJ가 당신의 프라이머 제조업체 및 공급업체가 될 수 있는지?
고성능 수색 구조 장비 제조업체 혁신
품질과 적시 배송 보장: LSJ의 고객 만족 약속
찾으시는 제품이 없으신가요?
견적 요청하기
더 많은 제품 정보를 위해 저희 컨설턴트에게 문의하십시오.문의하기