123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936 |
- import httpRequestApi from '../../utils/APIClient';
- const aiengine = require('../../utils/ChivoxAiEngine')
- const sha1 = require('../../utils/sha1');
- const app = getApp()
- import {
- formatDate
- } from '../../utils/util';
- Page({
- data: {
- title: '',
- id: '',
- img: '',
- fullScreenBtn: false,
- playBtn: true,
- gesture: true,
- muted: false,
- gesture: false,
- centerBtn: true,
- recordFlag: 0,
- recordSource: '',
- videoCtr: 'recordingVideoEnd',
- btnFlag: false,
- btnImgFlag: false,
- microphonePng: '../../static/index/microphone.png',
- recordingGif: '../../static/index/readingNow.gif',
- videoUrl: '',
- readingText: '',
- videoList: [],
- pageNo: 1,
- totalSize: 0,
- nextMargin: getApp().globalData.nextMargin,
- lowerThresHold: 100,
- isVideoListShow: true,
- overall: '',
- integrity: '',
- tone: '',
- fluency: '',
- accuracy: '',
- star: [0, 0, 0, 0, 0],
- ifTextShow: true,
- ifScoreDialogShow: false,
- ifScoreShow: false,
- statusbarobj: {
- isshowbtn: false,
- title: "小学语文朗读配音",
- },
- isScroll: true,
- noMoreWork: false,
- authHide: true,
- authImg: '',
- isIOS: app.globalData.isIOS,
- payPrice: ''
- },
- onLoad: function (option) {
- console.log(option);
- this.videoCtx = null;
- const uid = wx.getStorageSync('uid')
- this.getClassInfo(option.id);
-
- },
- getClassInfo: function (id) {
- httpRequestApi.getClassDetail(id).success(res => {
- console.log('课程信息', res)
- let reg = /\\n/g
- this.setData({
- title: res.data.data.userRead.title,
- videoUrl: res.data.data.userRead.videoPath,
- videoPathTemp: res.data.data.userRead.videoPath,
- originVideo: res.data.data.userRead.originVideo,
- img: res.data.data.userRead.iconImg,
- id: res.data.data.userRead.id,
- readingText: res.data.data.userRead.lessonText,
- grade: res.data.data.userRead.grade,
- exampleId: res.data.data.userRead.exampleId,
- summary: res.data.data.userRead.summary,
- coverImg: res.data.data.userRead.coverImg,
- shareImg: res.data.data.userRead.shareImg,
- isActivityRead: res.data.data.isActivityRead
- })
-
- if(res.data.data.isActivityRead){
- httpRequestApi.postActEvent('LESSON').success(res=>{
- console.log('示范朗读页',res)
- })
- }
- this.getReadInfo(id)
- httpRequestApi.userIntoPage('pages/reading/reading', '朗读页面').success((res) => {
- })
- })
- },
- onHide: function () {
- console.log('onhide')
- if (this.data.btnImgFlag) {
- this.recorderManager.stop();
- }
- if (this.innerAudioContext) {
- this.innerAudioContext.stop();
- }
-
- this.setData({
- recordFlag: 0
- })
- },
- onUnload: function () {
- console.log('onUnload')
- if (this.data.btnImgFlag) {
- this.recorderManager.stop();
- }
- if (this.innerAudioContext) {
- this.innerAudioContext.stop();
- }
- },
- onShow: function () {
- this.videoCtx = wx.createVideoContext('myVideo', this);
- let data = requirePlugin("myPlugin");
- const obj = {
- appid: 'a415',
- userid: wx.getStorageSync('uid'),
- getEvalMessage: (res) => {
- this.getRecordScore(res)
-
- },
- recorderCallback: (type, data) => {
-
- this.ssRecorderCallback(type, data)
- }
- }
-
- this.recorderManager = wx.getRecorderManager();
- this.recorderManager.onStop((res) => {
-
-
-
-
-
- this.videoCtx.seek(0);
- this.videoCtx.stop();
- console.log('recorder stop', res)
- const recordFile = res.tempFilePath;
- this.setData({
- recordFlag: 0,
- recordSource: recordFile,
- btnFlag: true,
- btnImgFlag: false
- })
- this.wsEngine.stop({
- success: () => {
- console.log('====== wsEngine stop success ======');
- wx.showLoading({
- title: '作品评测中',
- mask: true
- })
-
- },
- fail: (res) => {
- console.log("====== wsEngine stop fail ======");
- console.log(JSON.stringify(res));
-
- },
- complete: () => {
-
-
- console.log("====== wsEngine stop complete ======");
- }
- });
- })
- this.recorderManager.onStart(() => {
-
- this.setData({
- btnImgFlag: true,
- btnFlag: false
- })
- console.log('recorder start')
- });
-
- this.recorderManager.onFrameRecorded((res) => {
- const {
- frameBuffer
- } = res
- console.log('frameBuffer.byteLength', frameBuffer.byteLength)
-
- this.wsEngine.feed({
- data: frameBuffer,
- success: () => {
-
- console.log('feed success.')
- },
- fail: (res) => {
-
- console.log('feed fail:', JSON.stringify(res))
- },
- complete: () => {
-
- }
- });
- });
- },
- ssRecorderCallback: function (type, data) {
- console.log('录音测评监控回调', type)
- console.log('录音测评监控回调', data)
-
- if (type === 'onStart') {
- this.setData({
- btnImgFlag: true,
- btnFlag: false
- })
- console.log('recorder start')
- }
- if (type === 'onStop') {
- this.videoCtx.stop();
- this.setData({
- recordFlag: 0,
- recordSource: data.tempFilePath,
- btnFlag: true,
- btnImgFlag: false
- })
- console.log('recorder start')
- }
- },
-
- recordingVideoEnd: function () {
- console.log(this.data.videoCtr)
- console.log('recordingVideoEnd');
-
- if (this.data.recordFlag === 0) {
-
- this.playingVideoEnd();
- return;
- }
-
- if (this.data.recordFlag === 1) {
- this.recordStop();
- }
- },
-
- playingVideoEnd: function () {
- console.log('playingVideoEnd')
-
- },
-
- audioRecord: function () {
- console.log('111111111111111recordFlag', this.data.recordFlag)
-
- const isVip = wx.getStorageSync('vip');
- console.log('判断',!isVip && !this.data.isActivityRead)
- if (!isVip && !this.data.isActivityRead) {
- const imgName = this.data.isIOS ? 'ios_read' : 'android_read';
- if(!this.data.isIOS) {
- this.setData({
- payPrice: wx.getStorageSync('price')
- })
- }
- this.setData({
- authHide: !this.data.authHide,
- authImg: `http://reader-wx.ai160.com/images/reader/pay/${imgName}.png`
- })
- } else {
- if (this.recorderManager) {
- this.recorderManager.stop();
- }
- if (this.innerAudioContext) {
- this.innerAudioContext.stop();
- }
- if (this.data.recordFlag === 0) {
- this.wsEngine = aiengine.createWsEngine({});
- this.wsEngine.onResult(res => {
- wx.hideLoading();
- this.getRecordScore(res)
- })
- this.wsEngine.onErrorResult(res => {
- wx.hideLoading();
- console.log('驰声createWsEngine失败', res);
- })
- this.videoComplete();
-
- return;
- }
-
- if (this.data.recordFlag === 1) {
- wx.showLoading({
- title: '作品转码中',
- mask: true
- })
- this.recordStop();
- }
- }
- },
-
-
- recordStart: function () {
- console.log('录音开始');
- const options = {
- duration: 600000,
- sampleRate: 44100,
- numberOfChannels: 1,
- encodeBitRate: 192000,
- format: 'mp3',
- frameSize: 50
- }
- this.recorderManager.start(options);
-
-
-
-
-
-
-
- let timeStamp = new Date().getTime()
- let sig = sha1(`16075689600000da${timeStamp}caa8e60da6042731c230fe431ac9c7fd`)
- console.log('加密串', sig)
-
- let app = {
- applicationId: '16075689600000da',
- sig,
- alg: 'sha1',
- timestamp: timeStamp + '',
- userId: wx.getStorageSync('uid')
- }
- console.log('app数据', app)
- let lessonText = this.data.readingText;
- console.log('课文课文课文', lessonText)
- this.wsEngine.start({
- app,
- request: {
- coreType: "cn.pred.raw",
- refText: lessonText,
- rank: 100,
- attachAudioUrl: 1,
- result: {
- details: {
- gop_adjust: 1
- }
- }
- },
- audio: {
- audioType: "mp3",
- channel: 1,
- sampleBytes: 2,
- sampleRate: 16000
- },
- success: (res) => {
-
- console.log('驰声start成功', res)
- },
- fail: (res) => {
-
- console.log('驰声start失败', res)
- }
- })
- },
- getMicAuth() {
- let _this = this;
- wx.getSetting({
- success(res) {
- if (res.authSetting['scope.record']) {
- _this.videoComplete();
- } else {
- _this.getMicSetAuth();
- return;
- }
- }
- })
- },
- getMicSetAuth() {
- let _this = this;
- wx.authorize({
- scope: 'scope.record',
- success() {
-
- _this.audioRecord();
- },
- fail() {
- wx.showModal({
- title: '录音前请打开麦克风权限',
- content: '',
- confirmText: '我知道了',
- showCancel: false,
- success(res) {
-
- wx.openSetting({
- success(res) {
- console.log('跳转到设置页', res.authSetting)
-
-
-
-
- }
- })
- }
- })
- }
- })
- },
-
- recordStop: function () {
- this.setData({
- muted: false
- })
-
- console.log('录音结束')
- this.recorderManager.stop();
- wx.hideLoading()
- },
-
- getRecordScore(res) {
- console.log('测评结果', JSON.stringify(res))
- const result = res.result;
- const overall = result.overall;
- const integrity = result.integrity;
- const tone = result.tone;
-
- const accuracy = result.overall;
- const fluency = result.fluency.overall;
- let starArray = [];
- let myOverall = integrity * 0.3 + accuracy * 0.5 + fluency * 0.1 + tone * 0.1;
-
- console.log('我的总分', myOverall)
- if (myOverall < 5) {
- starArray = [0, 0, 0, 0, 0]
- } else if (5 <= myOverall && myOverall < 30) {
- starArray = [1, 0, 0, 0, 0]
- } else if (30 <= myOverall && myOverall < 50) {
- starArray = [1, 1, 0, 0, 0]
- } else if (50 <= myOverall && myOverall < 70) {
- starArray = [1, 1, 1, 0, 0]
- } else if (70 <= myOverall && myOverall < 90) {
- starArray = [1, 1, 1, 1, 0]
- } else if (90 <= myOverall) {
- starArray = [1, 1, 1, 1, 1]
- }
-
-
-
-
-
-
-
-
-
-
-
-
- this.setData({
- overall,
- integrity,
- tone,
- accuracy,
- fluency,
- ifScoreDialogShow: true,
- star: starArray
- })
- },
- closeScoreDialog() {
- this.setData({
- ifScoreDialogShow: false,
- ifScoreShow: true,
- ifTextShow: false
- })
- },
-
- audioPlay: function () {
-
- if (this.innerAudioContext) {
- this.innerAudioContext.stop();
- this.videoCtx.stop();
- }
- this.innerAudioContext = wx.createInnerAudioContext();
- this.innerAudioContext.src = this.data.recordSource;
- console.log('音频路径', this.data.recordSource)
- this.setData({
- videoUrl: this.data.videoUrl,
- muted: true
- })
- console.log(this.innerAudioContext.src);
- this.videoCtx.play();
- this.innerAudioContext.play();
-
- },
- exampleVideoPlay: function () {
- if (this.data.videoPathTemp == this.data.videoUrl) {
-
- httpRequestApi.playLogReport({
- userReadId: this.data.id,
- playStopTime: 1000
- }).success(res => {
- console.log('播放记录', res)
- })
- }
- },
- videoComplete: function () {
- this.setData({
- recordFlag: 1,
- videoUrl: this.data.originVideo,
- centerBtn: false,
- playBtn: false,
- isVideoListShow: false,
- muted: false,
- ifTextShow: true,
- ifScoreShow: false
- }, () => {
- console.log('播放视频播放视频播放视频')
-
- this.videoCtx.stop();
- this.videoCtx.play();
- this.recordStart();
- })
- },
-
- upload: function () {
- if (this.videoCtx) {
- this.videoCtx.stop();
- }
- if (this.data.audioPlaying) {
-
- this.setData({
- audioPlaying: false
- })
- }
- wx.showLoading({
- title: '作品上传中',
- mask: true
- })
- const recordSource = this.data.recordSource;
- wx.uploadFile({
-
- url: 'https://reader-api.efunbox.cn//file/upload',
- filePath: recordSource,
- name: '朗读录音',
- header: {
- uid: wx.getStorageSync('uid')
- },
- success: (res) => {
- const formateRes = JSON.parse(res.data);
- let audioPath = formateRes.data;
- console.log('音频上传成功')
- this.shareWorks(audioPath);
- }
- })
- },
- shareWorks: function (audio) {
- const data = {
- "lessonId": this.data.id,
- "originVideo": this.data.videoUrl,
- "audioPath": audio,
- "title": this.data.title,
- "iconImg": this.data.img,
- "summary": this.data.summary,
- "productId": this.data.productId,
- "grade": this.data.grade,
- "exampleId": this.data.exampleId,
- "coverImg": this.data.coverImg,
- "shareImg": this.data.shareImg
- };
- httpRequestApi.postWork(data).success(res => {
- wx.hideLoading({
- success: () => {
- wx.showToast({
- title: '作品已上传正在审核中',
- icon: 'none',
- duration: 1000,
- success: () => {
- console.log('上传成功', res);
- if (res.data.count > 0) {
- this.setData({
- flowerNum: res.data.count
- })
- this.flowerAnimationHandler();
- }
- const _data = this.data;
- const scoreData = {
- "userReadId": res.data.data.id,
- "complete": _data.integrity,
- "accuracy": _data.accuracy,
- "speed": _data.fluency,
- "intonation": _data.tone,
- "score": _data.overall
- }
-
- httpRequestApi.postWorksScore(scoreData).success(res => {
- console.log(res)
- });
- const pages = getCurrentPages();
- const prevPage = pages[pages.length - 2];
- prevPage.setData({
-
- fromReading: true
- }, () => {
- wx.navigateBack({
- delta: 1
- })
- })
- }
- })
- }
- });
- }).fail(res => {
- wx.hideLoading({
- success: () => {
- wx.showToast({
- title: '上传超时',
- icon: 'fail',
- duration: 1000
- })
- }
- });
- })
- },
-
- getReadInfo: function (id, pageNo, pageSize) {
-
- const data = {
- exampleId: this.data.id || id,
- pageNo: this.data.pageNo,
- pageSize: 3,
- type: 'READ'
- };
- httpRequestApi.getClassRead(data).success(res => {
- const readInfo = res.data.data.list;
- console.log(res)
- readInfo.forEach(item => {
- const temp = {};
- temp.title = item.userRead ? item.userRead.title : '';
- temp.img = item.userRead.iconImg;
- temp.plays = item.userRead.playAmount ? item.userRead.playAmount : 0;
- temp.likes = item.userRead.likeAmount ? item.userRead.likeAmount : 0;
- temp.shareAmount = item.userRead.shareAmount;
- temp.favoritesAmount = item.userRead.favoritesAmount;
- temp.commentAmount = item.userRead.commentAmount ? item.userRead.commentAmount : 0;
- temp.classId = item.userRead.exampleId;
- temp.time = formatDate(item.userRead.gmtCreated, 3);
- temp.avatar = item.user ? item.user.avatar : '';
- temp.uid = item.user ? item.user.uid : '';
- temp.url = item.userRead.videoPath;
- temp.isLike = item.isLike;
-
- temp.nickName = item.user ? item.user.wechatName : '';
- temp.id = item.userRead.id;
- temp.noReading = true;
- temp.isFans = item.isFans ? true : item.user.uid === this.uid ? true : false;
- temp.coverImg = item.userRead.coverImg;
- temp.videoShow = false;
- temp.grade = item.userRead.grade;
- temp.type = item.userRead.type;
- temp.shareImg = item.userRead.shareImg;
- item.isActivity && (temp.activity = true);
-
-
- this.data.videoList.push(temp);
- });
- this.setData({
- videoList: this.data.videoList,
- totalSize: res.data.data.totalSize,
- noMoreWork: readInfo.length <= 0 ? true : false
- })
- });
- },
-
- commentTap: function (e) {
- console.log('点击评论区', e)
- if (e.target.dataset.type === 'blank') {
- if (this.data.commentShow && this.data.commentId) {
- httpRequestApi.getClassDetail(this.data.commentId).success(res => {
- console.log('评论回显', res.data.data.userRead.commentAmount)
- let str = `videoList[${this.data.commentIndex}].commentAmount`;
- this.setData({
- [str]: res.data.data.userRead.commentAmount
- })
- })
- }
- this.setData({
- commentShow: false
- })
- }
- },
- scrollToLower: function (e) {
- console.log('滑动到底部', e)
- this.setData({
- pageNo: this.data.pageNo + 1
- }, () => {
- this.getReadInfo()
- })
- },
- onReachBottom: function (e) {
- console.log('滑动到底部', e)
- this.setData({
- pageNo: this.data.pageNo + 1
- }, () => {
- this.getReadInfo()
- })
- },
- scrollToUpper: function (e) {
- console.log('滑动到顶部', e)
- },
-
- openComment: function (e) {
- console.log('id', e.detail.activeId)
- this.setData({
- commentShow: !this.data.commentShow,
- commentId: e.detail.activeId,
- commentIndex: e.detail.activeIndex
- });
- },
- goToReading: function (e) {
- this.setData({
- pageNo: 1,
- videoList: []
- })
- const id = e.detail.activeId ? e.detail.activeId : e.currentTarget.dataset.id;
- this.getClassInfo(id)
- },
- onShareAppMessage: function (res) {
- console.log('点击分享按钮', res)
- console.log('onShareAppMessage', this.data.shareTitle)
- console.log('onShareAppMessage', this.data.shareId)
- console.log('onShareAppMessage', this.data.shareImg)
- if (res.from === 'button') {
- return {
- title: '请欣赏我的课文朗读作品,点赞+评论。',
- path: `/pages/index/index?readId=${this.data.shareId}&activity=${this.data.ifTapActivity}`,
- imageUrl: this.data.shareImg
- }
- } else {
- return {
- title: '课文朗读,从未如此有趣。',
- path: '/pages/index/index',
- }
- }
- },
- touchMove: function () {
- return
- },
- openShare: function (e) {
- console.log('用户点击分享按钮回调', e)
- this.setData({
- shareTitle: e.detail.currentTarget.dataset.title,
- shareId: e.detail.currentTarget.dataset.id,
- shareImg: e.detail.currentTarget.dataset.shareimg,
- ifTapActivity: e.detail.currentTarget.dataset.activity
- })
- },
- onPlay: function (e) {
-
- console.log('视频播放视频播放')
- if (this.videoCtx) {
- this.videoCtx.stop();
- } else {
- this.videoCtx = wx.createVideoContext('myVideo', this);
- this.videoCtx.stop();
- }
- },
- collectTap: function (e) {
- const index = e.detail.index;
- let str = `videoList[${index}].isFavorite`;
- let str2 = `videoList[${index}].favoritesAmount`;
- let favoritesAmount = e.detail.isCollect ? this.data.videoList[index].favoritesAmount + 1 : this.data.videoList[index].favoritesAmount - 1
- this.setData({
- [str]: e.detail.isCollect,
- [str2]: favoritesAmount
- })
- },
- likeTap: function (e) {
- console.log('点赞', e)
- const index = e.detail.index;
- let likeStr = `videoList[${index}].isLike`;
- let likeNumStr = `videoList[${index}].likes`;
- this.setData({
- [likeStr]: true,
- [likeNumStr]: this.data.videoList[index].likes + 1
- })
- },
- flowerAnimationHandler: function () {
- this.flowerBox = this.selectComponent("#flower-toast");
- console.log('this.flower', this.flowerBox)
- this.flowerBox.comeOut();
- },
-
- inputFocus(e) {
- this.setData({
- isScroll: false
- })
- this.triggerEvent('inputFocus');
- },
-
- inputBlur(e) {
- this.setData({
- isScroll: true
- })
- this.triggerEvent('inputBlur');
- },
- addShareAmount: function (e) {
- console.log('+++++1', e)
- let str = `videoList[${e.detail.index}].shareAmount`;
- this.setData({
- [str]: this.data.videoList[e.detail.index].shareAmount + 1
- })
- },
-
- goToAuth() {
- if (!wx.getStorageSync('message')) {
- wx.requestSubscribeMessage({
- tmplIds: ['KJ0YtcAacJNSXDBsE27JXqoaFrcJ1-N6Jcu85yTtQuY',
- '-2ZZpWFoyKvAtX1HwEIQLQ92LnN8cryamB94LqLGo98'],
- success: (res) => {
- console.log(res)
- if (res['KJ0YtcAacJNSXDBsE27JXqoaFrcJ1-N6Jcu85yTtQuY'] === 'reject') {
- console.log('用户不同意订阅')
- wx.setStorageSync('message', false)
- } else if(res['KJ0YtcAacJNSXDBsE27JXqoaFrcJ1-N6Jcu85yTtQuY'] === 'accept') {
- console.log('订阅成功')
- wx.setStorageSync('message', true)
- }
- this.userAuth()
- },
- fail: () => {
- this.userAuth()
- }
- })
- } else {
- this.userAuth()
- }
- },
- userAuth() {
- if(this.data.isIOS) {
- wx.navigateTo({
- url: `../vipActivity/vipActivity`
- });
- } else {
- const productId = wx.getStorageSync('productId');
- httpRequestApi.createOrder(productId).success(res => {
- console.log(res.data.data.package);
- const timeStamp = res.data.data.timeStamp;
- const nonceStr = res.data.data.nonceStr;
- const packages = res.data.data.package;
- const paySign = res.data.data.sign;
- wx.requestPayment({
- timeStamp,
- nonceStr,
- package: packages,
- signType: 'MD5',
- paySign,
- success: (res) => {
- this.setData({
- authHide: !this.data.authHide
- })
- httpRequestApi.getAuthActivity().success(res => {
- if (!res.data.data) {
- wx.setStorageSync('vip', false)
- wx.setStorageSync('date', '')
- } else {
- wx.setStorageSync('vip', true)
- wx.setStorageSync('date', res.data.data)
- }
- }).fail(error => {
- console.log(error)
- })
- },
- fail (res) { }
- })
- })
- }
- this.hideAuth();
- },
- hideAuth() {
- this.setData({
- authHide: !this.data.authHide
- })
- }
- })
|