@shijiu/jsview-vue-samples 2.2.35 → 2.2.128
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/BakeViewDemo/AnimatePic.vue +93 -0
- package/BakeViewDemo/App.vue +109 -0
- package/ClickDivDemo/App.vue +150 -0
- package/DemoHomepage/components/Dialog.vue +37 -11
- package/DemoHomepage/components/TabFrame.vue +8 -1
- package/DemoHomepage/router.js +61 -26
- package/DemoHomepage/views/Homepage.vue +30 -13
- package/FocusMoveStyle/App.vue +21 -4
- package/FocusMoveStyle/FoldableItem.vue +39 -12
- package/FreeMoveChildAttract/App.vue +105 -0
- package/FreeMoveLink/App.vue +55 -0
- package/FreeMoveResize/App.vue +102 -0
- package/LongText/App.vue +1 -3
- package/LongText/LongTextScroll.vue +78 -33
- package/LongTextLatex/App.vue +93 -0
- package/LongTextLatex/Button.vue +50 -0
- package/LongTextLatex/ButtonItem.vue +44 -0
- package/LongTextLatex/LongTextScroll.vue +189 -0
- package/LongTextLatex/Scroll.vue +14 -0
- package/MetroWidgetDemos/MassiveItems/App.vue +87 -0
- package/MetroWidgetDemos/MassiveItems/ContentItem.vue +388 -0
- package/MetroWidgetDemos/MassiveItems/Item.vue +203 -0
- package/MetroWidgetDemos/MassiveItems/WidgetItem.vue +101 -0
- package/MetroWidgetDemos/MassiveItems/data.js +17 -0
- package/MetroWidgetDemos/PingPong/AppPage.vue +19 -9
- package/MetroWidgetDemos/routeList.js +6 -0
- package/ScrollBoxTest/App.vue +160 -0
- package/TestNativeSharedView/App.vue +166 -73
- package/TextureAnimation/App2.vue +17 -6
- package/TombSweepingDayTest/Raining/RainScene.vue +36 -24
- package/package.json +1 -1
|
@@ -0,0 +1,93 @@
|
|
|
1
|
+
<!--
|
|
2
|
+
* 【界面概述】
|
|
3
|
+
* 协议书的示例
|
|
4
|
+
*
|
|
5
|
+
* 【技巧说明】
|
|
6
|
+
* Q: 如何长文字div的高度自适应?
|
|
7
|
+
* A: 描画长文字的div的高度不设置即可
|
|
8
|
+
* 并通过element.clientHeight获取渲染后的自动高度,以决定滚动轴的总高度
|
|
9
|
+
*
|
|
10
|
+
* Q: 长段文字如何换行?
|
|
11
|
+
* A: 若文字内容中需要折行,则需要把要显示内容放入字符串中,并加入'\n'来达到换行效果,例如:
|
|
12
|
+
* <div>{"第一行
|
|
13
|
+
* 第二行"}</div>
|
|
14
|
+
* =======需要改成=======
|
|
15
|
+
* <div>{"第一行\n\
|
|
16
|
+
* 第二行"}</div>
|
|
17
|
+
*
|
|
18
|
+
* Q: 文字首行缩进如何做?
|
|
19
|
+
* A: 目前系统只支持通过空格进行首行缩进,行首加入期望的空格数量即可达到缩进,因为盒子字体库和PC不尽相同,
|
|
20
|
+
* 所以务必在盒子上实际测试缩进效果。
|
|
21
|
+
-->
|
|
22
|
+
|
|
23
|
+
<script setup>
|
|
24
|
+
import LongTextScroll from "./LongTextScroll.vue";
|
|
25
|
+
import Button from "./Button.vue";
|
|
26
|
+
import { jJsvRuntimeBridge } from "jsview";
|
|
27
|
+
import { onMounted, ref } from "vue";
|
|
28
|
+
import { useRouter } from "vue-router";
|
|
29
|
+
|
|
30
|
+
const router = useRouter();
|
|
31
|
+
|
|
32
|
+
const onKeyDown = (ev) => {
|
|
33
|
+
if (ev.keyCode == 8 || ev.keyCode == 27 || ev.keyCode == 10000) {
|
|
34
|
+
router.go(-1); // 有router时,是从DemoHomepage进入,回退
|
|
35
|
+
}
|
|
36
|
+
return true;
|
|
37
|
+
};
|
|
38
|
+
|
|
39
|
+
onMounted(() => {
|
|
40
|
+
jJsvRuntimeBridge.notifyPageLoaded();
|
|
41
|
+
});
|
|
42
|
+
</script>
|
|
43
|
+
|
|
44
|
+
<template>
|
|
45
|
+
<jsv-focus-block
|
|
46
|
+
autoFocus
|
|
47
|
+
:onAction="{
|
|
48
|
+
onKeyDown: onKeyDown,
|
|
49
|
+
}"
|
|
50
|
+
>
|
|
51
|
+
<div>
|
|
52
|
+
<div
|
|
53
|
+
:style="{
|
|
54
|
+
textAlign: 'center',
|
|
55
|
+
fontSize: 30,
|
|
56
|
+
lineHeight: 50,
|
|
57
|
+
color: '#ffffff',
|
|
58
|
+
left: 140,
|
|
59
|
+
top: 20,
|
|
60
|
+
width: 1000,
|
|
61
|
+
height: 50,
|
|
62
|
+
backgroundColor: 'rgba(27,38,151,0.8)',
|
|
63
|
+
}"
|
|
64
|
+
>
|
|
65
|
+
可展示篇幅超过一屏的文字
|
|
66
|
+
</div>
|
|
67
|
+
<div :style="{ left: 140, top: 100 }">
|
|
68
|
+
<LongTextScroll
|
|
69
|
+
:style="{ width: 1000, height: 500, backgroundColor: '#EEEEEE' }"
|
|
70
|
+
:textStyle="{ color: '#000000', fontSize: 20 }"
|
|
71
|
+
:scrollBlockStyle="{
|
|
72
|
+
width: 10,
|
|
73
|
+
height: 30,
|
|
74
|
+
backgroundColor: '#555555',
|
|
75
|
+
}"
|
|
76
|
+
:scrollStyle="{
|
|
77
|
+
left: 1005,
|
|
78
|
+
width: 10,
|
|
79
|
+
height: 500,
|
|
80
|
+
backgroundColor: '#DDDDDD',
|
|
81
|
+
}"
|
|
82
|
+
:step="20"
|
|
83
|
+
>
|
|
84
|
+
</LongTextScroll>
|
|
85
|
+
<div :style="{ left: 400, top: 550 }">
|
|
86
|
+
<Button />
|
|
87
|
+
</div>
|
|
88
|
+
</div>
|
|
89
|
+
</div>
|
|
90
|
+
</jsv-focus-block>
|
|
91
|
+
</template>
|
|
92
|
+
|
|
93
|
+
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
<script setup>
|
|
2
|
+
import { HORIZONTAL, MetroWidget, EdgeDirection, useFocusHub } from "jsview";
|
|
3
|
+
import ButtonItem from "./ButtonItem.vue";
|
|
4
|
+
|
|
5
|
+
const focusHub = useFocusHub();
|
|
6
|
+
const data = [
|
|
7
|
+
{
|
|
8
|
+
width: 100,
|
|
9
|
+
height: 50,
|
|
10
|
+
marginRight: 100,
|
|
11
|
+
content: "同意",
|
|
12
|
+
},
|
|
13
|
+
{
|
|
14
|
+
width: 100,
|
|
15
|
+
height: 50,
|
|
16
|
+
content: "取消",
|
|
17
|
+
},
|
|
18
|
+
];
|
|
19
|
+
|
|
20
|
+
const measures = (item) => {
|
|
21
|
+
return item;
|
|
22
|
+
};
|
|
23
|
+
|
|
24
|
+
const onEdge = (edgeInfo) => {
|
|
25
|
+
if (edgeInfo.direction == EdgeDirection.top) {
|
|
26
|
+
focusHub.setFocus("longTextScroll");
|
|
27
|
+
}
|
|
28
|
+
};
|
|
29
|
+
</script>
|
|
30
|
+
|
|
31
|
+
<template>
|
|
32
|
+
<metro-widget
|
|
33
|
+
name="button"
|
|
34
|
+
:width="500"
|
|
35
|
+
:height="50"
|
|
36
|
+
:data="data"
|
|
37
|
+
:direction="HORIZONTAL"
|
|
38
|
+
:measures="measures"
|
|
39
|
+
:onEdge="onEdge"
|
|
40
|
+
>
|
|
41
|
+
<template #renderItem="{ data, query, onEdge, onAction }">
|
|
42
|
+
<button-item
|
|
43
|
+
:data="data"
|
|
44
|
+
:query="query"
|
|
45
|
+
:onEdge="onEdge"
|
|
46
|
+
:onAction="onAction"
|
|
47
|
+
/>
|
|
48
|
+
</template>
|
|
49
|
+
</metro-widget>
|
|
50
|
+
</template>
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
<!--
|
|
2
|
+
* @Author: ChenChanghua
|
|
3
|
+
* @Date: 2022-07-08 15:05:00
|
|
4
|
+
* @LastEditors: ChenChanghua
|
|
5
|
+
* @LastEditTime: 2022-07-08 17:45:44
|
|
6
|
+
* @Description: file content
|
|
7
|
+
-->
|
|
8
|
+
<script setup>
|
|
9
|
+
import { ref } from "vue";
|
|
10
|
+
|
|
11
|
+
const props = defineProps({
|
|
12
|
+
data: Object,
|
|
13
|
+
query: Object,
|
|
14
|
+
onEdge: Function,
|
|
15
|
+
onAction: Object,
|
|
16
|
+
});
|
|
17
|
+
const focused = ref(false);
|
|
18
|
+
const onFocus = () => {
|
|
19
|
+
focused.value = true;
|
|
20
|
+
};
|
|
21
|
+
|
|
22
|
+
const onBlur = () => {
|
|
23
|
+
focused.value = false;
|
|
24
|
+
};
|
|
25
|
+
|
|
26
|
+
const onClick = () => {};
|
|
27
|
+
|
|
28
|
+
props.onAction.register("onFocus", onFocus);
|
|
29
|
+
props.onAction.register("onBlur", onBlur);
|
|
30
|
+
props.onAction.register("onClick", onClick);
|
|
31
|
+
</script>
|
|
32
|
+
|
|
33
|
+
<template>
|
|
34
|
+
<div
|
|
35
|
+
:style="{
|
|
36
|
+
width: props.data.width,
|
|
37
|
+
height: props.data.height,
|
|
38
|
+
fontSize: 30,
|
|
39
|
+
backgroundColor: focused ? '#DD8800' : '#BBBBAA',
|
|
40
|
+
}"
|
|
41
|
+
>
|
|
42
|
+
{{ data.content }}
|
|
43
|
+
</div>
|
|
44
|
+
</template>
|
|
@@ -0,0 +1,189 @@
|
|
|
1
|
+
<script setup>
|
|
2
|
+
import Scroll from "./Scroll.vue";
|
|
3
|
+
import { ref, onMounted } from "vue";
|
|
4
|
+
import { useFocusHub, JsvFlexDiv, JsvTextBox } from "jsview";
|
|
5
|
+
|
|
6
|
+
const props = defineProps({
|
|
7
|
+
step: Number,
|
|
8
|
+
style: Object,
|
|
9
|
+
scrollStyle: Object,
|
|
10
|
+
scrollBlockStyle: Object,
|
|
11
|
+
textStyle: Object,
|
|
12
|
+
});
|
|
13
|
+
|
|
14
|
+
const focusHub = useFocusHub();
|
|
15
|
+
|
|
16
|
+
const rootRef = ref(null);
|
|
17
|
+
const scrollY = ref(0);
|
|
18
|
+
const textY = ref(0);
|
|
19
|
+
|
|
20
|
+
let textTotalHeight = 0;
|
|
21
|
+
const onTextSizeReady = (width, height) => {
|
|
22
|
+
textTotalHeight = height;
|
|
23
|
+
console.log(`textSize ready width=${width} height=${height}`);
|
|
24
|
+
};
|
|
25
|
+
|
|
26
|
+
const onAction = {
|
|
27
|
+
onKeyDown: (ev) => {
|
|
28
|
+
const valid = textTotalHeight > 0;
|
|
29
|
+
// let keyUsed = true;
|
|
30
|
+
if (valid) {
|
|
31
|
+
let text_y;
|
|
32
|
+
switch (ev.keyCode) {
|
|
33
|
+
case 38:
|
|
34
|
+
if (textY.value !== 0) {
|
|
35
|
+
text_y =
|
|
36
|
+
textY.value + props.step >= 0 ? 0 : textY.value + props.step;
|
|
37
|
+
(textY.value = text_y),
|
|
38
|
+
(scrollY.value =
|
|
39
|
+
(-text_y / (textTotalHeight - props.style.height)) *
|
|
40
|
+
(props.scrollStyle.height - props.scrollBlockStyle.height));
|
|
41
|
+
}
|
|
42
|
+
break;
|
|
43
|
+
case 40:
|
|
44
|
+
if (textY.value !== props.style.height - textTotalHeight) {
|
|
45
|
+
text_y =
|
|
46
|
+
textY.value - props.step <= props.style.height - textTotalHeight
|
|
47
|
+
? props.style.height - textTotalHeight
|
|
48
|
+
: textY.value - props.step;
|
|
49
|
+
(textY.value = text_y),
|
|
50
|
+
(scrollY.value =
|
|
51
|
+
(-text_y / (textTotalHeight - props.style.height)) *
|
|
52
|
+
(props.scrollStyle.height - props.scrollBlockStyle.height));
|
|
53
|
+
} else {
|
|
54
|
+
focusHub.setFocus("button");
|
|
55
|
+
}
|
|
56
|
+
break;
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
},
|
|
60
|
+
onFocus: () => {
|
|
61
|
+
console.log("LongTextScroll getFocus");
|
|
62
|
+
},
|
|
63
|
+
onBlur: () => {
|
|
64
|
+
console.log("LongTextScroll loseFocus");
|
|
65
|
+
},
|
|
66
|
+
};
|
|
67
|
+
|
|
68
|
+
onMounted(() => {
|
|
69
|
+
rootRef.value.requestFocus();
|
|
70
|
+
});
|
|
71
|
+
</script>
|
|
72
|
+
|
|
73
|
+
<template>
|
|
74
|
+
<jsv-focus-block ref="rootRef" name="longTextScroll" :onAction="onAction">
|
|
75
|
+
<div :style="{ overflow: 'hidden', ...style }">
|
|
76
|
+
<jsv-flex-div
|
|
77
|
+
:style="{ top: textY, width: style.width }"
|
|
78
|
+
:onSized="onTextSizeReady"
|
|
79
|
+
>
|
|
80
|
+
<jsv-text-box :enableLatex="true" :style="{ width: style.width, ...textStyle, }">
|
|
81
|
+
{{
|
|
82
|
+
"疾风引擎JsView用户服务协议及隐私权保护政策\n\
|
|
83
|
+
\n\
|
|
84
|
+
\n\
|
|
85
|
+
特别提示:\n\
|
|
86
|
+
\n\
|
|
87
|
+
欢迎您使用“疾风引擎JsView”。本用户服务协议及隐私权保护政策(下称“本协议”)是您与运营方之间订立的具有法律效力的合同。请您仔细阅读并充分理解本协议各条款内容,特别是涉及免除或者限制责任的条款、权利许可和信息使用的条款、同意开通和使用特殊单项服务的条款、法律适用和争议解决条款等。其中,免除或者限制责任条款等重要内容可能以下划线/加粗进行提示您,您应重点阅读。未成年人用户请在法定监护人陪同下仔细阅读并充分理解本协议,并征得法定监护人的同意后使用“疾风引擎JsView”。\n\
|
|
88
|
+
\n\
|
|
89
|
+
\n\
|
|
90
|
+
除非您完全接受本协议的全部内容,否则您无权\\textcolor{#FF0000}{下载}、注册、登录、使用(以下统称“使用”)“疾风引擎JsView”,或者通过任何方式使用“疾风引擎JsView”服务,或者获得“疾风引擎JsView”提供的任何服务(本协议中统称“使用”)。若您使用“疾风引擎JsView”及相关服务,则视为您已充分理解本协议并承诺作为本协议的一方当事人接受协议的约束,您不得以未仔细阅读、未充分理解等理由拒绝接受本协议的约束。\n\
|
|
91
|
+
\n\
|
|
92
|
+
\\textb{本协议内容或不能保证完全符合未来业务发展需求}。为此,您同意运营方保留随时修改本协议的权利。本协议条款修改后,运营方将及时公布,您同意予以密切关注。如果您继续使用疾风引擎JsView,即视为您完全接受修改后的协议。如果您不接受修改后的协议,请立即停止使用疾风引擎JsView。\n\
|
|
93
|
+
\n\
|
|
94
|
+
关于疾风引擎JsView的使用\n\
|
|
95
|
+
您使用“疾风引擎JsView”及相关服务,登录后,\\textcolor{#00FF00}{系统将为您自动匹配一个不可更改的用户ID},您应妥善保管该用户ID并对以您用户ID所进行的所有活动负法律责任。\n\
|
|
96
|
+
您可根据需要自行使用“疾风引擎JsView”及相关服务或更新“疾风引擎JsView”版本,如您不再需要使用“疾风引擎JsView”及相关服务可自行卸载或者删除。\n\
|
|
97
|
+
为更好的提升用户体验及服务,运营方将不定期提供软件、更新或改变(包括但不限于软件及修改、升级、功能强化、开发新服务、软件及替换等)。您有权选择更新版本或服务,您理解,如果您不及时更新“疾风引擎JsView”及相关服务,部分功能将受到限制或不能继续使用。您在使用疾风引擎JsView时,不得实施以下行为:\n\
|
|
98
|
+
违反国家法律法规规定的;\n\
|
|
99
|
+
危害国家、公共安全、重大公共利益,损害国家荣誉和利益的;\n\
|
|
100
|
+
煽动民族仇恨、民族歧视,破坏民族团结的;扰乱公共秩序、破坏社会稳定、违反公序良俗的;\n\
|
|
101
|
+
传播封建迷信、淫秽、色情、赌博、暴力、恐怖或者教唆犯罪;通过各种渠道盗取、窃取其他用户信息;\n\
|
|
102
|
+
散布病毒、垃圾广告、诈骗信息或存在欺诈、虚假、误导性信息;侵犯运营方、其他公民、其他用户及任何第三方依法享有的知识产权及其他合法权益;\n\
|
|
103
|
+
破坏、篡改、删除、影响疾风引擎JsView构成或内部数据影响正常运行的;\n\
|
|
104
|
+
对疾风引擎JsView进行反向工程、反向汇编、反向编译或者采取其他方式获取本软件源代码;\n\
|
|
105
|
+
扫描、测试、探测疾风引擎JsView缺陷以及BUG漏洞;\n\
|
|
106
|
+
通过第三方软件、插件来使用疾风引擎JsView,或制造、编写、传播该等软件、插件;其他违背社会公共利益或公共道德或依据相关本协议条款规定不适合在疾风引擎JsView实施的;\n\
|
|
107
|
+
及其他可能侵害运营方合法权益的行为。\n\
|
|
108
|
+
\n\
|
|
109
|
+
\n\
|
|
110
|
+
关于疾风引擎JsView的“ID”您在“疾风引擎JsView”的用户ID仅限于您本人使用,未经运营方书面同意,您不得将用户ID以任何形式赠与、借用、出租、转让、售卖或以其他方式许可他人使用,若您违反前述约定,您应自行承担一切不利法律后果。如果运营方发现或者有合理理由认为使用者并非ID初始使用人,为保障用户ID安全,运营商有权立即暂停、警告、删除或屏蔽特定内容、暂时冻结或永久终止该ID的登录等。\n\
|
|
111
|
+
因其他人恶意攻击或您自身原因或其他不可抗因素而导致的ID被盗、丢失,均由您本人承担责任,运营方不承担任何责任。\n\
|
|
112
|
+
您有责任维护个人账号的安全性与保密性,并对您以您用户ID名义所从事的活动承担全部法律责任,包括但不限于您在“疾风引擎JsView”上进行的任何数据修改、款项支付等操作行为。\n\
|
|
113
|
+
\n\
|
|
114
|
+
\n\
|
|
115
|
+
关于疾风引擎JsView的管理\n\
|
|
116
|
+
为提升用户使用体验并规范疾风引擎JsView管理,运营方有权制定、修改、废止相关的疾风引擎JsView用户制度、规则、办法等规范性文件(下称“疾风引擎JsView制度”),并及时予以公布。您在此同意,除遵守本协议约定以外,您还应遵守前述所及疾风引擎JsView制度。如您对疾风引擎JsView制度有任何意见、建议,欢迎您联系客服反馈。\n\
|
|
117
|
+
您理解、确认并同意,运营方有权依合理判断对违反有关法律法规、社会道德、公序良俗或本协议规定的行为采取管理措施,包括但不限于【向用户发出提醒、警告、删除或屏蔽特定内容、暂时冻结或永久终止用户ID的登录等】。同时,为维护自身及其他用户合法权益,运营方将不排除向有关行政主管部门报告或采取进一步的法律行动。\n\
|
|
118
|
+
您理解、确认并同意,如因您使用疾风引擎JsView过程中的行为导致任何第三方、运营方或其关联方遭受任何损害或遭受任何来自第三方的纠纷、诉讼、索赔等,您应当向第三方、运营方或其关联方赔偿相应的损失,并对您违反法律法规或本协议所产生的一切后果负全部法律责任。\n\
|
|
119
|
+
您理解、确认并同意,在法律许可的最大范围内,运营方对于任何运营方控制之外的原因(如地震、火灾、水灾、突发停电、政府命令、ISP中断、软件或硬件故障、计算机病毒或黑客攻击、系统不稳定等)所造成的任何直接的、间接的、附带性的、特殊的、惩罚性的或后果性的损失(包括但不仅限于数据损失、名誉损失、误工损失、电脑故障、用户数据的丢失或其他任何形式的损失),不承担任何责任。因上述不可控因素影响导致疾风引擎JsView无法正常运行的,运营方尽力在合理时限内进行修复。\n\
|
|
120
|
+
由于运营方设备硬件储存数据的局限性,您理解、确认并同意,运营方有权对疾风引擎JsView相应数据设置保存期限。对于超出保存期限的数据,可能会被后台系统自动删除且无法复原,您不得以数据删除为由向运营方提出权利主张。对于用户提出的数据恢复请求,运营方将结合技术可行性予以尽量协助,但不作担保。\n\
|
|
121
|
+
\n\
|
|
122
|
+
\n\
|
|
123
|
+
法律声明\n\
|
|
124
|
+
除法律明确规定外,运营方在此不作任何明示或默示地担保,包括但不限于对任何使用条件、不中断的使用、不侵权的担保,您在此同意自行承担因使用疾风引擎JsView所产生的全部风险。\n\
|
|
125
|
+
您理解、确认并同意,除有特别声明外,运营方在提供疾风引擎JsView服务中所涉及(包括但不限于网页、文字、图片、音频、视频、图表)的知识产权均归运营方所有;运营方提供本服务时所依托软件的著作权、专利权及其他知识产权均归运营方所有;运营方在本服务中使用的图形、文字或其组合以及其他运营方标志及产品、服务名称(“运营方标识”),其著作权、商标权及其他可能涉及的知识产权权利和权益均归运营方所有。未经运营方书面同意,您不得将运营方标识以任何方式使用、许可他人使用或作其他处理,也不得向他人表明您有权使用、许可他人使用或作其他有权处理运营方标识的行为。\n\
|
|
126
|
+
为优化用户的使用体验,运营方可能会向您推送广告,广告内容可能呈现一定程度的营销目的,运营方不对广告内容的真实性进行担保,您应审慎判断并对与该广告相关的交易负责。您与该等广告商、广告主的交易所遭受的纠纷,运营方可尽可能协助调处纠纷,但不承担任何责任。\n\
|
|
127
|
+
您理解、确认并同意,基于市场发展、用户反馈意见及建议以及技术优化等因素,运营方保留单方面对疾风引擎JsView服务的全部或部分服务内容变更、临时暂停、终止的权利,运营方将尽可能及时通知您。服务的临时暂停或终止都将可能导致数据信息的丢失、删除,您同意不以数据丢失、删除为由向运营方提出权利主张。\n\
|
|
128
|
+
基于疾风引擎JsView的服务性质,您理解、确认并同意,在不违反法律法规的情况下,运营方不对任何直接性、间接性、后果性、惩罚性、偶然性、特殊性或刑罚性的损害,包括因用户使用疾风引擎JsView应用程序或本服务而遭受的经济损失承担责任(即使运营方已被告知该等损失的可能性亦然)。尽管本协议中可能含有相悖的规定,运营方对用户承担的全部责任,无论因何原因或何种行为方式,始终不超过用户因使用运营方提供的服务而支付给运营方的费用(如有)。\n\
|
|
129
|
+
\n\
|
|
130
|
+
\n\
|
|
131
|
+
隐私权保护政策\n\
|
|
132
|
+
我们非常重视用户个人信息的保护,且我们与用户一同致力于用户个人信息的保护。本协议所指用户个人信息,是指用户在使用疾风引擎JsView过程中提交的、形成的独立的或与其他信息相结合后能对用户身份进行识别的信息,包括姓名、昵称、头像、电话、住址或位置信息等。\n\
|
|
133
|
+
在您使用疾风引擎JsView的过程中,我们将可能以如下方式收集您在使用服务时主动提供或因为使用服务而产生的个人信息:\n\
|
|
134
|
+
当您使用“疾风引擎JsView”及相关服务时,您可能需要提供您的个人信息(包括但不限于您的姓名、电话号码、地理位置信息、设备信息、您登录疾风引擎JsView时的微信昵称、微信头像等),提供这些信息是为了帮助您建立疾风引擎JsView用户ID。您还可以根据自身需求选择编辑/修改个人资料,如头像、个人主页背景图、昵称、出生日期、性别、个性签名、兴趣标签等信息。您理解并同意,运营方有权在遵守法律法规及本协议的前提下,收集、使用(含商业合作使用)、储存和分享您的个人信息,同时,我们将依法保护您浏览、修改、删除相关信息及撤回同意的权利。\n\
|
|
135
|
+
我们需要结合您的操作行为并通过算法分析,向您进行个性化推荐、展示或推送您可能感兴趣的特定信息。有的信息可能不是您喜欢的信息。\n\
|
|
136
|
+
请您了解,我们收集、使用上述信息时进行了去标识化处理,数据分析仅对应特定的、无法直接关联用户身份的编码,无法也绝不会与您的真实身份相关联。\n\
|
|
137
|
+
为保障您正常使用我们的服务,我们会收集您的【设备型号、操作系统版本号、国际移动设备识别码(IMEI)、网络设备硬件地址(MAC)、登陆IP地址、疾风引擎JsView软件版本号、接入网络的方式和类型、设备加速器(如重力感应设备)、操作日志等日志信息】。\n\
|
|
138
|
+
上述所及信息的收集均为运营方提供疾风引擎JsView完整服务所必需的,部分信息您可以在疾风引擎JsView相应的页面进行删除、修改。对于无法由用户自行删除的信息,您在同意停止使用疾风引擎JsView服务的前提下,可以向运营方提出删除请求,运营方将根据后台系统的技术可行性尽量配合。\n\
|
|
139
|
+
如未来为业务发展需要从第三方间接获取您的个人信息,我们会在获取信息前向您明示您个人信息的来源、类型及使用范围。如疾风引擎JsView开展业务需进行的个人信息处理活动超出您原本向第三方提供个人信息时的授权范围,我们将在处理您的该等个人信息前,征得您的明示同意。\n\
|
|
140
|
+
除下述情形外,我们不会主动向任何第三方共享、披露您的个人信息:\n\
|
|
141
|
+
与国家安全、国防安全有关的;\n\
|
|
142
|
+
与公共安全、公共卫生、重大公共利益有关的;\n\
|
|
143
|
+
与犯罪侦查、起诉、审判和判决执行等有关的;\n\
|
|
144
|
+
出于维护个人信息主体或其他个人的生命、财产等重大合法权益但又很难得到您本人同意的;\n\
|
|
145
|
+
所收集的个人信息是您自行向社会公众公开的;\n\
|
|
146
|
+
从合法公开披露的信息中收集个人信息的,如合法的新闻报道、政府信息公开等渠道;\n\
|
|
147
|
+
根据您的要求签订合同所必需的;\n\
|
|
148
|
+
用于维护所提供的产品或服务的安全稳定运行所必需的,例如发现、处置产品或服务的故障;\n\
|
|
149
|
+
为合法的新闻报道所必需的;涉及运营方及其关联方合并、收购、重组的;\n\
|
|
150
|
+
为改善疾风引擎JsView服务所必需的或符合本协议第四条第2点情形;\n\
|
|
151
|
+
学术研究机构基于公共利益开展统计或学术研究所必要,且对外提供学术研究或描述的结果时,对结果中所包含的个人信息进行去标识化处理的;\n\
|
|
152
|
+
及事先获得您的明确授权同意的;\n\
|
|
153
|
+
法律法规规定的情形。\n\
|
|
154
|
+
运营方将根据微信程序可行性并结合技术可行性,采取合理、有效、可行的措施保护用户个人信息的数据安全。运营方也将合理完善内部管理制度,为用户个人信息提供全方位的保障。\n\
|
|
155
|
+
运营方重视对未成年人个人隐私信息的保护,运营方将依赖您提供的个人信息判断用户是否成年。未成年人使用疾风引擎JsView应事先取得其监护人的同意,否则将由监护人承担全部法律责任。\n\
|
|
156
|
+
\n\
|
|
157
|
+
违约处理\n\
|
|
158
|
+
针对您违反本协议或相关法律法规的行为,运营方有权独立判断并视情况采取预先警示、拒绝发布、立即停止传输信息、删除评论、音频、视频等内容、短期禁止发言、限制账号部分或全部功能直至永久关闭账号等措施。运营方有权公告处理结果,且有权根据实际情况决定是否恢复使用。对涉嫌违反法律法规、涉嫌违法犯罪的行为将保存有关记录,并依法向有关主管部门报告、配合有关主管部门调查。对已删除内容运营方有权不予返还。\n\
|
|
159
|
+
若您违反本协议或相关法律法规规定,引起第三方投诉或诉讼索赔的,您应当自行承担全部法律责任。因您的违法或违约行为导致运营方及其关联公司、控制公司、继承公司向任何第三方赔偿或遭受国家机关处罚的,您还应足额赔偿运营方及其关联公司、控制公司、继承公司因此遭受的损失。\n\
|
|
160
|
+
若您在使用“疾风引擎JsView”及相关服务时上传的文字、视频、音频等侵犯了第三方知识产权、名誉权、姓名权、隐私权等权利及合法权益,运营方有权在收到权利方或者相关方通知的情况下删除该涉嫌侵权内容。针对第三方提出的全部权利主张,您应自行承担全部法律责任;如因您的侵权行为导致运营方及其关联公司、控制公司、继承公司遭受损失的,您还应足额赔偿运营方及其关联公司、控制公司、继承公司遭受的全部损失。\n\
|
|
161
|
+
\n\
|
|
162
|
+
\n\
|
|
163
|
+
免责声明\n\
|
|
164
|
+
您理解并同意,“疾风引擎JsView”及相关服务可能会受多种因素的影响或干扰,运营方不保证(包括但不限于):\n\
|
|
165
|
+
“疾风引擎JsView”完全适合用户的使用要求;\n\
|
|
166
|
+
运营方不受干扰,及时、安全或不出现错误;\n\
|
|
167
|
+
用户经由运营方取得的任何、服务或其他材料符合用户的期望;\n\
|
|
168
|
+
任何错误都将能得到更正。\n\
|
|
169
|
+
对于涉嫌借款或其他涉及财产的网络信息、账户密码、广告或推广等信息的,用户请谨慎对待并自行判断,基于前述原因您因此遭受的利润、商业信誉、资料损失或其他有形或无形损失的,我们不承担任何直接、间接、附带、特别、衍生性或惩罚性的赔偿责任。\n\
|
|
170
|
+
用户理解并同意,在使用“疾风引擎JsView”及相关服务过程中,可能遇到不可抗力等因素,包括但不限于政府行为、自然灾害、网络原因、黑客攻击、战争或任何其他不能预见、不能克服并不能避免的客观事件。出现不可抗力情况时,运营方将努力在第一时间及时处理,但因不可抗力给用户造成了损失,用户同意运营方不承担责任。\n\
|
|
171
|
+
运营方依本协议约定获得处理违法违规内容的权利不构成运营方的义务或承诺,运营方不能保证及时发现违法行为或进行相应处理。\n\
|
|
172
|
+
\n\
|
|
173
|
+
\n\
|
|
174
|
+
其他\n\
|
|
175
|
+
您在此同意,当运营方需要就某事项通知您时,在内发布公告、向用户单独发出通知、根据用户填报的联系方式等多种渠道均为有效通讯渠道。\n\
|
|
176
|
+
本协议条款的效力和解释均适用中华人民共和国的法律,如有条款与中华人民共和国法律相抵触,则该部分条款应按法律规定重新解释,部分条款的无效或重新解释不影响其他条款的法律效力。\n\
|
|
177
|
+
本协议以及疾风引擎JsView制度将统一构成您与运营方之间的完整协议,两者约定不一致的,以文本制定时间较晚者为准。\n\
|
|
178
|
+
本协议签订地为中华人民共和国上海市,若您在使用疾风引擎JsView过程中产生任何纠纷或争议,您同意将该纠纷或者争议提交本协议签订地人民法院管辖。本协议条款无论何种原因部分无效或不可执行,其他条款仍应继续有效,对双方具有约束力。"
|
|
179
|
+
}}
|
|
180
|
+
</jsv-text-box>
|
|
181
|
+
</jsv-flex-div>
|
|
182
|
+
</div>
|
|
183
|
+
<Scroll
|
|
184
|
+
:top="scrollY"
|
|
185
|
+
:scrollStyle="scrollStyle"
|
|
186
|
+
:scrollBlockStyle="scrollBlockStyle"
|
|
187
|
+
/>
|
|
188
|
+
</jsv-focus-block>
|
|
189
|
+
</template>
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
<script setup>
|
|
2
|
+
defineProps({
|
|
3
|
+
scrollStyle: Object,
|
|
4
|
+
top: Number,
|
|
5
|
+
scrollBlockStyle: Object,
|
|
6
|
+
});
|
|
7
|
+
</script>
|
|
8
|
+
<template>
|
|
9
|
+
<div :style="{ ...scrollStyle }">
|
|
10
|
+
<div :style="{ top: top }">
|
|
11
|
+
<div :style="{ ...scrollBlockStyle }"></div>
|
|
12
|
+
</div>
|
|
13
|
+
</div>
|
|
14
|
+
</template>
|
|
@@ -0,0 +1,87 @@
|
|
|
1
|
+
<!--
|
|
2
|
+
* @Author: ChenChanghua
|
|
3
|
+
* @Date: 2022-07-11 13:31:36
|
|
4
|
+
* @Description: file content
|
|
5
|
+
-->
|
|
6
|
+
<script setup>
|
|
7
|
+
import {
|
|
8
|
+
MetroWidget,
|
|
9
|
+
VERTICAL,
|
|
10
|
+
useFocusHub,
|
|
11
|
+
METRO_WIDGET_CONST,
|
|
12
|
+
FixPositionSlide,
|
|
13
|
+
} from "jsview";
|
|
14
|
+
import WidgetItem from "./WidgetItem.vue";
|
|
15
|
+
import { onMounted } from "vue";
|
|
16
|
+
|
|
17
|
+
const focusHub = useFocusHub();
|
|
18
|
+
|
|
19
|
+
const provideData = () => {
|
|
20
|
+
const data = [];
|
|
21
|
+
for (let i = 0; i < 10; i++) {
|
|
22
|
+
data.push({
|
|
23
|
+
width: 900,
|
|
24
|
+
height: 650,
|
|
25
|
+
name: "widget_" + i,
|
|
26
|
+
marginBottom: 10,
|
|
27
|
+
index: i,
|
|
28
|
+
});
|
|
29
|
+
}
|
|
30
|
+
return data;
|
|
31
|
+
};
|
|
32
|
+
|
|
33
|
+
const s = new FixPositionSlide();
|
|
34
|
+
const measures = (item) => {
|
|
35
|
+
return {
|
|
36
|
+
width: item.width,
|
|
37
|
+
height: item.height,
|
|
38
|
+
marginRight: item.marginRight,
|
|
39
|
+
marginBottom: item.marginBottom,
|
|
40
|
+
/**重要代码: itemSlide设置为ACT_FOCUS_RECT_EVENT, 由子MetroWidget控制滚动 */
|
|
41
|
+
// itemSlide: METRO_WIDGET_CONST.ITEM_SLIDE.ACT_FOCUS_RECT_EVENT,
|
|
42
|
+
};
|
|
43
|
+
};
|
|
44
|
+
|
|
45
|
+
onMounted(() => {
|
|
46
|
+
focusHub.setFocus("mwWidget");
|
|
47
|
+
});
|
|
48
|
+
</script>
|
|
49
|
+
|
|
50
|
+
<template>
|
|
51
|
+
<div :style="{ width: 1280, height: 720, backgroundColor: '#007788' }" />
|
|
52
|
+
<!-- 为了保证边缘的item缩放后依旧完整显示, 需要设置padding, 注意width/height是包含padding的 -->
|
|
53
|
+
|
|
54
|
+
<div
|
|
55
|
+
:style="{
|
|
56
|
+
textAlign: 'center',
|
|
57
|
+
fontSize: 30,
|
|
58
|
+
lineHeight: 50,
|
|
59
|
+
color: '#ffffff',
|
|
60
|
+
left: 60,
|
|
61
|
+
top: 5,
|
|
62
|
+
width: 1160,
|
|
63
|
+
height: 50,
|
|
64
|
+
backgroundColor: 'rgba(27,38,151,0.8)',
|
|
65
|
+
}"
|
|
66
|
+
>
|
|
67
|
+
测试MetroWidget可视区域内项目过多时防卡顿时,盒子上的分段显示(上下翻一屏)
|
|
68
|
+
</div>
|
|
69
|
+
|
|
70
|
+
<metro-widget
|
|
71
|
+
name="mwWidget"
|
|
72
|
+
:top="62"
|
|
73
|
+
:left="200"
|
|
74
|
+
:width="1000"
|
|
75
|
+
:height="650"
|
|
76
|
+
:provideData="provideData"
|
|
77
|
+
:padding="{ left: 30, right: 30 }"
|
|
78
|
+
:direction="VERTICAL"
|
|
79
|
+
:measures="measures"
|
|
80
|
+
:slideSetting="s"
|
|
81
|
+
>
|
|
82
|
+
<!-- 重要代码: 为了实现焦点就近移动, 需要传递onItemEdge回调 -->
|
|
83
|
+
<template #renderItem="{ data, onAction, onItemEdge }">
|
|
84
|
+
<widget-item :data="data" :onAction="onAction" :onItemEdge="onItemEdge" />
|
|
85
|
+
</template>
|
|
86
|
+
</metro-widget>
|
|
87
|
+
</template>
|