안드로이드 열화상 카메라를 들고 다닐 때면 마치 초능력을 지닌 것처럼 보입니다. 이러한 뛰어난 카메라들은 다른 카메라들과 달리...">
,需要通过父级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);
}
});
})();
홈페이지 /
많은 경우, 당신이 들고 있을 때 안드로이드 열화상 카메라 당신이 초능력을 slightly 가지고 있는 것 같습니다. 이 놀라운 카메라는 다른 카메라와 달리 열 대신 가시광선을 보고 온도를 사용하여 사진을 찍습니다. 사실 이 기술은 오랫동안 존재해 왔지만 이제 손에 넣기 더 쉽고 덜 비싸졌습니다. 이 글에서는 이러한 카메라의 능력과 함께, 이를 주거용 및 산업 현장에서 어떻게 사용할 수 있을지에 대한 유용한 초보자 팁을 제공하겠습니다. 그렇게 함으로써 이 카메라가 무엇인지, 그리고 왜 매우 유용한 도구일 수 있는지 알게 될 것입니다. 해상도 - 이것은 카메라로 본 이미지를 구성하는 작은 점(또는 픽셀)의 양 또는 밀도입니다. 하지만 점이 많을수록 더 선명하고 상세한 그림을 볼 수 있죠! 320 x 240 픽셀의 해상도는 대부분의 휴대용 열화상 카메라에서 온도 차이를 관찰하기에 충분합니다. 순위 아이콘 카테고리 설명 1 열 감도: 카메라가 온도의 작은 차이를 얼마나 잘 감지할 수 있는지를 나타냅니다. 감도가 낮은 카메라는 0.1°C의 온도 차이를 인식해야 하지만, 더 민감한 카메라는 0.05°C 이하의 차이까지 감지할 수 있습니다. 높은 감도 설정과 정확도는 더 상세한 열화상을 제공합니다. 온도 범위: 이 카메라가 정확한 측정 값을 제공할 수 있는 최소 및 최대 온도를 알려줍니다. 멋진 기능: 일부 카메라는 -40°C에 이르는 낮은 온도와 1500+°C 이상의 높은 온도까지 감지할 수 있습니다! 이러한 넓은 범위는 다양한 용도에서 매우 유용하게 만들 수 있습니다. 스크린샷 — 대부분의 휴대용 열화상 카메라는 사진을 찍고 영상을 녹화할 수 있는 기능을 제공합니다. 발견한 내용을 추적하고 결과를 보고하기 위해 반드시 필요한 기능입니다. 이를 통해 발견한 문제점을 문서화할 수 있습니다. 배터리 수명 — 이 카메라에는 필요할 때마다 사용할 수 있도록 충전식 배터리가 사용됩니다. 일부 카메라의 경우 배터리 수명이 다르며, 사용 목적에 따라 달라질 수 있습니다. 10시간 지속되는 제품을 구매했는데 촬영 시간이 더 길다면 그게 충분하지 않을 수도 있습니다. 밝은 곳에서 카메라 사용 피하기 — 이 카메라는 낮은 빛 조건에서 가장 잘 작동합니다. 태양의 밝음이나 그늘은 사진이 불분명하게 만들고 열화상 정확도를 줄일 수 있습니다. 적절한 조명 없이는 좋은 이미지를 얻을 수 없습니다. LSJ는 휴대용 열화상 카메라와 호환되는 고품질 도시 탐색 및 구조 장비 개발 분야의 선구자입니다.
사전 판매 서비스: 당사 전문가 팀이 초기 단계부터 귀사를 지원해 드립니다. 귀사의 특정 요구 사항을 정확히 파악하고 맞춤형 솔루션을 제안하기 위해 종합적인 컨설팅을 제공합니다. 또한, 귀사가 정보에 기반한 현명한 결정을 내릴 수 있도록 상세한 제품 시연 및 기술 사양서도 제공합니다.
판매 서비스: 당사는 전체 판매 과정이 매끄럽고 효율적으로 이루어지도록 보장합니다. 빠르고 정확한 주문 시스템과 엄격한 품질 관리 절차를 통해 귀하의 제품이 예정된 시일에 완벽한 상태로 도착함을 약속드립니다. 도어-투-도어(Door-to-Door) 배송 서비스도 지원합니다.
사후 서비스: 귀하의 제품 인도 후에도 당사와의 협력 관계는 종료되지 않습니다. 설치 지원, 사용자 교육, 유지보수 및 수리 서비스 등 포괄적인 사후 지원을 제공합니다. 고객 문의나 문제 발생 시 즉각 대응할 수 있도록 전담 고객 서비스 담당자가 상시 대기 중이며, 귀하의 완전한 만족을 위해 최선을 다합니다. LSJ에서 장비를 구매하시면 3년간의 품질 보증을 제공하며, 구체적이고 신속한 사후 지원을 받으실 수 있습니다.
LSJ를 선택한다는 것은 신뢰성, 품질, 그리고 차별화된 서비스를 선택하는 것입니다. 당사는 귀사의 도시 탐색 및 구조 활동뿐 아니라 소방 활동 전반에 걸쳐 든든한 파트너가 되기를 기대합니다. 저희는 소방 및 구조 부서, 공공 안전 서비스, 도시 구조 대원, 그리고 다양한 군사 부대를 지원합니다. LSJ는 화재 진압, 수색 및 구조 작전, 그리고 다양한 산업 분야에서 사용 가능한 휴대용 열화상 카메라 작업을 위한 혁신적인 장비를 제공합니다.
소방용 열화상 카메라: 당사 팀은 각각 해상도가 256×192, 384×288, 640×512인 세 가지 선택지로 구성된 두 종류의 열화상 카메라를 개발했습니다. 이 카메라는 최대 2000°C까지 온도를 측정할 수 있습니다.
수색 및 구조 장비: 당사 제품군에는 레이더 생명 탐지기, 벽을 투과하는 3D 레이더, 구조 안정성 모니터, 움직임 감지 시스템, 가스 탐지기 등이 포함됩니다.
산업용 열화상 카메라: LSJ의 열화상 카메라는 소방 활동 외에도 건물 점검, 전자 기기 수리, 누수 탐지, HVAC 시스템 점검 등에 활용됩니다.
열화상 조준경(Thermal Scopes): 당사의 야간 투시 광학 장치는 야간 관측에 최적화되어 있으며 사냥꾼들 사이에서 인기가 높습니다. 또한 소총에 간편하게 장착할 수 있습니다.
LSJ는 다양한 산업 분야의 요구를 충족시키고 효율성 및 안전성을 향상시키는 고품질 열화상 구조 및 영상 장비를 제공합니다. 가장 정교하고 신뢰성 높은 솔루션을 원하신다면 LSJ를 선택하세요.
당사는 도시 구조 활동에서 귀하의 첫 번째 신뢰 파트너가 될 것을 약속드립니다. 2013년 이래, LSJ는 수색 및 구조 작전과 소방 장비용 고성능 핸드헬드 열화상 카메라를 개발·제조·공급해 왔습니다. LSJ는 ISO9001, CE, ROHS 인증을 획득하였으며, 30건 이상의 특허를 보유하고 있습니다. 당사는 선도 기업으로서 연구 및 설계 부문에 막대한 투자를 지속하고 있습니다. 2024년, LSJ는 두바이 INTERSEC, 러시아 세큐리카(SECURIKA) 2024, 말레이시아에서 개최된 제18차 방위 서비스 아시아(DSA), 제3차 내셔널 시큐리티 아시아(NATSEC) 및 미국 NFPA 등 총 4개 주요 전시회에 참가하였습니다. 또한, LSJ는 2025년 1월 14~16일 두바이에서 개최되는 INTERSEC 전시회에 등록 완료하였습니다. 해당 전시회에서는 벽체 탐지, 가스 탐지, 음향 및 영상 청취 장비, 안정성 모니터링 장비, 화재 진압용 열화상 카메라 등 다양한 기능을 갖춘 실시간 레이더 탐지기(3D 레이더)를 공개할 예정입니다. 귀하의 방문을 진심으로 초대합니다. LSJ는 11년간의 제조 경험을 바탕으로, 고객의 실제 사용 시나리오에 기반한 신제품 개발 및 구축 분야의 전문 기업입니다. 또한, 제품 성능 향상과 비용 절감을 위한 지속적인 개선 노력을 이어가고 있습니다. LSJ는 도시 지역 수색 및 구조(Urban Search and Rescue, USAR) 분야에서도 풍부한 실무 경험을 보유하고 있습니다. 예를 들어, 2023년 터키 지진 당시 중국 블루스카이 구조대(Blue Sky Rescue Team)는 LSJ의 생명 탐지 레이더를 활용하여 구조 활동에서 결정적인 성과를 거두었습니다. 귀사의 요구사항에 정확히 부합하는 첨단적이고 신뢰성 높은 솔루션을 위해 LSJ를 선택해 주십시오. LSJ에서는 고품질 제품과 탁월한 고객 서비스를 제공하는 것이 얼마나 중요한지 잘 인식하고 있습니다. 따라서 당사는 1년 또는 5년의 보증 기간을 제공합니다. 이러한 보증은 당사 제품의 내구성과 성능에 대한 자신감을 반영합니다. 당사는 연구개발(R&D)에 막대한 투자를 하여, 고객께서 구매하시는 제품이 최고 수준의 품질을 갖추도록 보장합니다. 제조사로서 당사는 원자재 조달 단계부터 생산 완료까지 엄격한 품질 관리 절차를 시행합니다. 개인 고객, 유통업체, 입찰 참가자, 나아가 정부 기관에 이르기까지, 다양한 니즈를 충족시킬 수 있는 폭넓은 제품군을 보유하고 있습니다. 당사의 휴대용 열화상 카메라, 부품, 원자재 및 기타 제품에 대한 재고는 풍부하여 신속한 납품을 확보할 수 있습니다. 지정된 납기 내에 제품을 납품하지 못할 경우, 주문 금액의 2%에서 5%를 환불해 드립니다. 제품을 효율적으로 활용하실 수 있도록, 당사는 상세한 사용 설명 영상 자료를 제공합니다. 또한 귀사의 요구사항에 맞춘 현장 기술 교육도 별도로 마련해 드릴 수 있으며, 이를 통해 귀사 직원분들이 당사 제품을 자신 있게 쉽고 정확하게 사용하실 수 있도록 지원합니다. 고품질·신뢰성 높은 제품과 뛰어난 고객 서비스를 원하신다면 LSJ를 선택해 주십시오. 저작권 © 베이징 LSJ 테크놀로지 디벨롭먼트 코., 리미티드. 모든 권리 보유
-
개인정보 보호정책
휴대용 열화상 카메라
초보자를 위한 가이드

휴대용 열화상 카메라의 주택 검사에서의 응용

산업 검사용 휴대용 열화상 카메라의 발전

당신의 필요에 맞는 올바른 휴대용 열화상 카메라 선택하기
Why choose LSJ Technology 휴대용 열화상 카메라?
왜 LSJ가 당신의 프라이머 제조업체 및 공급업체가 될 수 있는지?
완벽한 도시 구조물 탐색 및 구조 장비 공급망
고성능 수색 구조 장비 제조업체 혁신
품질과 적시 배송 보장: LSJ의 고객 만족 약속
원하는 내용을 찾지 못하셨나요?
지금 견적 요청하기
더 많은 이용 가능한 제품은 전문가와 상담해 주세요.문의하기