1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071207220732074207520762077207820792080208120822083208420852086208720882089209020912092209320942095209620972098209921002101210221032104210521062107210821092110211121122113211421152116211721182119212021212122212321242125212621272128212921302131213221332134213521362137213821392140214121422143214421452146214721482149215021512152215321542155215621572158215921602161216221632164216521662167216821692170217121722173217421752176217721782179218021812182218321842185218621872188218921902191219221932194219521962197219821992200220122022203220422052206220722082209221022112212221322142215221622172218221922202221222222232224222522262227222822292230223122322233223422352236223722382239224022412242224322442245224622472248224922502251225222532254225522562257225822592260226122622263226422652266226722682269227022712272227322742275227622772278227922802281228222832284228522862287228822892290229122922293229422952296229722982299230023012302230323042305230623072308230923102311231223132314231523162317231823192320232123222323232423252326232723282329233023312332233323342335233623372338233923402341234223432344234523462347234823492350235123522353235423552356235723582359236023612362236323642365236623672368236923702371237223732374237523762377237823792380238123822383238423852386238723882389239023912392239323942395239623972398239924002401240224032404240524062407240824092410241124122413241424152416241724182419242024212422242324242425242624272428242924302431243224332434243524362437243824392440244124422443244424452446244724482449245024512452245324542455245624572458245924602461246224632464246524662467246824692470247124722473247424752476247724782479248024812482248324842485248624872488248924902491249224932494249524962497249824992500250125022503250425052506250725082509251025112512251325142515251625172518251925202521252225232524252525262527252825292530253125322533253425352536253725382539254025412542254325442545254625472548254925502551255225532554255525562557255825592560256125622563256425652566256725682569257025712572257325742575257625772578257925802581258225832584258525862587258825892590259125922593259425952596259725982599260026012602260326042605260626072608260926102611261226132614261526162617261826192620262126222623262426252626262726282629263026312632263326342635263626372638263926402641264226432644264526462647264826492650265126522653265426552656265726582659266026612662266326642665266626672668266926702671267226732674267526762677267826792680268126822683268426852686268726882689269026912692269326942695269626972698269927002701270227032704270527062707270827092710271127122713271427152716271727182719272027212722272327242725272627272728272927302731273227332734273527362737273827392740274127422743274427452746274727482749275027512752275327542755275627572758275927602761276227632764276527662767276827692770277127722773277427752776277727782779278027812782278327842785278627872788278927902791279227932794279527962797279827992800280128022803280428052806280728082809281028112812281328142815281628172818281928202821282228232824282528262827282828292830283128322833283428352836283728382839284028412842284328442845284628472848284928502851285228532854285528562857285828592860286128622863286428652866286728682869287028712872287328742875287628772878287928802881288228832884288528862887288828892890289128922893289428952896289728982899290029012902290329042905290629072908290929102911291229132914291529162917291829192920292129222923292429252926292729282929293029312932293329342935293629372938293929402941294229432944294529462947294829492950295129522953295429552956295729582959296029612962296329642965296629672968296929702971297229732974297529762977297829792980298129822983298429852986298729882989299029912992299329942995299629972998299930003001300230033004300530063007300830093010301130123013301430153016301730183019302030213022302330243025302630273028302930303031303230333034303530363037303830393040304130423043304430453046304730483049305030513052305330543055305630573058305930603061306230633064306530663067306830693070307130723073307430753076307730783079308030813082308330843085308630873088308930903091309230933094309530963097309830993100310131023103310431053106310731083109311031113112311331143115311631173118311931203121312231233124312531263127312831293130313131323133313431353136313731383139314031413142314331443145314631473148314931503151315231533154315531563157315831593160316131623163316431653166316731683169317031713172317331743175317631773178317931803181318231833184318531863187318831893190319131923193319431953196319731983199320032013202320332043205320632073208320932103211321232133214321532163217321832193220322132223223322432253226322732283229323032313232323332343235323632373238323932403241324232433244324532463247324832493250325132523253325432553256325732583259326032613262326332643265326632673268326932703271327232733274327532763277327832793280328132823283328432853286328732883289329032913292329332943295329632973298329933003301330233033304330533063307330833093310331133123313331433153316331733183319332033213322332333243325332633273328332933303331333233333334333533363337333833393340334133423343334433453346334733483349335033513352335333543355335633573358335933603361336233633364336533663367336833693370337133723373337433753376337733783379338033813382338333843385338633873388338933903391339233933394339533963397339833993400340134023403340434053406340734083409341034113412341334143415341634173418341934203421342234233424342534263427342834293430343134323433343434353436343734383439344034413442344334443445344634473448344934503451345234533454345534563457345834593460346134623463 |
- import Vue from 'vue'
- import Vuex from 'vuex'
- import config from 'common/config.js'
- import reqUtil from 'util/util-js/requstUtil.js'
- import date from 'util/util-js/date.js'
- import cNumber from 'util/util-js/makeNumber.js'
- import BLE from 'util/util-js/BLE.js';
- //快速打击部分
- import o0 from "@/util/util-js/o0.js"
- import o0Project from "@/util/util-js/o0Project.js"
- import o0ProjectRelease from "@/util/util-js/o0ProjectRelease0.1.js"
- import deviceData from "@/util/util-js/devices.js"
- Vue.use(Vuex)
- const store = new Vuex.Store({
- state: {
- // vLog:'',
- //引导层
- bGuidePages: false,
- //是否显示Canvas
- bCanvasShow: true,
- /**
- * 是否需要强制登录
- */
- forcedLogin: false,
- /**
- * 蓝牙实时发送数据的页面的名称
- */
- currentPageName: '',
- hasLogin: false,
- userInfo: null,
- userName: "匿名",
- days: 0,
- remainingDays: 0,
- signature: '',
- avatarUrl: "/static/defaultAvatar.png",
- // 是否是新用户,
- //TODO:登录接口返回的数据来判断
- bNewUser: false,
- //是否是第一次走新手
- bNewGuide: false,
- token: '',
- gender: 0,
- //省市区数据
- city: {
- label: '北京市-北京市-东城区',
- cityCode: "110101",
- //picker 选择器的index数组
- value: [0, 0, 0]
- },
- birthday: date.formatTime(new Date()),
- //默认值
- height: 0,
- weight: 0,
- //最近在玩的列表
- playGames: [],
- //最近在玩的排行游戏列表
- playRankingGames: [],
- //全部的游戏列表
- allGames: [],
- //关注的游戏列表
- favoriteGames: [],
- // 排行榜里面显示的游戏
- rankSelectedGame: null,
- rankInfo: null,
- cityName: "某市",
- /**
- * 默认的运动数据
- * date.addDaysFromNewDate(new Date(),1)
- */
- defaultPlanData: {
- startTime: date.formatDate(new Date()),
- endTime: date.addDaysFromNewDate(new Date(), 6),
- targetWeight: 0, //目标公斤
- calorie: 360, //运动消耗的卡路里,默认300 大卡
- cumulativeCalorie: 0, //累计增重
- sportTime: 40, //运动时间
- /**
- * 本地记录的消耗卡路里数量
- */
- localCalorie: 0,
- /**
- * 显示卡路里,过了12点清空
- */
- showCalorie: 0,
- /**
- * 总和
- */
- allCalorie: 0
- },
- /**
- * 计划的运动数据
- */
- planData: {
- startTime: date.formatDate(new Date()),
- endTime: date.formatDate(new Date()), //date.addDaysFromNewDate(new Date(),1),
- targetWeight: 0, //目标公斤
- cumulativeCalorie: 0, //累计增重
- calorie: 300, //运动消耗的卡路里
- sportTime: 40, //运动时间
- /**
- * 本地记录的消耗卡路里数量
- */
- localCalorie: 0,
- /**
- * 显示卡路里,过了12点清空
- */
- showCalorie: 0,
- /**
- * 总和
- */
- allCalorie: 0
- },
- //记录表盘计划刷新的卡路里
- oldArcbarProCalorie: 0,
- //记录表盘当前的总卡路里
- oldArcbarAllCalorie: 0,
- //当前运动的世时间
- localSportTime: 0,
- //当前运动时间,运动时候记录的时间
- runingTime: 0,
- //蓝牙设备信息列表
- //id 不可变,用于保存到本地区分
- BLEInfoList: deviceData.getDeviceList(),
- //记录的蓝牙设备,保存id, 和对应的蓝牙连接数据
- BLEDeviceList: [],
- //显示的蓝牙设备,取本地数据时候更新
- BLEDeviceShowList: [],
- //选择连接的蓝牙设备
- BLEConnectDevice: null,
- //获取到的服务
- BLEGetServices: null,
- //当前发送给蓝牙的指令,目前是只有蓝牙手柄
- currentInstruction: '',
- instructionState: {
- // bAcc: false, //是否开启加速计状态
- // bGyroscope: false, //是否开启陀螺仪状态
- bOpen: false, //是否开启指令
- bSteps: false, //是否开启步数
- },
- //绑定的设备
- DeviceBindingList: [{
- id: 0,
- cname: "开启手机数据",
- ename: "bindMobilePhoneBandage",
- icon: "/static/devicesIcon/bandage.png",
- mIcon: "/static/devicesIcon/bandage.png",
- bRatio: false,
- usageMode: 'bindPhone',
- describe: '手机情景下使用',
- limitType: 'rebound', //限制回弹版本
- deviceType: 'mySelf', //指的是使用手机本身加速计计算
- deviceName: 'PHONE', //连接硬件名称
- }],
- ConnectBindingDevice: null,
- cIndex: -1,
- //当前是否连接
- bConnection: false,
- /**
- * 通过验证的连接,比如通过mac验证,或者说是首页直连,都设置这个参数,确保已经连上
- */
- bVerifiedConnection: false,
- /**
- * Android 出现不匹配的情况下,判断
- * ios 暂时没有此类问题
- */
- bPhoneMatched: false,
- //最近连接过的设备
- finallyUseDevice: null,
- /**
- * 用户选择好友的信息
- */
- finallySelectFriendInfo: null,
- //phoneNumber
- phoneNumber: '',
- openid: '',
- appleid: '',
- //获取验证码
- bCodeDisabled: false,
- count: 59,
- interval: null,
- //conversion列表
- oldSwiperList: [],
- // 计划任务过期
- bPlanExpired: false,
- // 制定玩计划任务后
- bPlanFinish: false,
- //标准体重,男女根据当前年龄计算
- standardWeight: 0,
- //是否安装了微信
- bInstallWechat: false,
- bHideWeixin: false,
- //导航栏高度。这里统一参数,单位px
- navHeight: 46,
- tabbarHeight: 65,
- systemInfo: null, //系统全部信息
- clientName: '', //但是客户端名字
- system: '', // 系统版本
- platform: '', // 平台
- appName: '',
- version: '1.6.3', //软件版本
- versionCode: '21030101',
- showEndTime: config.endTime, //游戏显示时间字段,后台返回对应此时间之前的数据
- //现在游戏显示在对应的平台
- gamePlatform: {
- 0: 'android',
- 1: 'ios',
- 2: 'all'
- },
- globalAcc: null,
- globalOri: null,
- globalAccData: {
- ax: 0,
- ay: 0,
- az: 0
- },
- globalGyroData: {
- gx: 0,
- gy: 0,
- gz: 0
- },
- globalLastGyroData: {
- gx: 0,
- gy: 0,
- gz: 0
- },
- globalMyAttitude: null,
- /**
- * 当前显示的模式下标,区分总体的显示模块
- * 比如拳击模块体验下,设置 0
- * 跳绳为主的模式体验下,设置 1
- */
- currentModeIndex: 1,
- //蓝牙变量操作
- /**
- * 操作蓝牙设备
- */
- bOpenBluetooth: false,
- /**
- * 是否初始化蓝牙适配器
- */
- bOpenSuccess: false,
- /**
- * 是否监听蓝牙状态变化
- */
- bListenAdapterStateChange: false,
- /**
- * 是否监听寻找新设备事件
- */
- bListenDeviceFound: false,
- // 设备Id
- BLEDeviceId: "",
- // 服务Id
- BLEServiceId: "",
- // 特征值id
- BLENotifyCharacteristicId: "",
- //监听rssi对象
- BLERSSIInterval: null,
- //蓝牙服务timeout
- getBLEDeviceServicesTimeout: null,
- //本地游戏地址
- // http://192.168.0.112:7456/build/index.html
- // http://127.0.0.1:7456/build/index.html
- LocationGameUrl: "http://110.43.54.43/t8/",
- //快速打击对象
- filter: null,
- deviceMs: 1,
- //改进版的沙袋打击对象
- sandbagAlgorithm: null,
- sandbagAlgorithmLastTime: new Date().getTime(),
- /**
- * 蓝牙参数对象
- */
- // 设备Id
- deviceId: "",
- // 服务Id
- serviceId: "",
- notifyCharacteristicId: "",
- writeCharacteristicId: "",
- showToast: false,
- bListenerUpdate: false,
- bListenerJson: false,
- bListenerMac: false,
- bListenerAccArray: false,
- /**
- * 发送16进制时候,返回的刷新数据
- */
- bListenerHexUpdate: false,
- BluetoothAdapter: null,
- //版本状态,用于区分部分特定的环境
- versionCodeState: null,
- //显示蓝牙是否断开连接Modal
- bShowBLEConnectModal: false,
- bGamePlaying: false,
- //跳绳条件下计数
- bRopeKeyOne: 0,
- bRopeKeyTwo: 0,
- //钻石,金币
- cDiamond: 0,
- cGold: 0,
- /**
- * 任务相关
- */
- currentJumpTask: null,
- multiPersonList: [],
- singlePersonList: [],
- /**
- * 校准识别部分
- */
- convertAcc: [{
- type: 'x',
- match: 'ax', //默认匹配一一对应
- direction: 1,
- }, {
- type: 'y',
- match: 'ay',
- direction: -1,
- }, {
- type: 'z',
- match: 'az',
- direction: -1,
- }],
- convertGyro: [{
- type: 'x',
- match: 'gx', //默认匹配一一对应
- direction: 1,
- }, {
- type: 'y',
- match: 'gy',
- direction: 1,
- }, {
- type: 'z',
- match: 'gz',
- direction: 1,
- }],
- /**
- * 签到列表
- */
- signInList: [],
- isSignIn:false,
- },
- mutations: {
- /**
- * 蓝牙解析后的数据,转化成对应的坐标系方向
- * @param {Object} context
- */
- onConvertDeviceData(state, context) {
- let {
- data,
- callback = null
- } = context;
- let {
- acc,
- gyro,
- } = data;
- //根据已校准的数据转化对应的轴
- let outAcc = {
- ax: acc[state.convertAcc[0].match] * state.convertAcc[0].direction,
- ay: acc[state.convertAcc[1].match] * state.convertAcc[1].direction,
- az: acc[state.convertAcc[2].match] * state.convertAcc[2].direction
- };
- let outGyro = {
- gx: gyro[state.convertGyro[0].match] * state.convertGyro[0].direction,
- gy: gyro[state.convertGyro[1].match] * state.convertGyro[1].direction,
- gz: gyro[state.convertGyro[2].match] * state.convertGyro[2].direction
- }
- if (callback)
- callback({
- convertAcc: outAcc,
- convertGyro: outGyro
- });
- },
- onAccAndGyroConvertDataGet(state) {
- const convertAcc = uni.getStorageSync('convertAcc');
- if (convertAcc) {
- state.convertAcc = convertAcc;
- }
- const convertGyro = uni.getStorageSync('convertGyro');
- if (convertGyro) {
- state.convertGyro = convertGyro;
- }
- },
- onAccAndGyroConvertDataSave(state) {
- uni.setStorageSync('convertAcc', state.convertAcc);
- uni.setStorageSync('convertGyro', state.convertGyro);
- },
- onAccAndGyroConvertDataReset(state) {
- state.convertAcc = [{
- type: 'x',
- match: 'ax', //默认匹配一一对应
- direction: 1,
- }, {
- type: 'y',
- match: 'ay',
- direction: -1,
- }, {
- type: 'z',
- match: 'az',
- direction: -1,
- }];
- state.convertGyro = [{
- type: 'x',
- match: 'gx', //默认匹配一一对应
- direction: 1,
- }, {
- type: 'y',
- match: 'gy',
- direction: 1,
- }, {
- type: 'z',
- match: 'gz',
- direction: 1,
- }];
- //重置一下数据保存
- this.commit('onAccAndGyroConvertDataSave');
- },
- /**
- * 设置当前操作的任务记录到本地
- * @param {Object} state
- * @param {Object} _taskObj
- */
- setActionJumpTask(state, _taskObj) {
- uni.setStorageSync('currentJumpTask', _taskObj);
- state.currentJumpTask = _taskObj;
- },
- //获取本地任务对象
- getActionJumpTask(state) {
- //如果存在本地任务
- const value = uni.getStorageSync('currentJumpTask');
- if (value) {
- state.currentJumpTask = value;
- }
- },
- resetActionJumpTask(state) {
- state.currentJumpTask = null;
- uni.setStorageSync('currentJumpTask', state.currentJumpTask);
- },
- setFinallSelectFriendInfo(state, friendInfo) {
- state.finallySelectFriendInfo = friendInfo;
- console.log('finallySelectFriendInfo', JSON.stringify(friendInfo));
- },
- clearFinallFriendInfo(state) {
- state.finallySelectFriendInfo = null;
- },
- /**
- * 获取记录的最后一次连接设备
- * @param {Object} state
- */
- getFinalUseDevice(state) {
- // 获取本地存储的最后一次使用的设备
- //1.获取最近连接的蓝牙设备, 指蓝牙搜索到的obj
- const value = uni.getStorageSync('finallyUseDevice');
- if (value) {
- state.finallyUseDevice = value;
- }
- console.log('获取的finallyUseDevice', value);
- },
- /**
- * 存储最后一次使用的设备信息,后面登陆时候,如果存在设备最后一次使用信息,则自动连接
- * @param {Object} state
- * @param {Object} device
- */
- setFinallUseDevice(state, device) {
- uni.setStorageSync('finallyUseDevice', device);
- state.finallyUseDevice = device;
- console.log("保存finallyUseDevice:", state.finallyUseDevice);
- // uni.setStorage({
- // key: 'finallyUseDevice',
- // data: device,
- // success: (res) => {
- // state.finallyUseDevice = device;
- // console.log("保存finallyUseDevice:", res);
- // }
- // })
- },
- /**
- * 移除记录的use device
- */
- clearFinallUseDevice(state) {
- uni.removeStorage({
- key: 'finallyUseDevice',
- success: (res) => {
- state.finallyUseDevice = null;
- console.log("移除finallyUseDevice:", res);
- }
- })
- },
- /**
- * 设置运动时间
- * @param {Object} state
- * @param {Object} time
- */
- setLocalSportTime(state, time) {
- // let _sportTime = Number(time);
- state.localSportTime = Number(time);
- uni.setStorage({
- key: 'localSportTime',
- data: state.localSportTime,
- success: (res) => {
- // uni.showToast({
- // title: "保存成功"
- // })
- }
- })
- },
- /**
- * 设置卡路里
- * @param {Object} state
- * @param {Object} calorie
- */
- setLocalCalorie(state, calorie) {
- state.planData.localCalorie = Number(calorie);
- uni.setStorage({
- key: 'localCalorie',
- data: state.planData.localCalorie,
- success: (res) => {
- // uni.showToast({
- // title: "保存成功"
- // })
- }
- })
- },
- /**
- * 设置表盘显示的卡路里,
- * @param {Object} state
- * @param {Object} calorie
- */
- setShowCalorie(state, calorie) {
- state.planData.showCalorie = Number(calorie);
- uni.setStorage({
- key: 'showCalorie',
- data: state.planData.showCalorie,
- success: (res) => {
- // uni.showToast({
- // title: "保存成功"
- // })
- }
- })
- },
- /**
- * 增加卡路里
- * @param {Object} state
- * @param {Object} calorie
- */
- addlocalCalorie(state, calorie) {
- //卡路里不能为负数
- calorie = Math.abs(calorie);
- //当前需要添加的卡路里
- let temNum = Number(calorie);
- //本地的卡路里
- let temNum2 = Number(state.planData.localCalorie);
- // 本地加 + 传入的卡路里
- let _numberLocal = temNum.add(temNum2);
- //显示的卡路里
- let _showCalorie = Number(state.planData.showCalorie);
- //显示的卡路里加上 本地卡路里 和添加的卡路里之和要小于或等于 计划的卡路里
- let _allCalorie = _numberLocal.add(_showCalorie);
- // console.log("计算的最后卡路里_showCalorie:", _showCalorie,_allCalorie);
- //如果超过计划的,用计划的卡路里记录
- if (_allCalorie > state.planData.calorie) {
- let _calorie = Number(state.planData.calorie);
- //假如更新时候,localCalorie 值不为0,但是还未更新给服务器,此时,不能设置localCalorie 0
- //用传入的值,减去 allcalorie 总和和目标的差
- let _value = Number(_allCalorie).sub(_calorie);
- let _endValue = Number(_numberLocal).sub(_value);
- state.planData.localCalorie = Number(_endValue.toFixed(2));
- //如果大于或者等于的话,用计划 于 显示的卡路里 差值
- // state.planData.localCalorie = Number(_calorie.sub(_showCalorie).toFixed(2));
- // //显示最大值
- // state.planData.showCalorie = Number(_calorie.sub(state.planData.localCalorie).toFixed(2));
- } else {
- //
- state.planData.localCalorie = Number(_numberLocal.toFixed(2));
- // //输入的卡路里 + 自身显示的卡路里
- // state.planData.showCalorie = Number(temNum.add(_showCalorie).toFixed(2));
- }
- console.log("计算的最后卡路里:", state.planData);
- if (state.planData.localCalorie < 0) {
- //如果修改计划时候,本地数据计算的结果为负数,先取总和,localCalorie负再重置为0
- state.planData.showCalorie = _showCalorie.add(state.planData.localCalorie);
- state.planData.allCalorie = state.planData.showCalorie;
- state.planData.localCalorie = 0;
- } else {
- state.planData.allCalorie = _showCalorie.add(state.planData.localCalorie);
- }
- try {
- uni.setStorageSync('localCalorie', state.planData.localCalorie);
- } catch (e) {
- // error
- console.error(e);
- }
- try {
- uni.setStorageSync('showCalorie', state.planData.showCalorie);
- } catch (e) {
- // error
- console.error(e);
- }
- // uni.setStorage({
- // key: 'localCalorie',
- // data: state.planData.localCalorie,
- // success: (res) => {
- // // uni.showToast({
- // // title: "保存成功"
- // // })
- // }
- // })
- // uni.setStorage({
- // key: 'showCalorie',
- // data: state.planData.showCalorie,
- // success: (res) => {
- // // uni.showToast({
- // // title: "保存成功"
- // // })
- // }
- // })
- },
- /**
- * 每次登陆同步本地数据到服务器
- * 当天的数据更新,只更新一次
- * @param {Object} state
- */
- syncLocalDataToServer(state, callback) {
- let self = this;
- uni.getStorage({
- key: 'syncDate',
- success: function(res) {
- // console.log(res.data);
- let oldTime = res.data;
- let nDate = new Date();
- let newTime = date.formatDate(nDate);
- let days = date.datedifference(newTime, oldTime);
- // console.log(days);
- // 如果相差大于1天,
- if (days != 0) {
- // 更新存储日期
- uni.setStorageSync("syncDate", newTime);
- // 执行更新函数
- self.commit("syncRequestEvent", {
- success: () => {
- //清空显示的本地数据
- self.commit("setShowCalorie", 0);
- state.planData.allCalorie = state.planData.showCalorie.
- add(state.planData.localCalorie);
- if (callback)
- callback({
- newDate: nDate
- });
- }
- });
- //清空记录的本地运动时间
- // console.log('情况运动时间');
- self.commit("setLocalSportTime", 0);
- //设置本地数据是0
- state.localSportTime = 0;
- } else {
- if (callback)
- callback({
- newDate: nDate
- });
- }
- // date.getDays.
- },
- fail: function(res) {
- // console.error(res);
- // 如果没有日期,则存储一个新的
- let nDate = new Date();
- let tempTime = date.formatDate(nDate);
- uni.setStorageSync("syncDate", tempTime);
- if (callback)
- callback({
- newDate: nDate
- });
- }
- });
- },
- // 同步数据的请求
- syncRequestEvent(state, data) {
- let self = this;
- let {
- success,
- fail
- } = data;
- //需要卡路里取整存服务器,小数点后面,继续保留。以消除累计误差
- let oldLocalCalorie = state.planData.localCalorie;
- let _localCalorieInt = parseInt(state.planData.localCalorie);
- //小数点后面
- let _afterLocalCalorie = Number(oldLocalCalorie).sub(_localCalorieInt);
- console.log("*******===:", oldLocalCalorie, _localCalorieInt, _afterLocalCalorie);
- if (_localCalorieInt === 0) {
- // uni.showToast({
- // title: '',
- // icon: 'loading',
- // mask: true,
- // duration: 1000
- // })
- if (success)
- success();
- return;
- }
- uni.showToast({
- title: '',
- icon: 'loading',
- mask: false,
- duration: 10000
- })
- //把卡路里累计到cumulativeCalorie 变量,之后传服务器 += Math.round(state.planData.localCalorie)
- state.planData.cumulativeCalorie += _localCalorieInt;
- //添加到showCalorie 中
- state.planData.showCalorie = Number(state.planData.showCalorie).add(_localCalorieInt);
- state.planData.allCalorie = state.planData.showCalorie.add(_afterLocalCalorie);
- //不管是否同步成功,清空本地记录的卡路里,前一步已添加到cumulativeCalorie
- self.commit("setLocalCalorie", _afterLocalCalorie);
- self.commit("setShowCalorie", Number(state.planData.showCalorie));
- // 把卡路里记录到服务器
- reqUtil.requestData(config.URL.FITNESSPROGRAM, state.planData, 'POST').then(
- res => {
- // console.warn(res);
- if (res.code == 0) {
- uni.showToast({
- title: '同步成功',
- mask: true,
- duration: 1000
- });
- //同步一下服务器的返回值
- state.planData = Object.assign(state.planData, res.data);
- //暂时默认同步拳击1 的卡路里
- reqUtil.requestData(config.URL.UPLOADRANKING, {
- gameId: '1', //拳击模式 game id = 1;
- score: _localCalorieInt,
- cityCode: state.city.cityCode,
- }, "POST").then(res => {
- console.warn('****上传首页拳击卡路里,后面多个模式,可能需要多个不同的游戏id ***', res);
- },
- e => {
- console.log(e)
- });
- setTimeout(() => {
- uni.hideToast();
- }, 1000);
- if (success)
- success();
- } else {
- state.planData.cumulativeCalorie = Number(state.planData.cumulativeCalorie).sub(
- _localCalorieInt);
- state.planData.showCalorie = Number(state.planData.showCalorie).sub(
- _localCalorieInt);
- self.commit("setLocalCalorie", oldLocalCalorie);
- if (fail)
- fail();
- }
- console.log("减法 ==", Number(state.planData.cumulativeCalorie).sub(_localCalorieInt));
- },
- e => {
- console.log(e);
- state.planData.cumulativeCalorie = Number(state.planData.cumulativeCalorie).sub(
- _localCalorieInt);
- state.planData.showCalorie = Number(state.planData.showCalorie).sub(_localCalorieInt);
- self.commit("setLocalCalorie", oldLocalCalorie);
- uni.hideToast();
- if (fail)
- fail();
- }
- );
- },
- //登录成功后,重置一下状态
- resetCountDown(state) {
- if (state.interval) {
- clearInterval(state.interval);
- state.interval = null;
- state.count = 59;
- state.bCodeDisabled = false;
- }
- },
- //验证码操作
- countDown(state, phoneNumber) {
- //限制验证码操作
- state.bCodeDisabled = true;
- state.interval = setInterval(() => {
- --state.count;
- if (state.count <= 0) {
- clearInterval(state.interval);
- state.interval = null;
- state.count = 59;
- state.bCodeDisabled = false;
- }
- }, 1000);
- setTimeout(() => {
- clearInterval(state.interval)
- state.count = 59;
- state.bCodeDisabled = false;
- }, 60000);
- reqUtil.requestData(config.URL.GETCODE, {
- "phoneNumber": phoneNumber
- }).then(res => {
- console.log('requestData GETCODE =====', res);
- uni.showToast({
- title: "发送成功",
- mask: true,
- duration: 1000
- })
- },
- e => {
- console.log(e)
- });
- },
- //获取记录的蓝牙列表数据
- getBLEDeviceList(state) {
- // console.log("getBLEDeviceList=");
- uni.getStorage({
- key: 'BLEDeviceList',
- success: (res) => {
- console.log("*****getBLEDeviceList=", res);
- let _list = res.data;
- state.BLEDeviceList = res.data;
- //更新BLEDeviceShowList 数组
- state.BLEDeviceShowList = [];
- _list.forEach(item => {
- //如果记录到本地的id,和信息列表中的id一致,则结合
- for (let i = 0; i < state.BLEInfoList.length; i++) {
- let eq = state.BLEInfoList[i];
- if (item.id == eq.id) {
- state.BLEDeviceShowList.push(Object.assign({}, item, eq));
- break;
- }
- }
- })
- }
- })
- },
- //添加蓝牙设备数据
- addBLEDevice(state, data) {
- let devicelist = [];
- if (state.BLEDeviceList && state.BLEDeviceList.length != 0) {
- devicelist = state.BLEDeviceList;
- }
- // console.log(data, devicelist)
- let bHas = false;
- devicelist.forEach((item, index, selfArr) => {
- if (item.id == data.id) {
- //如果存在,更新保存的数据,比如 mac或者uuid等
- selfArr[index] = item = Object.assign({}, item, data);
- bHas = true;
- }
- })
- //把当前添加的的蓝牙设信息备作为最后一次连接覆盖到本地
- this.commit('setFinallUseDevice', data);
- if (!bHas) {
- //如果不是更新数据,就添加但却数据到列表
- devicelist.push(data);
- }
- uni.setStorage({
- key: 'BLEDeviceList',
- data: devicelist,
- success: (res) => {
- // uni.showToast({
- // title: "保存成功"
- // })
- state.BLEDeviceList = devicelist;
- // console.log("devicelist:",devicelist);
- //更新BLEDeviceShowList 数组
- state.BLEDeviceShowList = [];
- devicelist.forEach(item => {
- //如果记录到本地的id,和信息列表中的id一致,则结合
- for (let i = 0; i < state.BLEInfoList.length; i++) {
- let eq = state.BLEInfoList[i];
- if (item.id == eq.id) {
- // console.log("存储的======================:", item, eq);
- state.BLEDeviceShowList.push(Object.assign({}, item, eq));
- break;
- }
- }
- })
- // console.log("state.BLEDeviceShowList:",state.BLEDeviceShowList);
- }
- })
- },
- //删除蓝牙设备数据
- deleteBLEDevice(state, index) {
- let devicelist = [];
- devicelist = state.BLEDeviceList;
- devicelist.splice(index, 1);
- uni.setStorage({
- key: 'BLEDeviceList',
- data: devicelist,
- success: (res) => {
- uni.showToast({
- title: "删除成功"
- })
- state.BLEDeviceList = devicelist;
- //更新BLEDeviceShowList 数组
- state.BLEDeviceShowList = [];
- devicelist.forEach(item => {
- //如果记录到本地的id,和信息列表中的id一致,则结合
- for (let i = 0; i < state.BLEInfoList.length; i++) {
- let eq = state.BLEInfoList[i];
- if (item.id == eq.id) {
- state.BLEDeviceShowList.push(Object.assign({}, item, eq));
- break;
- }
- }
- })
- }
- })
- },
- //获取计划表数据
- getPlanData(state, callback) {
- reqUtil.requestData(config.URL.FITNESSPROGRAMGET).then(res => {
- // console.log('获取计划表数据:getPlanData=====', res.data);
- if (res.code == 0) {
- state.planData = Object.assign(state.planData, res.data);
- // 处理本地数据
- let templocalCalorie = uni.getStorageSync("localCalorie");
- // console.log("templocalCalorie:", templocalCalorie, state.planData);
- if (templocalCalorie) {
- templocalCalorie = Number(templocalCalorie);
- if (templocalCalorie > state.planData.calorie) {
- state.planData.localCalorie = state.planData.calorie;
- uni.setStorage({
- key: "localCalorie",
- data: state.planData.localCalorie
- });
- } else {
- state.planData.localCalorie = templocalCalorie;
- }
- } else {
- state.planData.localCalorie = 0;
- }
- //处理本地的cumulativeCalorie
- let tempShowCalorie = uni.getStorageSync("showCalorie");
- // console.log("tempShowCalorie:", tempShowCalorie, state.planData);
- if (tempShowCalorie) {
- tempShowCalorie = Number(tempShowCalorie);
- if (tempShowCalorie > state.planData.calorie) {
- state.planData.showCalorie = state.planData.calorie;
- uni.setStorage({
- key: "showCalorie",
- data: state.planData.showCalorie
- });
- } else {
- state.planData.showCalorie = tempShowCalorie;
- }
- } else {
- state.planData.showCalorie = 0;
- }
- state.planData.allCalorie = state.planData.showCalorie.add(state.planData
- .localCalorie);
- // console.log("======",state.planData )
- state.days = date.datedifference(res.data.startTime, res.data.endTime) + 1;
- let nDate = new Date();
- let tempTime = date.formatDate(nDate);
- state.remainingDays = date.datedifference(tempTime, res.data.endTime) + 1;
- console.log("state.remainingDays======", tempTime, res.data.endTime, state
- .remainingDays);
- }
- // showArcbar
- if (callback) {
- callback();
- }
- },
- e => {
- console.log(e)
- });
- },
- /**
- * 获取全部游戏
- * @param {Object} state
- */
- getAllGame(state, callback) {
- //获得全部游戏列表
- if (state.allGames.length != 0) {
- if (callback)
- callback();
- return;
- }
- reqUtil.requestData(
- config.URL.GAMELIST_BY_RANKING_SHOW_AND_PLATFORM, {
- rankingShow: 1,
- page: 1,
- size: 100
- }
- ).then(res => {
- // console.log('获取默认的全部游戏 =====', res);
- if (res.code == 0) {
- state.allGames = [];
- state.allGames = state.allGames.concat(res.data);
- }
- if (callback)
- callback();
- },
- e => {
- console.log(e);
- if (callback)
- callback();
- }
- );
- },
- getRankGame(state, data) {
- let {
- param,
- callback
- } = data;
- reqUtil.requestData(config.URL.GETRANKRANGR, param).then(res => {
- console.log('获取默认的游戏数据:GETRANKRANGR=====', res);
- if (res.data != null) {
- state.rankSelectedGame = res.data.gameInfo;
- state.rankInfo = res.data.rankInfo;
- //然后获取排名
- }
- if (callback)
- callback(res);
- },
- e => {
- console.log(e)
- });
- },
- /**
- * 苹果端登陆
- * @param {Object} state
- * @param {Object} data
- */
- appleUserInfoLogin(state, data) {
- let self = this;
- let {
- params,
- callback
- } = data;
- console.log('获取用户数据:USERINFOAPPLEADD params=====', params);
- reqUtil.requestData(config.URL.USERINFOAPPLEADD, params, 'POST').then(res => {
- console.log('获取用户数据:USERINFOAPPLEADD =====', res);
- if (res.code == 0) {
- let userInfo = res.data;
- self.commit('login', userInfo);
- console.log("11~~");
- } else if (res.code = 201) {
- state.hasLogin = true;
- }
- console.log("apple callback!!!");
- callback();
- },
- e => {
- console.log(e)
- });
- },
- //添加用户信息和登录
- addUserAvatarAndLogin(state, data) {
- let self = this;
- let {
- params,
- filePath,
- callback
- } = data;
- console.log("addUserAvatarAndLogin 初始化对应数据");
- reqUtil.reqUpload(config.URL.USERINFOADDAVATARINFO, params, filePath).then(res => {
- console.log('获取用户数据:USERINFOADDAVATARINFO =====', res);
- if (res.code == 0) {
- let userInfo = res.data;
- self.commit('login', userInfo);
- } else if (res.code = 201) {
- state.hasLogin = true;
- }
- if (callback) {
- callback();
- }
- },
- e => {
- console.log(e)
- });
- },
- //app登录或h5
- accountLogin(state, callback) {
- let self = this;
- // console.log("app登录或h5 初始化对应数据")
- reqUtil.requestData(config.URL.USERINFOURL).then(res => {
- console.log('获取用户数据:USERINFOURL =====', res);
- if (res.code == 0) {
- let userInfo = res.data.userInfo;
- state.phoneNumber = res.data.phoneNumber || '';
- state.openid = res.data.openid || '';
- self.commit('login', userInfo);
- } else if (res.code = 201) {
- state.hasLogin = true;
- }
- if (callback) {
- callback();
- }
- },
- e => {
- console.log(e)
- });
- },
- //小程序页面登录
- login(state, userInfo) {
- console.log("登陆的信息==", userInfo);
- if (userInfo.cityCode == "" || userInfo.cityCode == null) {
- //不存在就设置默认值
- userInfo.cityCode = state.city.cityCode;
- }
- let cityCode = userInfo.cityCode;
- // console.log("cicicicitycode:", cityCode);
- let provinceData = require('@/components/slambb-picker/city-data/province.js').default;
- let cityData = require('@/components/slambb-picker/city-data/city.js').default;
- let areaData = require('@/components/slambb-picker/city-data/area.js').default;
- // 解析citycode
- for (let i = 0; i < provinceData.length; i++) {
- if (provinceData[i].value == cityCode.substr(0, 2)) {
- let currentCityData = cityData[i];
- for (let j = 0; j < currentCityData.length; j++) {
- if (currentCityData[j].value == cityCode.substr(0, 4)) {
- let areaDataTemp = areaData[i][j];
- for (let k = 0; k < areaDataTemp.length; k++) {
- if (areaDataTemp[k].value == cityCode) {
- state.city.value = [i, j, k];
- state.city.label = provinceData[i].label +
- '-' +
- currentCityData[j].label +
- '-' +
- areaDataTemp[k].label;
- state.cityName = currentCityData[j].label;
- break;
- }
- }
- break;
- }
- }
- break;
- }
- }
- state.userInfo = userInfo;
- state.userName = userInfo.username || '新用户';
- state.avatarUrl = userInfo.avatarUrl || '/static/defaultAvatar.png';
- state.gender = userInfo.gender;
- state.signature = userInfo.signature || '';
- state.birthday = userInfo.birthday;
- state.city.cityCode = cityCode.toString();
- state.weight = userInfo.weight || state.weight;
- state.height = userInfo.height || state.height;
- state.hasLogin = true;
- //登录时候 获取一下排行榜里面的游戏
- // this.commit('getRankGame', {
- // param: {
- // type: "china",
- // cityCode: 12345
- // }
- // });
- //进入此页面先设置平台参数
- if (state.platform == "ios") {
- uni.setStorageSync("platform", 1);
- } else if (state.platform == "android") {
- uni.setStorageSync("platform", 0);
- }
- //获取版本信息
- this.commit('getVersionCode');
- },
- // 退出登录
- // 删除token 操作
- delectToken(state, data) {
- let self = this;
- let {
- success
- } = data;
- reqUtil.requestData(config.URL.USERLOGINOUT, {}).then(res => {
- console.log('USERLOGINOUT=====', res);
- self.commit("logout");
- try {
- //清空保存的storage
- uni.clearStorageSync();
- } catch (e) {
- // error
- console.error(e);
- }
- if (state.BLERSSIInterval) {
- clearInterval(state.BLERSSIInterval);
- state.BLERSSIInterval = null;
- }
- if (state.BLEConnectDevice) {
- self.commit("onCloseBLEConnection", {
- getSuccess: () => {}
- });
- }
- if (success) {
- success(res);
- }
- },
- e => {
- console.log(e)
- });
- },
- logout(state) {
- state.userInfo = null;
- state.userName = "匿名";
- state.avatarUrl = '/static/defaultAvatar.png';
- state.days = '0';
- state.signature = '';
- state.gender = 0;
- state.hasLogin = false;
- state.phoneNumber = '';
- state.openid = '';
- state.appleid = '';
- //处理设备值
- state.cIndex = -1;
- //绑定的设备
- state.ConnectBindingDevice = null;
- //蓝牙设备
- state.BLEConnectDevice = null;
- //蓝牙服务
- state.BLEGetServices = null;
- //最近连接过的设备
- state.finallyUseDevice = null;
- //最近选择的好友
- state.finallySelectFriendInfo = null;
- //记录的蓝牙设备,保存id, 和对应的蓝牙连接数据
- state.BLEDeviceList = [];
- //显示的蓝牙设备,取本地数据时候更新
- state.BLEDeviceShowList = [];
- //记录表盘计划刷新的卡路里
- state.oldArcbarProCalorie = 0;
- //记录表盘当前的总卡路里
- state.oldArcbarAllCalorie = 0;
- //任务相关
- state.currentJumpTask = null;
- },
- loginUserInfo(state, data) {
- let {
- infoRes,
- success,
- fail
- } = data;
- console.log('loginUserInfo');
- reqUtil.requestData(config.URL.WXGETUSERINFO, {
- appid: 'wxd6dfd60729d33d17',
- encryptedData: infoRes.encryptedData,
- iv: infoRes.iv,
- signature: infoRes.signature,
- rawData: infoRes.rawData
- }).then(res => {
- console.log('wxInfoRes=====', res);
- let userInfo = res.data;
- this.commit('login', userInfo);
- if (success) {
- success(res);
- }
- },
- e => {
- console.log(e)
- if (fail) {
- success(fail);
- }
- });
- },
- //这里统一静默处理login
- oauth(state, context) {
- let {
- value,
- callback
- } = context;
- uni.login({
- provider: value,
- success: (res) => {
- // console.log('code:', res);
- reqUtil.requestData(config.URL.USERlOGINURL, {
- appid: 'wxd6dfd60729d33d17',
- code: res.code,
- platfrom: value
- }).then(res => {
- console.log('login token=====', res);
- state.token = res.data.token;
- uni.setStorageSync('token', state.token);
- uni.getUserInfo({
- provider: value,
- success: (infoRes) => {
- if (callback) {
- callback(infoRes);
- }
- },
- fail: (failRes) => {
- //假如没有授权,login 之后,不做处理,需要用户点击授权时候,再进行处理用户登录
- console.log('getUserInfo failRes:', failRes)
- }
- });
- },
- e => {
- console.log(e)
- });
- },
- fail: (err) => {
- console.error('授权登录失败:' + JSON.stringify(err));
- }
- });
- },
- onLuanchLogin(state, data) {
- let {
- success
- } = data;
- const filters = ['weixin', 'qq', 'sinaweibo'];
- let platform = '';
- uni.getProvider({
- service: 'oauth',
- success: (res) => {
- if (res.provider && res.provider.length) {
- for (let i = 0; i < res.provider.length; i++) {
- if (~filters.indexOf(res.provider[i])) {
- platform = res.provider[i];
- console.log("platform=", platform);
- uni.showToast({
- icon: 'loading',
- title: ''
- })
- this.commit('oauth', {
- value: platform,
- callback: (infoRes) => {
- // console.log("infoRes:", infoRes);
- this.commit('loginUserInfo', {
- infoRes: infoRes,
- success: (res) => {
- console.log("获取用户成功");
- if (success) {
- success(res);
- }
- uni.hideToast();
- },
- fail: (res) => {
- console.error("获取用户失败");
- uni.hideToast();
- }
- });
- }
- })
- }
- }
- this.hasProvider = true;
- }
- },
- fail: (err) => {
- console.error('获取服务供应商失败:' + JSON.stringify(err));
- }
- });
- },
- initAdapter(state, callback) {
- //初始化蓝牙模块
- let params = {
- success: (res) => {
- state.bOpenSuccess = true;
- state.bOpenBluetooth = true;
- if (callback)
- callback(res);
- //监听断开事件
- this.commit("B_OnBLEConnectionStateChange");
- },
- fail: (fail) => {
- state.bOpenSuccess = false;
- state.bOpenBluetooth = false;
- uni.showToast({
- title: '蓝牙尚未开启!',
- icon: 'none'
- })
- },
- complete: (complete) => {
- console.log("complete bListenAdapterStateChange:", state.bListenAdapterStateChange);
- if (state.bListenAdapterStateChange) return;
- state.bListenAdapterStateChange = true;
- uni.onBluetoothAdapterStateChange((res) => {
- console.log('adapterState changed, now is', res)
- // 手机蓝牙状态
- state.bOpenBluetooth = res.available;
- if (state.bOpenBluetooth && !state.bOpenSuccess) {
- this.commit('initAdapter');
- }
- })
- }
- };
- this.commit("B_OpenBluetoothAdapter", params);
- },
- // todo 未使用到
- onGetDevices(state, context) {
- let {
- success
- } = context;
- if (!state.BLEConnectDevice) return;
- // #ifdef APP-PLUS
- let deviceId = state.BLEConnectDevice.deviceId;
- uni.getBLEDeviceRSSI({
- deviceId,
- success: res => {
- let _dis = Math.pow(Math.E, (Math.abs(res.RSSI) - 66.78) / 16.56);
- if (_dis > state.BLEConnectDevice.limitDis) {
- if (state.cIndex != -1) {
- uni.showToast({
- title: '设备断开连接!',
- icon: 'none',
- duration: 2000,
- mask: true
- })
- }
- setTimeout(() => {
- this.commit("B_CloseBLEConnection", {
- deviceId: deviceId
- })
- state.cIndex = -1;
- state.bConnection = false;
- state.bVerifiedConnection = false;
- }, 1000)
- } else {
- // console.log("DIS~~~~~~~~~", _dis);
- if (success) {
- success({
- RSSI: res.RSSI,
- DIS: _dis
- });
- }
- }
- }
- })
- // #endif
- },
- //清除连接的开启的timeout
- onUnloadCreateBLEConnectionTimeout(state) {
- if (state.getBLEDeviceServicesTimeout) {
- clearTimeout(state.getBLEDeviceServicesTimeout);
- state.getBLEDeviceServicesTimeout = null;
- }
- },
- initBLEData(state) {
- // 设备Id
- state.deviceId = "";
- // 服务Id
- state.serviceId = "";
- state.notifyCharacteristicId = "";
- state.writeCharacteristicId = "";
- state.currentInstruction = "";
- state.showToast = false;
- state.bListenerUpdate = false;
- state.bListenerJson = false;
- state.bListenerMac = false;
- state.bListenerAccArray = false;
- //更新二进制的
- state.bListenerHexUpdate = false;
- },
- //连接蓝牙
- onCreateBLEConnection(state, context) {
- let {
- index,
- item,
- initItem = false,
- getSuccess = null,
- getinitAdapter = null
- } = context;
- uni.showToast({
- title: '连接设备中...',
- icon: 'loading',
- duration: 10000,
- mask: true
- })
- let params = {
- item: item,
- success: (success) => {
- state.bConnection = true;
- if (state.getBLEDeviceServicesTimeout) {
- clearTimeout(state.getBLEDeviceServicesTimeout);
- state.getBLEDeviceServicesTimeout = null;
- }
- state.getBLEDeviceServicesTimeout = setTimeout(() => {
- let retryCount = 5;
- this.commit("B_GetBLEDeviceServices", {
- retryCount: retryCount,
- item: item,
- callback: () => {
- uni.showToast({
- title: '连接成功',
- icon: 'loading',
- duration: 2000,
- mask: true
- })
- //是否需要设置item,默认不设置
- if (initItem) {
- state.cIndex = index;
- state.BLEConnectDevice = item;
- }
- if (getSuccess)
- getSuccess();
- /**
- * 直接连接过成功
- */
- state.bVerifiedConnection = true;
- },
- getServiceList: (serviceList) => {
- //搜索服务失败后
- state.BLEGetServices = serviceList;
- },
- getFail: () => {
- this.commit("B_CloseBLEConnection", {
- deviceId: item.deviceId
- })
- // state.cIndex = -1;
- // state.bConnection = false;
- // state.bVerifiedConnection = false;
- this.commit("onResetBLEConnection");
- }
- });
- }, 2000);
- },
- fail: (fail) => {
- console.log("***fail:", fail);
- if (fail.errCode === 10012) {
- console.log("连接超时,请重试!");
- uni.showToast({
- title: '连接失败,开启设备后尝试重新连接!',
- icon: 'none',
- duration: 3000,
- mask: true
- })
- } else if (fail.errCode === 10013) {
- console.log("连接失败,蓝牙地址无效!");
- uni.showToast({
- title: '连接失败,蓝牙地址无效',
- icon: 'none',
- duration: 2000,
- mask: true
- })
- } else if (fail.errCode === 10000) {
- this.commit('initAdapter', () => {
- if (getinitAdapter) {
- getinitAdapter();
- }
- })
- } else {
- // err.errCode10003原因多种:蓝牙设备未开启或异常导致无法连接;蓝牙设备被占用或者上次蓝牙连接未断开导致无法连接
- console.log("连接失败,请重试!", state.BLEConnectDevice);
- uni.showToast({
- title: '请尝试开启设备和重启app。',
- icon: 'none',
- duration: 2000,
- mask: true
- })
- }
- }
- };
- this.commit("B_CreateBLEConnection", params);
- },
- //devices hardware 连接后验证,这里不需要处理 bVerifiedConnection,通过mac 验证后处理
- onCreateBLESuccess(state, context) {
- let {
- item,
- getSuccess = null
- } = context;
- this.commit("B_CreateBLEConnection", {
- item: item,
- success: success => {
- state.BLEConnectDevice = item;
- state.bConnection = true;
- if (getSuccess) {
- getSuccess();
- }
- },
- fail: fail => {
- if (fail.errCode === 10012) {
- console.log("连接超时,请重试!");
- uni.showToast({
- title: '连接超时,检查对应设备是否开启?',
- icon: 'none',
- duration: 2000,
- mask: true
- })
- } else if (fail.errCode === 10013) {
- console.log("连接失败,蓝牙地址无效!");
- uni.showToast({
- title: '蓝牙地址无效,检查设备是否正常?',
- icon: 'none',
- duration: 2000,
- mask: true
- })
- } else if (fail.errCode === 10000) {
- console.log("连接失败,初始化 wx.openBluetoothAdapter 调用之后使用");
- uni.showToast({
- title: '连接失败,检查手机蓝牙是否开启?',
- icon: 'none',
- duration: 2000,
- mask: true
- })
- } else {
- console.log("连接失败,请重试!");
- uni.showModal({
- title: '连接失败',
- content: '设备未开启或被占用。请重启app和设备后重新连接。'
- })
- // uni.showToast({
- // title: '设备未开启或被占用异常导致无法连接。',
- // icon: 'none',
- // duration: 2000,
- // mask: true
- // })
- }
- }
- });
- },
- //获取蓝牙服务
- onGetBLEDeviceServices(state, context) {
- let {
- item,
- success = null,
- } = context;
- let retryCount = 5;
- this.commit("B_GetBLEDeviceServices", {
- retryCount: retryCount,
- item: item,
- callback: success,
- getServiceList: (serviceList) => {
- state.BLEGetServices = serviceList;
- },
- getFail: () => {
- this.commit("B_CloseBLEConnection", {
- deviceId: item.deviceId
- })
- this.commit("onResetBLEConnection");
- }
- })
- },
- //重置蓝牙连接参数
- onResetBLEConnection(state) {
- state.cIndex = -1;
- state.BLEConnectDevice = null;
- //蓝牙服务
- state.BLEGetServices = null;
- state.bConnection = false;
- state.bVerifiedConnection = false;
- },
- onCloseBLEConnection(state, context) {
- console.log("onCloseBLEConnection", state.BLEConnectDevice);
- let {
- getSuccess = null,
- } = context;
- if (state.BLERSSIInterval) {
- clearInterval(state.BLERSSIInterval);
- state.BLERSSIInterval = null;
- }
- this.commit("B_CloseBLEConnection", {
- deviceId: state.BLEConnectDevice.deviceId,
- success: () => {
- state.cIndex = -1;
- state.BLEConnectDevice = null;
- //蓝牙服务
- state.BLEGetServices = null;
- if (getSuccess) {
- getSuccess();
- }
- state.bConnection = false;
- state.bVerifiedConnection = false;
- uni.closeBluetoothAdapter({
- success(res) {
- console.log(res)
- state.bOpenBluetooth = false;
- }
- })
- }
- });
- },
- //不关闭 adapter
- onOnlyCloseBLEConnection(state, context) {
- let {
- getSuccess = null
- } = context;
- if (state.BLERSSIInterval) {
- clearInterval(state.BLERSSIInterval);
- state.BLERSSIInterval = null;
- }
- this.commit("B_CloseBLEConnection", {
- deviceId: state.BLEConnectDevice.deviceId,
- success: () => {
- state.cIndex = -1;
- state.BLEConnectDevice = null;
- //蓝牙服务
- state.BLEGetServices = null;
- if (getSuccess) {
- getSuccess();
- }
- state.bConnection = false;
- state.bVerifiedConnection = false;
- }
- });
- },
- onWriteBLEConnectionValue(state, context) {
- //#ifdef H5
- console.warn("h5不支持蓝牙:", 'onWriteBLEConnectionValue');
- return;
- //#endif
- let {
- getSuccess = null,
- getFail = null,
- value,
- bSendHex = false,
- bOpen = false,
- } = context;
- if (!state.BLEConnectDevice && state.cIndex == -1) {
- uni.showToast({
- title: '蓝牙设备未连接',
- icon: 'none'
- })
- }
- // console.log(22);
- //记录蓝牙盒子当前的指令
- // state.currentInstruction = value;
- // 发送 3 :开启原始数据
- // 发送4 :关闭原始数据
- // 发送 5 :开启步数
- // 发送6 :关闭步数
- if (value == "3") {
- state.instructionState.bOpen = true;
- } else if (value == "4") {
- state.instructionState.bOpen = false;
- } else if (value == "5") {
- state.instructionState.bSteps = true;
- } else if (value == "6") {
- state.instructionState.bSteps = false;
- } else if (bSendHex && bOpen) {
- state.instructionState.bOpen = true;
- } else if (bSendHex && !bOpen) {
- state.instructionState.bOpen = false;
- }
- let retryCount = 5;
- this.commit("B_WriteBLECharacteristicValue", {
- value,
- retryCount,
- getSuccess,
- getFail,
- bSendHex
- });
- },
- //获取距离
- onGetRSSITransDistance(state, context) {
- let {
- RSSI
- } = context;
- BLE.getRSSITransDistance(RSSI);
- },
- //添加使用的前端信息
- gOnAddClientInfo(state, context) {
- uni.getSystemInfo({
- success: (res) => {
- // console.log("系统信息:", res);
- let clientInfo = res;
- clientInfo.clientSystem = res.system;
- reqUtil.requestData(config.URL.ADDCLIENTINFO, clientInfo, 'POST').then(
- res => {
- console.warn(res);
- },
- e => {}
- );
- },
- fail: (err) => {},
- complete: () => {}
- })
- },
- //创建快速打击对象
- gCreateFilterObj(state) {
- state.filter = null;
- state.deviceMs = 1;
- state.filter = new o0Project.Filter();
- console.log("gCreateFilterObj");
- },
- //更新快速打击对象数据
- gUpdateFilter(state, context) {
- let {
- data,
- callback
- } = context;
- let {
- min,
- s,
- ms
- } = data;
- var msGap = ms - state.deviceMs;
- state.deviceMs = ms;
- while (msGap < 0) {
- msGap += 1000;
- }
- // console.log(data);
- let {
- ax,
- ay,
- az
- } = data.acc;
- let {
- gx,
- gy,
- gz
- } = data.gyro;
- state.filter.Update(new o0.Vector3(ax, ay, az), msGap, new o0.Vector3(gx, gy, gz),
- callback); //我自己的更新acc的函数
- },
- /**
- * 创建一个沙袋打击对象
- * @param {Object} state
- */
- gCreateSandbagAlgorithm(state) {
- state.sandbagAlgorithm = null;
- state.sandbagAlgorithmLastTime = new Date().getTime();
- state.sandbagAlgorithm = new o0ProjectRelease.SandbagAlgorithm();
- console.log("gCreateSandbagAlgorithm");
- },
- /**
- * 更新 沙袋打击对象 数据
- * @param {Object} state
- * @param {Object} context
- */
- gUpdateSandbagAlgorithm(state, context) {
- let {
- data,
- callback = null
- } = context;
- let {
- ax,
- ay,
- az
- } = data.acc;
- let {
- gx,
- gy,
- gz
- } = data.gyro;
- let [hit, dir] = state.sandbagAlgorithm.Update(ax / 10, az / 10, gz, -gx, data.ms);
- if (dir != undefined) {
- let temp = state.sandbagAlgorithm.getTempValue(dir);
- if (callback) {
- callback(temp);
- }
- }
- },
- /**
- * 开启加速计,陀螺仪,并且模拟ble发送
- * @param {Object} state
- */
- gStartSimulateBLEUpdate(state) {
- //todo 区分平台,目前是android 模块
- if (state.globalMyAttitude == null) {
- state.globalMyAttitude = uni.requireNativePlugin("MyAttitude");
- let globalEvent = uni.requireNativePlugin('globalEvent');
- globalEvent.addEventListener('updateAccAndGyro', function(e) {
- //updateAccAndGyro{"accelerometer":[-0.178375244140625,9.327804565429688,2.6168670654296875],"gyroscope":[0.0018310546875,-0.0019989013671875,0.0027923583984375]}
- //console.log('updateAccAndGyro' + JSON.stringify(e));
- let _accArray = e.accelerometer;
- let _gyroArray = e.gyroscope;
- state.globalAccData.ax = _accArray[0];
- state.globalAccData.ay = _accArray[1];
- state.globalAccData.az = _accArray[2];
- state.globalGyroData.gx = _gyroArray[0];
- state.globalGyroData.gy = _gyroArray[1];
- state.globalGyroData.gz = _gyroArray[2];
- let box = {};
- box["acc"] = state.globalAccData;
- box["gyro"] = state.globalGyroData;
- box["ms"] = e.ms;
- //更新数据给webview,在game-play-web||game-play-sub绑定
- //后面更新数据都用此接口
- uni.$emit('updateBLEDeviceData', box);
- });
- }
- var ret = state.globalMyAttitude.onStartAccAndGyro();
- if (!ret.accelerometer || !ret.gyroscope) {
- uni.showModal({
- title: '提示',
- content: '是否初始化,加速计:' + ret.accelerometer + ',陀螺仪:' + ret.gyroscope
- })
- }
- console.log('gStartSimulateBLEUpdate:', ret);
- },
- /**
- * 停止加速计,陀螺仪
- * @param {Object} state
- */
- gStopSimulateBLEUpdate(state) {
- //todo 区分平台,目前是android 模块
- let globalEvent = uni.requireNativePlugin('globalEvent');
- globalEvent.removeEventListener('updateAccAndGyro');
- var ret = state.globalMyAttitude.onStopAccAndGyro();
- console.log('gStopSimulateBLEUpdate:', ret);
- state.globalMyAttitude = null;
- },
- /**
- * 限制开始游戏
- */
- glimitPlayGame(state, context) {
- let {
- gameTags,
- callback
- } = context;
- //没有标签直接进去
- if (gameTags.length == 0) {
- callback();
- return;
- }
- let canPlay = false;
- gameTags.forEach((item) => {
- //如果存在普通模式
- if (item.tagMode === 'normal') {
- canPlay = true;
- }
- if (canPlay)
- return;
- })
- if (!canPlay) {
- //2.如果普通模式不存在,就判断是否连接硬件了
- if (!state.BLEConnectDevice || state.cIndex == -1) {
- uni.showToast({
- title: "请连接标签对应的设备模式!",
- icon: "none",
- duration: 2000,
- mask: true
- })
- return;
- }
- //3.如果连接了设备,判断但是处于什么模式
- gameTags.forEach((item, index, selfArr) => {
- //如果存在普通模式
- if (item.tagMode === state.BLEConnectDevice.usageMode) {
- canPlay = true;
- }
- if (canPlay)
- return;
- if (index == selfArr.length - 1) {
- uni.showToast({
- title: "游戏没有当前设备模式!",
- icon: "none",
- duration: 2000,
- mask: true
- })
- }
- })
- }
- if (canPlay) {
- callback();
- }
- },
- checkAppUpdata(state) {
- //#ifdef APP-PLUS
- let _temp = {
- appid: plus.runtime.appid,
- version: state.version,
- versionCode: state.versionCode,
- platform: state.platform.toLocaleLowerCase(),
- }
- //#endif
- //#ifdef H5
- //此 _temp 测试用
- let _temp = {
- appid: '1',
- version: "2.0.0",
- versionCode: "20122202",
- platform: "android",
- }
- //#endif
- reqUtil.requestData(config.URL.APPVERSIONUPDATE, _temp).then(res => {
- console.log('requestData APPVERSIONUPDATE =====', res);
- let _data = res.data;
- if (res.code == 0 && res.data.status === 1) {
- uni.showModal({ //提醒用户更新
- title: "更新提示",
- content: res.data.note,
- success: (res) => {
- if (res.confirm) {
- if (state.platform.toLocaleLowerCase() == "android") {
- plus.runtime.openURL(_data.url, function(res) {
- plus.nativeUI.alert("本机没安装应用宝,请安装后获取新版本。");
- }, 'com.tencent.android.qqdownloader');
- } else {
- //ios
- plus.runtime.openURL(_data.url);
- }
- }
- }
- })
- } else {
- uni.showToast({
- title: '当前为最新版本',
- icon: 'none',
- duration: 2000,
- mask: true
- })
- }
- },
- e => {
- console.log(e)
- });
- },
- /**
- * 蓝牙BLE迁移到store.js
- */
- // 初始化蓝牙模块适配器
- B_OpenBluetoothAdapter(state, context) {
- let {
- success,
- fail,
- complete
- } = context;
- //#ifdef H5
- console.warn('h5不加载蓝牙模块');
- return;
- //#endif
- uni.openBluetoothAdapter({
- success: res => {
- if (success)
- success(res);
- },
- fail: res => {
- if (fail)
- fail(res);
- },
- complete: res => {
- if (complete)
- complete(res);
- }
- })
- },
- /**
- * 关闭蓝牙模块适配器
- */
- B_CloseBluetoothAdapter() {
- //#ifdef H5
- console.warn('h5不加载蓝牙模块');
- return;
- //#endif
- uni.closeBluetoothAdapter({
- success: res => {
- console.log('断开蓝牙模块成功');
- uni.showToast({
- icon: "none",
- title: "蓝牙已经断开!",
- mask: false,
- duration: 3000
- });
- }
- });
- },
- B_OnBLEConnectionStateChange(state) {
- let _self = this;
- //#ifdef H5
- console.warn('h5不加载蓝牙模块');
- return;
- //#endif
- uni.onBLEConnectionStateChange(res => {
- // 该方法回调中可以用于处理连接意外断开等异常情况
- console.log(`蓝牙连接状态 -------------------------->`, JSON.stringify(res));
- if (!res.connected) {
- //要在连接的状态下 ,并且获取过匹配列表有参数的情况下,才提示重连
- if (!state.bShowBLEConnectModal && state.bVerifiedConnection && state
- .bPhoneMatched) {
- state.bShowBLEConnectModal = true;
- let _connectItem = Object.assign({}, state.BLEConnectDevice);
- let _cIndex = state.cIndex;
- //断开连接后reset一下参数
- _self.commit("onResetBLEConnection");
- let _tip = state.bGamePlaying ? "蓝牙已断开是否重新连接蓝牙?重连需要重启游戏!" : "蓝牙已断开是否重新连接蓝牙";
- uni.showModal({
- title: _tip,
- success: (sRes) => {
- state.bShowBLEConnectModal = false;
- if (sRes.confirm) {
- console.log("重连的_cIndex:", _cIndex);
- _self.commit("onCreateBLEConnection", {
- item: _connectItem,
- index: _cIndex,
- initItem: true,
- getSuccess: () => {
- //此处不检查外部设备
- uni.$emit('retryConnectBLESuccess');
- },
- getinitAdapter: () => {}
- })
- }
- }
- })
- } else {
- //断开连接后reset一下参数
- _self.commit("onResetBLEConnection");
- }
- uni.$emit('callbackCloseBLE');
- }
- });
- },
- /**
- * 连接低功耗蓝牙设备。
- * 若APP在之前已有搜索过某个蓝牙设备,并成功建立连接,可直接传入之前搜索获取的 deviceId 直接尝试连接该设备,无需进行搜索操作。
- */
- B_CreateBLEConnection(state, context) {
- let {
- item,
- success,
- fail
- } = context;
- this.commit('initBLEData');
- state.deviceId = item.deviceId;
- let timeout = 10000;
- console.log("B_CreateBLEConnection deviceId ==", state.deviceId)
- uni.createBLEConnection({
- // 这里的 deviceId 需要已经通过 createBLEConnection 与对应设备建立链接
- deviceId: state.deviceId,
- timeout: timeout,
- success: res => {
- if (success) {
- success(res);
- }
- },
- fail: res => {
- if (fail)
- fail(res);
- }
- });
- },
- /**
- * 获取设备的服务ID
- */
- B_GetBLEDeviceServices(state, context) {
- let {
- retryCount,
- item,
- callback,
- getServiceList,
- getFail,
- } = context;
- let serviceList = [];
- let _self = this;
- uni.getBLEDeviceServices({
- deviceId: item.deviceId,
- success: res => {
- // console.log("getBLEDeviceServices==", JSON.stringify(res), item);
- serviceList = res.services;
- if (getServiceList) {
- getServiceList(serviceList);
- }
- if (serviceList.length == 0) {
- if (retryCount > 0) {
- retryCount--;
- context.retryCount = retryCount;
- setTimeout(() => {
- this.commit('B_GetBLEDeviceServices', context);
- }, 500)
- return;
- }
- if (getFail) {
- getFail();
- }
- uni.hideToast();
- uni.showModal({
- title: '提示',
- content: '1.获取服务失败,请尝试重新连接设备。\r\n2.尝试重启设备再重新连接。'
- })
- }
- for (let i = 0; i < serviceList.length; i++) {
- let service = serviceList[i];
- if (service.uuid.toLocaleLowerCase() === item.PRIMARY_SERVICE
- .toLocaleLowerCase()) {
- state.serviceId = service.uuid;
- //开始获取指定服务的特征值
- _self.commit('B_GetBLEDeviceCharacteristics', {
- item: item,
- callback: callback
- });
- break;
- }
- }
- },
- fail: failRes => {
- console.log('device services:', failRes.services)
- uni.showModal({
- title: '连接错误',
- content: '请尝试重新连接设备。'
- })
- if (getFail) {
- getFail();
- }
- }
- });
- },
- /**
- * 获取指定服务的特征值
- */
- B_GetBLEDeviceCharacteristics(state, context) {
- let {
- item,
- callback
- } = context;
- let deviceId = state.deviceId;
- let serviceId = state.serviceId;
- let characteristicsList = [];
- uni.getBLEDeviceCharacteristics({
- deviceId,
- serviceId,
- success: res => {
- if (item.PRIMARY_NOTIFY != '') {
- state.notifyCharacteristicId = item.PRIMARY_NOTIFY;
- this.commit('B_NotifyBLECharacteristicValueChange', {
- callback: callback
- });
- }
- if (item.PRIMARY_WRITE != '') {
- state.writeCharacteristicId = item.PRIMARY_WRITE;
- }
- },
- fail: res => {
- console.log('device getBLEDeviceCharacteristics failed:', JSON.stringify(res))
- }
- })
- },
- //启用低功耗蓝牙设备特征值变化时的 notify 功能,订阅特征值。
- //注意:必须设备的特征值支持notify或者indicate才可以成功调用,具体参照 characteristic 的 properties 属性
- B_NotifyBLECharacteristicValueChange(state, context) {
- let {
- callback
- } = context;
- // 启用notify功能
- // console.log("启用notify功能");
- uni.notifyBLECharacteristicValueChange({
- state: true,
- deviceId: state.deviceId,
- serviceId: state.serviceId,
- characteristicId: state.notifyCharacteristicId,
- success: (res) => {
- this.commit('B_OnBLECharacteristicValueChange', {
- callback: callback
- });
- // _self.onBLECharacteristicValueChange(callback); //监听特征值变化
- },
- fail: (res) => {
- uni.showToast({
- title: 'notify启动失败',
- icon: "none",
- mask: true
- });
- }
- })
- },
- //监听低功耗蓝牙设备的特征值变化。必须先启用notify接口才能接收到设备推送的notification。
- B_OnBLECharacteristicValueChange(state, context) {
- let {
- callback
- } = context;
- console.log("onBLECharacteristicValueChange success");
- if (callback) {
- callback({
- notifyCharacteristicId: state.notifyCharacteristicId,
- writeCharacteristicId: state.writeCharacteristicId
- })
- }
- uni.onBLECharacteristicValueChange(function(res) {
- let box = {};
- var resValue = BLE.ab2hext(res.value); //16进制字符串
- if (state.currentInstruction == "V" && state.showToast) {
- var resValueStr = BLE.hexToString(resValue);
- let _info = {
- type: 'version',
- instruction: 'V',
- value: resValueStr.replace(/\{|}/g, '').trim()
- }
- uni.$emit('listenerBLE', _info);
- state.currentInstruction = "";
- state.showToast = false;
- return;
- } else if (state.currentInstruction == 'M' && state.bListenerMac) {
- var resValueStr = BLE.hexToString(resValue);
- let _info = {
- type: 'mac',
- instruction: 'M',
- value: resValueStr.replace(/\{|}/g, '').trim()
- }
- uni.$emit('listenerBLE', _info);
- state.currentInstruction = "";
- state.bListenerMac = false;
- return;
- }
- //步数数据解析
- if (state.bListenerJson) {
- var resValueStr = BLE.hexToString(resValue);
- console.log(resValueStr);
- box["Json"] = resValueStr;
- uni.$emit('updateBLEDeviceJson', box);
- }
- //解析4组加速计数据
- if (state.bListenerAccArray) {
- let ms1 = BLE.hex2int(resValue.substr(2, 4));
- let min1 = BLE.hex2int(resValue.substr(6, 2));
- let s1 = BLE.hex2int(resValue.substr(8, 2));
- let ax1Str = resValue.substr(10, 4);
- let ay1Str = resValue.substr(14, 4);
- let az1Str = resValue.substr(18, 4);
- let ax1 = BLE.hexToSignedInt(ax1Str) / 32768 * 16;
- let ay1 = BLE.hexToSignedInt(ay1Str) / 32768 * 16;
- let az1 = BLE.hexToSignedInt(az1Str) / 32768 * 16;
- let ms2 = BLE.hex2int(resValue.substr(22, 4));
- let min2 = BLE.hex2int(resValue.substr(26, 2));
- let s2 = BLE.hex2int(resValue.substr(28, 2));
- let ax2Str = resValue.substr(30, 4);
- let ay2Str = resValue.substr(34, 4);
- let az2Str = resValue.substr(38, 4);
- let ax2 = BLE.hexToSignedInt(ax2Str) / 32768 * 16;
- let ay2 = BLE.hexToSignedInt(ay2Str) / 32768 * 16;
- let az2 = BLE.hexToSignedInt(az2Str) / 32768 * 16;
- let ms3 = BLE.hex2int(resValue.substr(42, 4));
- let min3 = BLE.hex2int(resValue.substr(46, 2));
- let s3 = BLE.hex2int(resValue.substr(48, 2));
- let ax3Str = resValue.substr(50, 4);
- let ay3Str = resValue.substr(54, 4);
- let az3Str = resValue.substr(58, 4);
- let ax3 = BLE.hexToSignedInt(ax3Str) / 32768 * 16;
- let ay3 = BLE.hexToSignedInt(ay3Str) / 32768 * 16;
- let az3 = BLE.hexToSignedInt(az3Str) / 32768 * 16;
- let ms4 = BLE.hex2int(resValue.substr(62, 4));
- let min4 = BLE.hex2int(resValue.substr(66, 2));
- let s4 = BLE.hex2int(resValue.substr(68, 2));
- let ax4Str = resValue.substr(70, 4);
- let ay4Str = resValue.substr(74, 4);
- let az4Str = resValue.substr(78, 4);
- let ax4 = BLE.hexToSignedInt(ax4Str) / 32768 * 16;
- let ay4 = BLE.hexToSignedInt(ay4Str) / 32768 * 16;
- let az4 = BLE.hexToSignedInt(az4Str) / 32768 * 16;
- let accArray = [{
- ax: ax1,
- ay: ay1,
- az: az1,
- ms: ms1,
- min: min1,
- s: s1
- }, {
- ax: ax2,
- ay: ay2,
- az: az2,
- ms: ms2,
- min: min2,
- s: s2
- }, {
- ax: ax3,
- ay: ay3,
- az: az3,
- ms: ms3,
- min: min3,
- s: s3
- }, {
- ax: ax4,
- ay: ay4,
- az: az4,
- ms: ms4,
- min: min4,
- s: s4
- }]
- for (let i = 0; i < accArray.length; i++) {
- let _temp = accArray[i];
- box["acc"] = {
- ax: _temp.ax,
- ay: _temp.ay,
- az: _temp.az,
- };
- box["min"] = _temp.min;
- box["s"] = _temp.s;
- box["ms"] = _temp.ms;
- uni.$emit('updateBLEDeviceData', box);
- }
- }
- //原始数据解析
- if (state.bListenerUpdate) {
- //R/L 左手还是右手
- let handle = resValue.substr(6, 2);
- let axStr = resValue.substr(8, 4);
- let ayStr = resValue.substr(12, 4);
- let azStr = resValue.substr(16, 4);
- //一个字节最大只能表示265 2个字节可以表示65536 然后你这边做一下转换 例如00 3E 3*16+14=62 ----->0.03 g
- //(真实值= AD值 /32768 * 16)
- //0.003 = 62 / 2768 * 16
- let ax = BLE.hexToSignedInt(axStr) / 32768 * 16;
- let ay = BLE.hexToSignedInt(ayStr) / 32768 * 16;
- let az = BLE.hexToSignedInt(azStr) / 32768 * 16;
- let gxStr = resValue.substr(20, 4);
- let gyStr = resValue.substr(24, 4);
- let gzStr = resValue.substr(28, 4);
- //角速度(AD值/32768 * 2000) 角速度单位是 °/s 范围是 正负2000
- let gx = BLE.hexToSignedInt(gxStr) / 32768 * 2000;
- let gy = BLE.hexToSignedInt(gyStr) / 32768 * 2000;
- let gz = BLE.hexToSignedInt(gzStr) / 32768 * 2000;
- //毫秒
- let ms = BLE.hex2int(resValue.substr(2, 4));
- //分
- let min = BLE.hex2int(resValue.substr(32, 2));
- //秒
- let s = BLE.hex2int(resValue.substr(34, 2));
- box["handle"] = BLE.hexToString(handle);
- box["acc"] = {
- ax,
- ay,
- az
- };
- box["gyro"] = {
- gx,
- gy,
- gz
- };
- box["min"] = min;
- box["s"] = s;
- box["ms"] = ms;
- //更新数据给webview,在game-play-web||game-play-sub绑定
- //后面更新数据都用此接口
- uni.$emit('updateBLEDeviceData', box);
- }
- //todo 解析跳绳模式
- if (state.bListenerHexUpdate) {
- //报头,固定
- let byte1 = resValue.substr(0, 2);
- //功能码,todo
- let byte2 = resValue.substr(2, 2);
- // 报文类型,后续区分在这里,目前是跳绳模式类型
- let byte3 = resValue.substr(4, 2);
- //报文内容,长度以 2为单位 动态变化
- let byteData = resValue.substr(6, resValue.length - 10)
- //报文按照长度2切割
- let byteArray = byteData.replace(/(\d{2})(?=(?:\d{2})+(?!\d))/g, '$1,').split(',');
- console.log("byteArray:", byteArray);
- // 校验
- let byteVerify = resValue.substr(resValue.length - 4, 2);
- // 报尾,结束
- let byteEnd = resValue.substr(resValue.length - 2, 2);
- //todo 暂时先这样触发
- if (byteArray.length == 2 && byteArray[0] != byteArray[1]) {
- if (byteArray[0] == '00') {
- state.bRopeKeyOne = 1;
- } else {
- //'01'
- state.bRopeKeyTwo = 1;
- }
- if (state.bRopeKeyOne == 1 && state.bRopeKeyTwo == 1) {
- state.bRopeKeyOne = 0;
- state.bRopeKeyTwo = 0;
- box["Rope"] = 1;
- uni.$emit('updateBLEDeviceData', box);
- }
- }
- }
- });
- },
- /**
- * 开启跳绳模式
- */
- B_OpenRopeSkipping() {
- // this.commit('onWriteBLEConnectionValue', {
- // value: "5B310101FE5D",
- // bSendHex: true,
- // bOpen: true
- // });
- console.log('B_OpenRopeSkipping', 3);
- this.commit('onWriteBLEConnectionValue', {
- value: "3"
- });
- },
- /**
- * 关闭跳绳模式
- */
- B_CloseRopeSkipping() {
- // this.commit('onWriteBLEConnectionValue', {
- // value: "5B210100FF5D",
- // bSendHex: true,
- // bOpen: false
- // });
- this.commit('onWriteBLEConnectionValue', {
- value: "4"
- });
- },
- //向低功耗蓝牙设备特征值中写入二进制数据。注意:必须设备的特征值支持 write 才可以成功调用。
- B_WriteBLECharacteristicValue(state, context) {
- let {
- value,
- retryCount,
- success,
- getFail,
- bSendHex,
- } = context;
- if (!value && value === '') {
- uni.showToast({
- title: "指令为空"
- })
- return;
- }
- let _sendData;
- if (bSendHex) {
- state.bRopeKeyTwo = 0;
- state.bRopeKeyOne = 0;
- //如果是发送16进制
- state.bListenerHexUpdate = true;
- //重置原 update
- state.bListenerUpdate = false;
- let typedArray = new Uint8Array(value.match(/[\da-f]{2}/gi).map(function(h) {
- return parseInt(h, 16)
- }))
- _sendData = typedArray.buffer;
- } else {
- state.bListenerHexUpdate = false;
- //记录一下指令
- state.currentInstruction = value;
- //V 获取版本,M 获取mac 地址
- if (value == "V")
- state.showToast = true;
- if (value == "M") {
- state.showToast = true;
- state.bListenerMac = true;
- }
- if (value == "4") {
- state.bListenerUpdate = false;
- }
- if (value == "3") {
- if (state.bListenerUpdate) {
- uni.showToast({
- title: "原始数据已开启"
- })
- return;
- }
- state.bListenerUpdate = true;
- }
- if (value == "6") {
- // state.bListenerJson = false;
- state.bListenerAccArray = false;
- }
- if (value == "5") {
- // if (state.bListenerJson) {
- // uni.showToast({
- // title: "步数数据已开启"
- // })
- // return;
- // }
- // state.bListenerJson = true;
- if (state.bListenerAccArray) {
- uni.showToast({
- title: "加速计组数据已开启"
- })
- return;
- }
- state.bListenerAccArray = true;
- }
- _sendData = BLE.str2ab(value);
- }
- console.log("currentInstruction:", state.currentInstruction, value, state.bListenerUpdate, state
- .bListenerMac,
- state.bListenerHexUpdate);
- console.log("state.deviceId:", state.deviceId, state.serviceId, state.writeCharacteristicId);
- uni.writeBLECharacteristicValue({
- deviceId: state.deviceId,
- serviceId: state.serviceId,
- // 这里的 characteristicId 需要在 getBLEDeviceCharacteristics 接口中获取
- characteristicId: state.writeCharacteristicId,
- // 这里的value是ArrayBuffer类型
- value: _sendData,
- success: (res) => {
- console.log('writeBLECharacteristicValue success', res.errMsg, value,
- retryCount);
- if (success) {
- success(res);
- }
- },
- fail: (fail) => {
- console.log(fail)
- //重新写入
- if (retryCount > 0) {
- console.log("writeBLECharacteristicValue Rewrite ===================>" +
- value + " == " + retryCount);
- retryCount--;
- setTimeout(() => {
- this.commit("B_WriteBLECharacteristicValue", {
- value,
- retryCount,
- success,
- getFail
- });
- }, 300);
- }
- if (getFail) {
- getFail(fail);
- }
- }
- })
- },
- /**
- * 断开蓝牙连接
- */
- B_CloseBLEConnection(state, context) {
- let {
- deviceId,
- success = null
- } = context;
- uni.closeBLEConnection({
- deviceId,
- success: res => {
- if (success)
- success();
- },
- fail: (fail) => {
- console.log("关闭蓝牙失败", fail);
- }
- });
- },
- //获取手机中蓝牙已匹配的设备
- B_GetBondedDevices(state, context) {
- // console.log("getBondedDevices ====>");
- let {
- success = null,
- deviceId = null
- } = context;
- //Android
- function android_bluetooth_list(deviceName, deviceId, count, callback) {
- console.log("===》调用android_bluetooth_list count:", count);
- var main = plus.android.runtimeMainActivity();
- var BluetoothAdapter = plus.android.importClass("android.bluetooth.BluetoothAdapter");
- var BAdapter = BluetoothAdapter.getDefaultAdapter();
- var Context = plus.android.importClass("android.content.Context");
- var lists = BAdapter.getBondedDevices();
- plus.android.importClass(lists);
- var len = lists.size();
- // var BluetoothManager = plus.android.importClass("android.bluetooth.BluetoothManager");
- // var BluetoothDevice = plus.android.importClass("android.bluetooth.BluetoothDevice");
- // var ProfileType = plus.android.importClass("android.bluetooth.ProfileType");
- // plus.android.importClass(BluetoothManager);
- // plus.android.importClass(BluetoothDevice);
- // plus.android.importClass(ProfileType);
- // var UUID = plus.android.importClass("java.util.UUID");
- // var uuid = UUID.fromString("0000FFF0-0000-1000-8000-00805F9B34FB");
- // var gDevice = BAdapter.getRemoteDevice("C5:5C:19:04:00:30");
- // plus.android.importClass(gDevice);
- // var bluetoothSocket = gDevice.createInsecureRfcommSocketToServiceRecord(uuid);
- // plus.android.importClass(bluetoothSocket);
- // console.log("是否连接:",bluetoothSocket.isConnected());
- // var deviceLists = BluetoothManager.getConnectedDevices();
- // plus.android.importClass(deviceLists);
- // console.log("deviceLists.len=" + deviceLists.size());
- console.log("getBondedDevices.len=", len, "deviceId:", deviceId);
- //测试start===》 如果没有配对的设备,重新获取
- // count--;
- // if(count >0){
- // setTimeout(()=>{
- // android_bluetooth_list("BGBox", deviceId, count, callback);
- // },1000)
- // return;
- // }
- //测试end
- if (len == 0) {
- //如果没有配对的设备,重新获取
- count--;
- if (count > 0) {
- setTimeout(() => {
- android_bluetooth_list("BGBox", deviceId, count, callback);
- }, 2000)
- } else {
- if (callback)
- callback(null);
- }
- } else {
- var iterator = lists.iterator();
- let temp = null;
- plus.android.importClass(iterator);
- while (iterator.hasNext()) {
- var d = iterator.next();
- plus.android.importClass(d);
- // if (d.getName().indexOf(deviceName) > -1)
- // console.log(d.getAddress(), deviceId);
- if (deviceId == null && d.getName().indexOf(deviceName) > -1) {
- let typeEnum = {
- 0: 'Unknown',
- 1: 'Classic',
- 2: 'Le',
- 3: 'Dual'
- };
- let bondStateEnum = {
- 10: 'None',
- 11: 'Bonding',
- 12: 'Bonded'
- };
- temp = {
- name: d.getName(),
- address: d.getAddress(),
- type: {
- 'value': d.getType(),
- 'name': typeEnum[d.getType()]
- },
- bondState: {
- 'value': d.getBondState(),
- 'name': bondStateEnum[d.getBondState()]
- }
- }
- console.log("获取到设备,并且跳出:", temp);
- break;
- } else if (d.getAddress() == deviceId) {
- // console.log(d.getName());
- // console.log(d.getAddress());
- // Classic 1
- // Dual 3
- // Le 2
- // Unknown 0
- // console.log(d.getType());
- // Bonded 12
- // Bonding 11 Indicates bonding (pairing) is in progress with the remote device.
- // None 10
- // console.log(d.getBondState());
- let typeEnum = {
- 0: 'Unknown',
- 1: 'Classic',
- 2: 'Le',
- 3: 'Dual'
- };
- let bondStateEnum = {
- 10: 'None',
- 11: 'Bonding',
- 12: 'Bonded'
- };
- temp = {
- name: d.getName(),
- address: d.getAddress(),
- type: {
- 'value': d.getType(),
- 'name': typeEnum[d.getType()]
- },
- bondState: {
- 'value': d.getBondState(),
- 'name': bondStateEnum[d.getBondState()]
- }
- }
- console.log("获取到设备,并且跳出:", temp);
- break;
- }
- }
- // return temp;
- if (temp == null && count > 0) {
- count--;
- setTimeout(() => {
- android_bluetooth_list("BGBox", deviceId, count, callback);
- }, 2000)
- } else {
- if (callback)
- callback(temp);
- }
- }
- }
- function ios_bluetooth_list(deviceName, callback) {
- //原生操作 首先需要通过 uni.requireNativePlugin("ModuleName") 获取 module
- var SLABluetoothModule = uni.requireNativePlugin("SLABluetoothUniPlugin-SLAModule")
- if (SLABluetoothModule) {
- SLABluetoothModule.getConnectionDevicesAsync({
- serviceUUIDs: "FFF0"
- }, (res) => {
- console.log("***************getConnectionDevicesAsync:", JSON.stringify(res));
- if (res.data) {
- console.log("获取到对应的匹配设备!");
- let typeEnum = {
- 0: 'Unknown',
- 1: 'Classic',
- 2: 'Le',
- 3: 'Dual'
- };
- let bondStateEnum = {
- 10: 'None',
- 11: 'Bonding',
- 12: 'Bonded'
- };
- let temp = {
- name: res.data[0].name,
- address: res.data[0].identifier,
- type: {
- 'value': 2,
- 'name': typeEnum[2]
- },
- bondState: {
- 'value': 12,
- 'name': bondStateEnum[12]
- }
- }
- if (callback) {
- callback({
- "device": temp
- });
- }
- } else {
- console.log("匹配设备数据不存在!");
- if (callback) {
- callback({
- "device": null
- });
- }
- }
- })
- } else {
- console.error("不存在SLABluetoothModule ios 插件!");
- if (callback) {
- callback({
- "device": null
- });
- }
- }
- }
- let device = null;
- let _count = 3;
- switch (plus.os.name) {
- case "Android":
- // Android平台: plus.android.*
- android_bluetooth_list("BGBox", deviceId, _count, (data) => {
- device = data;
- console.log("android getBondedDevices 匹配的对象======>", device)
- if (device != null) {
- state.bPhoneMatched = true;
- } else {
- state.bPhoneMatched = false;
- }
- if (success) {
- success(device);
- }
- });
- break;
- case "iOS":
- // iOS平台: plus.ios.*
- ios_bluetooth_list("BGBox", (res) => {
- device = res.device
- if (success) {
- success(device);
- }
- console.log("ios getBondedDevices 匹配的对象======>", device)
- if (device != null) {
- state.bPhoneMatched = true;
- } else {
- state.bPhoneMatched = false;
- }
- });
- break;
- default:
- // 其它平台
- if (success) {
- success(device);
- }
- break;
- }
- // if (success) {
- // success(device);
- // }
- },
- B_OpenBLESetting() {
- function android_bluetooth_setting() {
- var main = plus.android.runtimeMainActivity(); //获取activity
- var Intent = plus.android.importClass('android.content.Intent');
- var Settings = plus.android.importClass('android.provider.Settings');
- var intent = new Intent(Settings.ACTION_BLUETOOTH_SETTINGS); //可设置表中所有Action字段
- main.startActivity(intent);
- }
- function ios_bluetooth_setting() {
- // var UIApplication = plus.ios.import("UIApplication");
- // var application2 = UIApplication.sharedApplication();
- // var NSURL2 = plus.ios.import("NSURL");
- // var setting2 = NSURL2.URLWithString("app-settings:");
- // application2.openURL(setting2);
- // plus.ios.deleteObject(setting2);
- // plus.ios.deleteObject(NSURL2);
- // plus.ios.deleteObject(application2);
- // plus.runtime.openURL({
- // action: 'App-Prefs:root=Bluetooth'
- // }, function(e) {
- // console.log(JSON.stringify(e));
- // });
- plus.runtime.launchApplication({
- action: 'App-Prefs:root=Bluetooth'
- }, function(e) {
- console.log(JSON.stringify(e));
- });
- }
- let device = null;
- switch (plus.os.name) {
- case "Android":
- // Android平台: plus.android.*
- android_bluetooth_setting();
- break;
- case "iOS":
- // iOS平台: plus.ios.*
- ios_bluetooth_setting();
- break;
- default:
- // 其它平台
- break;
- }
- },
- //获取versionCode状态,用于处理特定的信息显示
- getVersionCode(state) {
- let self = this;
- reqUtil.requestData(config.URL.GETVERSIONCODE, {
- code: state.versionCode
- }).then(res => {
- console.log('获取GETVERSIONCODE =====', res);
- if (res.code == 0) {
- state.versionCodeState = res.data;
- }
- },
- e => {
- console.log(e)
- });
- },
- /**
- * 任务其他操作
- */
- //获取关卡信息
- getLevelList(state, callback) {
- let self = this;
- reqUtil
- .requestData(config.URL.GETLEVELJUMPLIST, {})
- .then(
- res => {
- if (res.code == 0) {
- // console.log('GETLEVELJUMPLIST:' + JSON.stringify(res.data.singlePerson));
- state.singlePersonList = res.data.singlePerson;
- state.multiPersonList = res.data.multiPerson;
- //获取到数据时候,重置actionJump
- self.commit('resetActionJumpTask');
- if (callback)
- callback();
- }
- },
- e => {
- console.log(e);
- }
- );
- },
- /**
- * 获取钱包信息
- * @param {Object} state
- * @param {Object} callback
- */
- getUserWallets(state, callback) {
- reqUtil
- .requestData(config.URL.USERGETWALLETINFO, {})
- .then(
- res => {
- if (res.code == 0) {
- console.log('USERGETWALLETINFO:' + JSON.stringify(res.data));
- state.cGold = res.data.gold;
- state.cDiamond = res.data.diamond;
- if (callback)
- callback();
- }
- },
- e => {
- console.log(e);
- }
- );
- },
- setGoldAndDiamond(state, context) {
- let {
- gold,
- diamond
- } = context;
- state.cGold = gold;
- state.cDiamond = diamond;
- },
- /**
- * 抽屉和弹出框
- */
- hideDrawerById(state, context) {
- // let { id } = context;
- //personal-drawer
- uni.getSubNVueById('personal-drawer').hide('slide-in-left', 200);
- },
- showDrawerById(state, context) {
- // let { id } = context;
- //personal-drawer
- uni.getSubNVueById('personal-drawer').show('slide-in-left', 200);
- },
- showPopupById(state, context) {
- let {
- type,
- item
- } = context;
- console.log(type, item);
- switch (type) {
- case 'levelReward':
- uni.$emit('reward-popup', {
- title: '奖励',
- content: '',
- type: type,
- item: {
- gold: item.rewardGold,
- diamond: item.rewardDiamond,
- honor: item.rewardHonor
- },
- operationItem: item
- });
- break;
- case 'prompt':
- // 向 popup 传递消息
- uni.$emit('reward-popup', {
- title: '奖励',
- content: '',
- type: type,
- item: {
- gold: item.rewardGold,
- diamond: item.rewardDiamond,
- honor: item.rewardHonor
- },
- operationItem: item
- });
- break;
- case 'unlock':
- // 向 popup 传递消息
- uni.$emit('reward-popup', {
- title: '解锁关卡',
- content: '',
- type: type,
- item: {
- consumeGold: item.consumeGold,
- consumeDiamond: item.consumeDiamond
- },
- operationItem: item
- });
- break;
- case 'signIn':
- this.commit("onSendSignInPopup",context);
- break;
- case 'pkFinish':
- // 向 popup 传递消息
- uni.$emit('reward-popup', {
- title: 'pk完成',
- content: '',
- type: type,
- item: item,
- operationItem: item
- });
- break;
- default:
- uni.showToast({
- title: 'showPopup类型为空',
- icon: 'none'
- })
- break;
- }
- // #ifdef APP-PLUS
- //personal-popup
- const subNVue = uni.getSubNVueById('personal-popup')
- subNVue.show('zoom-out', 250)
- // #endif
- },
- showGuideById(state, context) {
- let {
- type,
- item
- } = context;
- uni.$emit('guide-popup', {
- title: 'guide',
- content: '定制guide',
- type: type,
- item: item,
- operationItem: item
- });
- const subNVue = uni.getSubNVueById('personal-guide')
- subNVue.show('fade-in', 250)
- },
- getSignInList(state, callback) {
- reqUtil
- .requestData(config.URL.GETSIGNINLIST, {})
- .then(
- res => {
- if (res.code == 0) {
- console.log('GETSIGNINLIST:' + JSON.stringify(res.data));
- state.signInList = res.data.signInList;
- state.isSignIn = res.data.isSignIn;
- if (callback)
- callback(res.data);
- }
- },
- e => {
- console.log(e);
- }
- );
- },
- onUserSignIn(state, callback) {
- reqUtil
- .requestData(config.URL.USERSIGNIN, {})
- .then(
- res => {
- console.log('USERSIGNIN:' + JSON.stringify(res));
- if (res.code == 0) {
- state.cGold = res.data.userGold;
- state.cDiamond = res.data.userDiamond;
- uni.showToast({
- title: '签到成功',
- mask: true
- })
- //根据dayType 计算最近一个flag
- for(let i=0;i<state.signInList.length;i++){
- if(res.data.signIn.dayType == state.signInList[i].dayType){
- state.signInList[i] = Object.assign({},state.signInList[i],res.data.signIn);
- break;
- }
- }
- state.isSignIn = true;
- if (callback)
- callback(res.data);
- } else if (res.code == 901) {
- uni.showToast({
- title: '今天已签到',
- mask: true
- })
- }
- },
- e => {
- console.log(e);
- }
- );
- },
- onSendSignInPopup(state,context){
- let {
- type,
- item
- } = context;
- let _reward = [{
- name: 'gold',
- width: 28,
- height: 28,
- url: '../../../static/common/sideBar/sGold.png',
- selectedUrl: '../../../static/common/subNVue/sign/sign-grey-gold@2x.png',
- explain: '',
- value: 20,
- isSelect: false
- },
- {
- name: 'diamond',
- width: 28,
- height: 28,
- url: '../../../static/common/sideBar/sDiamond.png',
- selectedUrl: '../../../static/common/subNVue/sign/sign-grey-diamond@2x.png',
- explain: '',
- value: 20,
- isSelect: false
- }
- ];
-
- let list = state.signInList;
- let lists = [];
- for (let i = 0; i < list.length; i++) {
- if (0 !== list[i].gold) {
- lists.push(Object.assign({}, _reward[0], {
- value: list[i].gold
- }))
- } else if (0 !== list[i].diamond) {
- lists.push(Object.assign({}, _reward[1], {
- value: list[i].diamond
- }))
- }
- lists[i].isSelect = list[i].flag == 1?true:false;
- }
-
- // 向 popup 传递消息
- uni.$emit('reward-popup', {
- title: '每日签到',
- content: '',
- type: type,
- lists: lists,
- isSignIn:state.isSignIn
- });
- }
- }
- })
- export default store
|