合并画布,部分样式调整
This commit is contained in:
@@ -235,7 +235,7 @@ const openTypeList = (t)=>{
|
||||
return {
|
||||
tools:{
|
||||
icon:'fi-rr-magic-wand',
|
||||
label:'Advanced tools',
|
||||
label:t('Header.AdvancedTools'),
|
||||
value:'tools',
|
||||
router:'/home/tools',
|
||||
list:[
|
||||
@@ -273,39 +273,39 @@ const openTypeList = (t)=>{
|
||||
{
|
||||
icon:'fi fi-ss-box-open',
|
||||
value:'toProduct',
|
||||
label:'To Product Image',
|
||||
label:t('Header.toolsToProduct'),
|
||||
router:'tools=toProduct'
|
||||
},{
|
||||
icon:'fi fi-br-keyboard-brightness',
|
||||
value:'relight',
|
||||
label:'Relight',
|
||||
label:t('Header.toolsRelight'),
|
||||
router:'tools=relight'
|
||||
},{
|
||||
icon:'fi fi-rr-play-alt',
|
||||
value:'poseTransfer',
|
||||
label:'Transfer Pose',
|
||||
label:t('Header.toolsToTransferPose'),
|
||||
router:'tools=poseTransfer'
|
||||
},{
|
||||
icon:'i class="fi fi-rr-puzzle-alt',
|
||||
value:'deReconstruction',
|
||||
label:'De/Reconstruction',
|
||||
label:t('Header.toolsDeReconstruction'),
|
||||
router:'tools=deReconstruction'
|
||||
},{
|
||||
icon:'fi fi-rr-cubes',
|
||||
value:'patternMaking3D',
|
||||
label:'3D Pattern Making',
|
||||
label:t('Header.toolsPatternMaking'),
|
||||
router:'tools=patternMaking3D'
|
||||
},{
|
||||
icon:'fi fi-rr-pen-swirl',
|
||||
value:'canvasUpload',
|
||||
label:'Canvas',
|
||||
label:t('Header.toolsCanvas'),
|
||||
router:'tools=canvasUpload'
|
||||
},
|
||||
]
|
||||
},
|
||||
library:{
|
||||
icon:'fi-rr-followcollection',
|
||||
label:'Library',
|
||||
label:t('LibraryPage.library'),
|
||||
value:'library',
|
||||
router:'/home/library',
|
||||
list:[
|
||||
@@ -344,7 +344,7 @@ const openTypeList = (t)=>{
|
||||
},
|
||||
history:{
|
||||
icon:'fi-br-time-past',
|
||||
label:'History',
|
||||
label:t('HistoryPage.History'),
|
||||
value:'history',
|
||||
Todaylist:[
|
||||
],
|
||||
@@ -357,28 +357,28 @@ const openTypeList = (t)=>{
|
||||
},
|
||||
gallery:{
|
||||
icon:'fi-rr-gallery',
|
||||
label:'Gallery',
|
||||
label:t('Header.WORKS'),
|
||||
value:'works',
|
||||
router:'/home/works',
|
||||
list:[
|
||||
{
|
||||
icon:'',
|
||||
label:'All',
|
||||
label:t('works.all'),
|
||||
value:'all',
|
||||
router:'works=all'
|
||||
},{
|
||||
icon:'',
|
||||
label:'Liked works',
|
||||
label:t('works.FavoriteWorks'),
|
||||
value:'favoriteWorks',
|
||||
router:'works=favoriteWorks'
|
||||
},{
|
||||
icon:'',
|
||||
label:'My Works',
|
||||
label:t('works.MyWorks'),
|
||||
value:'myWorks',
|
||||
router:'works=myWorks'
|
||||
},{
|
||||
icon:'',
|
||||
label:'New years 2025',
|
||||
label:t('works.NewYear_2025'),
|
||||
value:'NewYear_2025',
|
||||
router:'works=NewYear_2025'
|
||||
},
|
||||
@@ -386,13 +386,13 @@ const openTypeList = (t)=>{
|
||||
},
|
||||
event:{
|
||||
icon:'fi-rr-calendar-star',
|
||||
label:'Event',
|
||||
label:t('Header.EVENTS'),
|
||||
value:'events',
|
||||
router:'/home/events',
|
||||
list:[
|
||||
{
|
||||
icon:'',
|
||||
label:'All',
|
||||
label:t('works.all'),
|
||||
value:'all',
|
||||
router:'events=all'
|
||||
}
|
||||
|
||||
@@ -23,10 +23,21 @@ const getUploadUrl = () => {
|
||||
return url
|
||||
}
|
||||
const getMinioUrl = (url) => {
|
||||
const { pathname } = new URL(url);
|
||||
const result = pathname.slice(1);
|
||||
return result
|
||||
if(isUrl(url)){
|
||||
const { pathname } = new URL(url);
|
||||
const result = pathname.slice(1);
|
||||
return result
|
||||
}
|
||||
return ''
|
||||
}
|
||||
function isUrl(str) {
|
||||
try {
|
||||
new URL(str);
|
||||
return true;
|
||||
} catch (e) {
|
||||
return false;
|
||||
}
|
||||
}
|
||||
const rgbaToHex = (rgba)=> { // rgba转16进制
|
||||
let hex = '#';
|
||||
rgba.forEach((i,index) => {
|
||||
@@ -93,7 +104,27 @@ function downloadIamge(imgsrc, name) { // 下载图片地址和图片名
|
||||
}
|
||||
image.src = imgsrc
|
||||
}
|
||||
|
||||
async function downloadVideoWithFetch(url, filename) {
|
||||
try {
|
||||
const response = await fetch(url);
|
||||
const blob = await response.blob();
|
||||
const blobUrl = URL.createObjectURL(blob);
|
||||
|
||||
const a = document.createElement('a');
|
||||
a.href = blobUrl;
|
||||
a.download = filename || 'video.mp4';
|
||||
document.body.appendChild(a);
|
||||
a.click();
|
||||
|
||||
// 清理
|
||||
setTimeout(() => {
|
||||
document.body.removeChild(a);
|
||||
URL.revokeObjectURL(blobUrl);
|
||||
}, 100);
|
||||
} catch (error) {
|
||||
console.error('下载失败:', error);
|
||||
}
|
||||
}
|
||||
function dataURLtoFile(dataurl, filename) {//吧url转为文件对象,指定文件名称
|
||||
var arr = dataurl.split(','), mime = arr[0].match(/:(.*?);/)[1],
|
||||
bstr = atob(arr[1]), n = bstr.length, u8arr = new Uint8Array(n);
|
||||
@@ -592,6 +623,7 @@ export {
|
||||
dataURLtoBlob,
|
||||
isMoible,
|
||||
downloadIamge,
|
||||
downloadVideoWithFetch,
|
||||
getBrowserInfo,
|
||||
setPubDate,
|
||||
murmur,
|
||||
|
||||
Reference in New Issue
Block a user