未验证 提交 08016e2c 编写于 作者: O openharmony_ci 提交者: Gitee

!9503 【OpenHarmony 4.0.9.3】【Beta2】【ArkUI子系统】【TOD】【rk3568】【必现】新增接口用例

Merge pull request !9503 from hekun/cherry-pick-1690358949
/**
* Copyright (c) 2023 Huawei Device Co., Ltd.
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
@Entry
@Component
struct ApiRect {
build() {
Column({ space: 10 }) {
Text('normal').fontSize(11).fontColor(0xCCCCCC).width('90%')
.onClick(()=>{
let storage: LocalStorage = LocalStorage.getShared();
console.log(storage.keys().toString());
})
// 绘制90% * 50的矩形
Column({ space: 5 }) {
Text('normal').fontSize(9).fontColor(0xCCCCCC).width('90%')
// 绘制90% * 50矩形
Rect({ width: '90%', height: 50 })
.fill(Color.Pink)
// 绘制90% * 50的矩形框
Rect()
.width('90%')
.height(50)
.fillOpacity(0)
.stroke(Color.Red)
.strokeWidth(3)
Text('with rounded corners').fontSize(11).fontColor(0xCCCCCC).width('90%')
// 绘制90% * 80的矩形, 圆角宽高分别为40、20
Rect({ width: '90%', height: 80 })
.radiusHeight(20)
.radiusWidth(40)
.fill(Color.Pink)
// 绘制90% * 80的矩形, 圆角宽高为20
Rect({ width: '90%', height: 80 })
.radius(20)
.fill(Color.Pink)
.stroke(Color.Transparent)
}.width('100%').margin({ top: 10 })
// 绘制90% * 50矩形, 左上圆角宽高40,右上圆角宽高20,右下圆角宽高40,左下圆角宽高20
Rect({ width: '90%', height: 80 })
.radius([[40, 40], [20, 20], [40, 40], [20, 20]])
.fill(Color.Pink)
}.width('100%').margin({ top: 5 })
}
}
\ No newline at end of file
/**
* Copyright (c) 2023 Huawei Device Co., Ltd.
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
@Entry
@Component
struct BlurStyle1 {
build() {
Column() {
Text("BlurStyle.BACKGROUND_THIN").margin(5).id("BACKGROUND_THIN")
.backgroundBlurStyle(BlurStyle.BACKGROUND_THIN, { colorMode: ThemeColorMode.SYSTEM, adaptiveColor: AdaptiveColor.DEFAULT })
Text("BlurStyle.BACKGROUND_REGULAR").margin(5).id("BACKGROUND_REGULAR")
.backgroundBlurStyle(BlurStyle.BACKGROUND_REGULAR, { adaptiveColor: AdaptiveColor.AVERAGE })
Text("BlurStyle.BACKGROUND_THICK").margin(5).id("BACKGROUND_THICK")
.backgroundBlurStyle(BlurStyle.BACKGROUND_THICK)
Text("BlurStyle.BACKGROUND_ULTRA_THICK").margin(5).id("BACKGROUND_ULTRA_THICK")
.backgroundBlurStyle(BlurStyle.BACKGROUND_ULTRA_THICK)
}.width('90%').height("90%")
}
}
\ No newline at end of file
/**
* Copyright (c) 2023 Huawei Device Co., Ltd.
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
@Entry
@Component
struct CanvasRenderer1 {
private settings: RenderingContextSettings = new RenderingContextSettings(true)
private context: CanvasRenderingContext2D = new CanvasRenderingContext2D(this.settings)
private offCanvas: OffscreenCanvas = new OffscreenCanvas(600, 600)
build() {
Flex({ direction: FlexDirection.Column, alignItems: ItemAlign.Center, justifyContent: FlexAlign.Center }) {
Canvas(this.context)
// .imageSmooththingQuality(ImageSmooththingQuality.high)
.width('100%')
.height('100%')
.backgroundColor('#ffff00')
.onReady(() =>{
this.offCanvas
var offContext = this.offCanvas.getContext("2d", this.settings)
offContext.fillStyle = 0x0000FF
offContext.fillRect(20, 20, 150, 100)
var image = this.offCanvas.transferToImageBitmap()
this.context.transferFromImageBitmap(image)
})
}
.width('100%')
.height('100%')
}
}
\ No newline at end of file
/**
* Copyright (c) 2023 Huawei Device Co., Ltd.
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
@Entry
@Component
struct ClickExample {
@State displayX: string = 'displayX'
@State displayY: string = 'displayY'
@State windowX: string = 'windowX'
@State windowY: string = 'windowY'
@State intentionCode: string = 'intentionCode'
build() {
Column() {
Text(this.displayX).id("displayX")
Text(this.displayY).id("displayY")
Text(this.windowX).id("windowX")
Text(this.windowY).id("windowY")
Text(this.intentionCode).id("intentionCode")
Row({ space: 20 }) {
Button('Click').width(100).height(40).id("Button_click")
.onClick((event: ClickEvent) => {
this.displayX = "onClick: " + event.displayX
this.displayY = "onClick: " + event.displayY
this.windowX = "onClick: " + event.windowX
this.windowY = "onClick: " + event.windowY
})
.onTouch((event: TouchEvent) => {
this.displayX = "onTouch: " + event.getHistoricalPoints()[0].touchObject.displayX
this.displayY = "onTouch: " + event.getHistoricalPoints()[0].touchObject.displayY
this.windowX = "onTouch: " + event.getHistoricalPoints()[0].touchObject.windowX
this.windowY = "onTouch: " + event.getHistoricalPoints()[0].touchObject.windowY
})
.onKeyEvent((event: KeyEvent) => {
this.intentionCode = "KeyEvent: " + event.intentionCode
})
Button('Mouse').width(100).height(40).id("Mouse_click")
.onClick((event: MouseEvent) => {
this.displayX = "MouseEvent: " + event.displayX
this.displayY = "MouseEvent: " + event.displayY
this.windowX = "MouseEvent: " + event.windowX
this.windowY = "MouseEvent: " + event.windowY
})
}.margin(20)
}.width('100%')
}
}
\ No newline at end of file
/**
* Copyright (c) 2023 Huawei Device Co., Ltd.
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
@CustomDialog
struct CustomDialogExample {
@Link textValue: string
@Link inputValue: string
@Link openAnimation: AnimateParam
@Link closeAnimation: AnimateParam
@State widthSize: number = 250
@State heightSize: number = 100
private flag: boolean = true
controller: CustomDialogController
// 若尝试在CustomDialog中传入多个其他的Controller,以实现在CustomDialog中打开另一个或另一些CustomDialog,那么此处需要将指向自己的controller放在最后
cancel: () => void
confirm: () => void
build() {
Column() {
Button('change size')
.width(this.widthSize)
.height(this.heightSize)
.margin(30)
.onClick(() => {
if (this.flag) {
this.widthSize = 150
this.heightSize = 60
this.flag = false
} else {
this.widthSize = 250
this.heightSize = 100
}
})
Flex({ justifyContent: FlexAlign.SpaceAround }) {
Button('cancel')
.onClick(() => {
this.controller.close()
this.cancel()
}).backgroundColor(0xffffff).fontColor(Color.Black)
Button('confirm')
.onClick(() => {
this.inputValue = this.textValue
this.controller.close()
this.confirm()
}).backgroundColor(0xffffff).fontColor(Color.Red)
}.margin({ bottom: 10 })
}
// dialog默认的borderRadius为24vp,如果需要使用border属性,请和borderRadius属性一起使用。
}
}
@Entry
@Component
struct CustomDialogUser {
@State textValue: string = ''
@State inputValue: string = 'click me'
dialogController: CustomDialogController = new CustomDialogController({
builder: CustomDialogExample({
cancel: this.onCancel,
confirm: this.onAccept,
textValue: $textValue,
inputValue: $inputValue,
openAnimation:{
duration: 2000,
iterations: 3,
onFinish: () => {
console.info('openAnimation play end')
},
},
closeAnimation:{
duration: 2000,
iterations: 3,
onFinish: () => {
console.info('closeAnimation play end')
},
}
}),
cancel: this.existApp,
autoCancel: true,
alignment: DialogAlignment.Default,
offset: { dx: 0, dy: -20 },
gridCount: 4,
customStyle: false
})
// 在自定义组件即将析构销毁时将dialogControlle删除和置空
aboutToDisappear() {
delete this.dialogController, // 删除dialogController
this.dialogController = undefined // 将dialogController置空
}
onCancel() {
console.info('Callback when the first button is clicked')
}
onAccept() {
console.info('Callback when the second button is clicked')
}
existApp() {
console.info('Click the callback in the blank area')
}
build() {
Column() {
Button(this.inputValue)
.onClick(() => {
if (this.dialogController != undefined) {
this.dialogController.open()
}
}).backgroundColor(0x317aff)
}.width('100%').margin({ top: 5 })
}
}
\ No newline at end of file
/**
* Copyright (c) 2023 Huawei Device Co., Ltd.
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
@Entry
@Component
struct DatePickerDialogOptions0 {
build() {
Column() {
Button("DatePickerDialog")
.margin(20)
.onClick(() => {
DatePickerDialog.show({
start: new Date("2000-1-1"),
end: new Date("2100-12-31"),
selected: new Date("2023-7-24"),
lunarSwitch: true
}).id("DatePickerDialogOptions0")
})
}.width('100%')
}
}
\ No newline at end of file
/**
* Copyright (c) 2023 Huawei Device Co., Ltd.
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import promptAction from '@ohos.promptAction';
@Entry
@Component
struct DragEvent {
@State targetImage: string = '';
@State targetText: string = 'Drag Text';
@State hyperLinkText: string = 'HyperLink';
@State hyperLinkContent: string = 'HyperLink';
@State imageWidth: number = 100;
@State imageHeight: number = 100;
@State abstractContent: string = "abstract";
@State textContent: string = "";
@State dragBehavior: string = "dragBehavior";
@State dragRet: string = "dragRet";
@State useCustomDropAnimation1: string = "useCustomDropAnimation";
@State imgState: Visibility = Visibility.Visible;
build() {
Row() {
Column() {
Text(this.dragBehavior).id("dragBehavior").margin(5)
Text(this.dragRet).id("dragRet").margin(5)
Text(this.useCustomDropAnimation1).id("useCustomDropAnimation").margin(5)
Image($r('app.media.icon')).margin(5)
.width(100)
.height(100)
.draggable(true)
.margin({left: 15})
.visibility(this.imgState)
.onDragStart((event)=>{
event.setResult(DragRet.DRAG_SUCCESS);
})
.onDragEnd((event)=>{
event.dragBehavior = DragBehavior.MOVE
this.dragBehavior = event.dragBehavior.toString()
event.useCustomDropAnimation === true
if(event.useCustomDropAnimation === true){
this.useCustomDropAnimation1 = "true"
promptAction.showToast({duration: 100, message: 'useCustomDropAnimation==true'});
}
if (event.getResult() === DragRet.DRAG_SUCCESS) {
promptAction.showToast({duration: 100, message: 'Drag Success'});
} else if (event.getResult() === DragRet.DRAG_FAILED) {
promptAction.showToast({duration: 100, message: 'Drag Failed'});
} else if (event.getResult() === DragRet.DRAG_CANCELED) {
promptAction.showToast({duration: 100, message: 'Drag Canceled'});
} else if (event.getResult() === DragRet.DROP_DISABLED) {
promptAction.showToast({duration: 100, message: 'Drop Disabled'});
}
this.dragRet = event.getResult().toString()
})
}.width('90%')
.height('100%')
.margin({left: '5%'})
}
.height('100%')
}
}
\ No newline at end of file
/**
* Copyright (c) 2023 Huawei Device Co., Ltd.
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
@Component
struct HelloComponent {
@State message: string = 'Hello, World!';
build() {
// HelloComponent自定义组件组合系统组件Row和Text
Row() {
Text(this.message)
.onClick(() => {
// 状态变量message的改变驱动UI刷新,UI从'Hello, World!'刷新为'Hello, ArkUI!'
this.message = 'Hello, ArkUI!';
})
}
}
}
@Entry
@Component
struct myPage {
build() {
Column() {
Text('ArkUI message')
HelloComponent({ message: 'Hello, World!' });
Divider()
HelloComponent({ message: '你好!' });
}
}
}
\ No newline at end of file
/**
* Copyright (c) 2023 Huawei Device Co., Ltd.
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
@Entry
@Component
struct Index {
@Builder
SubMenu() {
Menu() {
MenuItem({ content: "复制", labelInfo: "Ctrl+C" })
MenuItem({ content: "粘贴", labelInfo: "Ctrl+V" })
}
}
@Builder
MyMenu(){
Menu() {
MenuItem({
content: "content1",
endIcon: "resource/base/media/icon.png",
labelInfo: "labelInfo1",
}).id("menuItem_options1")
.contentFont({ size: 10 })
.contentFontColor(Color.Blue)
.labelFont({ size: 15 })
.labelFontColor(Color.Red)
MenuItem({
content: "content2",
endIcon: $r("app.media.icon"),
labelInfo: $r("app.string.MenuItem2_labelInfo"),
}).id("menuItem_options2")
MenuItemGroup({
footer: "footer1"
}).id("MenuItemGroup_options1")
MenuItemGroup({
footer: $r("app.string.MenuItemGroup2_footer"),
}).id("MenuItemGroup_options2")
MenuItemGroup({
footer: this.SubMenu.bind(this)
}).id("MenuItemGroup_options3")
}
}
build() {
Row() {
Column() {
Button('click to show menu')
.id("button_menu")
.fontSize(30)
.fontWeight(FontWeight.Bold)
}
.bindMenu(this.MyMenu)
.width('100%')
}
.height('100%')
}
}
\ No newline at end of file
/**
* Copyright (c) 2023 Huawei Device Co., Ltd.
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
@Entry
@Component
struct ModalTransition1 {
@State isShow:boolean = false
@State isShow2:boolean = false
@Builder myBuilder2() {
Column() {
Button("close modal 2")
.margin(10)
.fontSize(20)
.onClick(()=>{
this.isShow2 = false;
})
}
.width('100%')
.height('100%')
.justifyContent(FlexAlign.Center)
}
@Builder myBuilder() {
Column() {
Button("transition modal 2")
.margin(10)
.fontSize(20)
.onClick(()=>{
this.isShow2 = true;
}).bindContentCover(this.isShow2, this.myBuilder2(), {modalTransition: ModalTransition.ALPHA, backgroundColor: Color.Gray, onAppear: () => {console.log("BindContentCover onAppear.")}, onDisappear: () => {console.log("BindContentCover onDisappear.")}})
Button("close modal 1")
.margin(10)
.fontSize(20)
.onClick(()=>{
this.isShow = false;
})
}
.width('100%')
.height('100%')
.justifyContent(FlexAlign.Center)
}
build() {
Column() {
Button("transition modal 1")
.onClick(() => {
this.isShow = true
})
.fontSize(20)
.margin(10)
.bindContentCover($$this.isShow, this.myBuilder(), {modalTransition: ModalTransition.ALPHA, backgroundColor: Color.Pink, onAppear: () => {console.log("BindContentCover onAppear.")}, onDisappear: () => {console.log("BindContentCover onDisappear.")}})
}
.justifyContent(FlexAlign.Center)
.backgroundColor(Color.White)
.width('100%')
.height('100%')
}
}
\ No newline at end of file
/**
* Copyright (c) 2023 Huawei Device Co., Ltd.
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
@Entry
@Component
struct PanGestureEvent {
@State velocityX: number = 0
@State velocityY: number = 0
@State velocity: number = 0
private panOption: PanGestureOptions = new PanGestureOptions({ direction: PanDirection.Left | PanDirection.Right })
build() {
Column() {
Column() {
Text(this.velocityX.toString()).id("velocityX")
Text(this.velocityY.toString()).id("velocityY")
Text(this.velocity.toString()).id("velocity")
}
.height("90%")
.width("90%")
.padding(20)
.border({ width: 3 })
.margin(50)
// 左右拖动触发该手势事件
.gesture(
PanGesture(this.panOption)
.onActionUpdate((event: GestureEvent) => {
this.velocityX = event.velocityX
this.velocityY = event.velocityY
this.velocity = event.velocity
})
)
}
}
}
\ No newline at end of file
/**
* Copyright (c) 2023 Huawei Device Co., Ltd.
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
@Entry
@Component
struct RenderFit1 {
build() {
Column() {
Text("LEFT").id("LEFT").renderFit(RenderFit.LEFT).margin(5)
Text("RIGHT").id("RIGHT").renderFit(RenderFit.RIGHT).margin(5)
Text("TOP_LEFT").id("TOP_LEFT").renderFit(RenderFit.TOP_LEFT).margin(5)
Text("TOP_RIGHT").id("TOP_RIGHT").renderFit(RenderFit.TOP_RIGHT).margin(5)
Text("BOTTOM_LEFT").id("BOTTOM_LEFT").renderFit(RenderFit.BOTTOM_LEFT).margin(5)
Text("BOTTOM_RIGHT").id("BOTTOM_RIGHT").renderFit(RenderFit.BOTTOM_RIGHT).margin(5)
Text("RESIZE_FILL").id("RESIZE_FILL").renderFit(RenderFit.RESIZE_FILL).margin(5)
Text("RESIZE_CONTAIN").id("RESIZE_CONTAIN").renderFit(RenderFit.RESIZE_CONTAIN).margin(5)
Text("RESIZE_CONTAIN_TOP_LEFT").id("RESIZE_CONTAIN_TOP_LEFT").renderFit(RenderFit.RESIZE_CONTAIN_TOP_LEFT).margin(5)
Text("RESIZE_CONTAIN_BOTTOM_RIGHT").id("RESIZE_CONTAIN_BOTTOM_RIGHT").renderFit(RenderFit.RESIZE_CONTAIN_BOTTOM_RIGHT).margin(5)
Text("RESIZE_COVER").id("RESIZE_COVER").renderFit(RenderFit.RESIZE_COVER).margin(5)
Text("RESIZE_COVER_TOP_LEFT").id("RESIZE_COVER_TOP_LEFT").renderFit(RenderFit.RESIZE_COVER_TOP_LEFT).margin(5)
Text("RESIZE_COVER_BOTTOM_RIGHT").id("RESIZE_COVER_BOTTOM_RIGHT").renderFit(RenderFit.RESIZE_COVER_BOTTOM_RIGHT).margin(5)
}.width('90%').height("90%")
}
}
\ No newline at end of file
/**
* Copyright (c) 2023 Huawei Device Co., Ltd.
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
@Entry
@Component
struct RotateOptions1 {
build() {
Column() {
Text('RotateOptions').width('90%').fontColor(0xCCCCCC).padding(15).fontSize(14)
Row().id("RotateOptions")
.rotate({
x: 0,
y: 0,
z: 1,
centerX: '50%',
centerY: '50%',
centerZ: 1,
perspective: 2,
angle: 300
}) // 组件以矢量(0,0,1)为旋转轴,绕中心点顺时针旋转300度
.width(100).height(100).backgroundColor(0xAFEEEE)
}.width('100%').margin({ top: 5 })
}
}
\ No newline at end of file
/**
* Copyright (c) 2023 Huawei Device Co., Ltd.
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
@Entry
@Component
struct RouteType1 {
@State scale1: number = 1
@State opacity1: number = 1
build() {
Column() {
Navigator({ target: 'pages/RouteType2', type: NavigationType.Push }) {
Image($r('app.media.icon')).width('100%').height('100%') // 图片存放在media文件夹下
}
}.scale({ x: this.scale1 }).opacity(this.opacity1)
}
// 自定义方式1:完全自定义转场过程的效果
pageTransition() {
PageTransitionEnter({ type: RouteType.Pop, duration: 1200, curve: Curve.Linear })
.onEnter((type: RouteType, progress: number) => {
this.scale1 = 1
this.opacity1 = progress
}) // 进场过程中会逐帧触发onEnter回调,入参为动效的归一化进度(0% -- 100%)
PageTransitionExit({ duration: 1200, curve: Curve.Ease })
.onExit((type: RouteType, progress: number) => {
this.scale1 = 1 - progress
this.opacity1 = 1
}) // 退场过程中会逐帧触发onExit回调,入参为动效的归一化进度(0% -- 100%)
}
}
\ No newline at end of file
/**
* Copyright (c) 2023 Huawei Device Co., Ltd.
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
@Entry
@Component
struct RouteType2 {
@State scale2: number = 1
@State opacity2: number = 1
build() {
Column() {
Navigator({ target: 'pages/RouteType1', type: NavigationType.Push }) {
Image($r('app.media.icon')).width('100%').height('100%') // 图片存放在media文件夹下
}
}.width('100%').height('100%').scale({ x: this.scale2 }).opacity(this.opacity2)
}
// 自定义方式1:完全自定义转场过程的效果
pageTransition() {
PageTransitionEnter({ type: RouteType.Pop, duration: 1200, curve: Curve.Linear })
.onEnter((type: RouteType, progress: number) => {
this.scale2 = 1
this.opacity2 = progress
}) // 进场过程中会逐帧触发onEnter回调,入参为动效的归一化进度(0% -- 100%)
PageTransitionExit({ duration: 1200, curve: Curve.Ease })
.onExit((type: RouteType, progress: number) => {
this.scale2 = 1 - progress
this.opacity2 = 1
}) // 退场过程中会逐帧触发onExit回调,入参为动效的归一化进度(0% -- 100%)
}
}
\ No newline at end of file
/**
* Copyright (c) 2023 Huawei Device Co., Ltd.
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
@Entry
@Component
struct ShadowTypeStyle {
build() {
Column({ space: 10 }) {
Text('ShadowType: COLOR').fontSize(15).fontColor(0xCCCCCC).width('90%')
Image($r('app.media.icon')).id("ShadowType_COLOR")
.width('90%')
.height(40)
.shadow({type:ShadowType.COLOR,radius:20})
Text('ShadowType: BLUR').fontSize(15).fontColor(0xCCCCCC).width('90%')
Image($r('app.media.icon')).id("ShadowType_BLUR")
.width('90%')
.height(40)
.shadow({type:ShadowType.BLUR,radius:20})
// 添加阴影效果,图片效果不变
Text('ShadowStyle: OUTER_DEFAULT_XS').fontSize(15).fontColor(0xCCCCCC).width('90%')
Image($r('app.media.icon')).id("OUTER_DEFAULT_XS")
.width('90%')
.height(40)
.shadow(ShadowStyle.OUTER_DEFAULT_XS)
.shadow({type:ShadowType.COLOR,radius:20})
Text('ShadowStyle: OUTER_DEFAULT_SM').fontSize(15).fontColor(0xCCCCCC).width('90%')
Image($r('app.media.icon')).id("OUTER_DEFAULT_SM")
.width('90%')
.height(40)
.shadow(ShadowStyle.OUTER_DEFAULT_SM)
Text('ShadowStyle: OUTER_DEFAULT_MD').fontSize(15).fontColor(0xCCCCCC).width('90%')
Image($r('app.media.icon')).id("OUTER_DEFAULT_MD")
.width('90%')
.height(40)
.shadow(ShadowStyle.OUTER_DEFAULT_MD)
Text('ShadowStyle: OUTER_DEFAULT_LG').fontSize(15).fontColor(0xCCCCCC).width('90%')
Image($r('app.media.icon')).id("OUTER_DEFAULT_LG")
.width('90%')
.height(40)
.shadow(ShadowStyle.OUTER_DEFAULT_LG)
Text('ShadowStyle: OUTER_FLOATING_SM').fontSize(15).fontColor(0xCCCCCC).width('90%')
Image($r('app.media.icon')).id("OUTER_FLOATING_SM")
.width('90%')
.height(40)
.shadow(ShadowStyle.OUTER_FLOATING_SM)
Text('ShadowStyle: OUTER_FLOATING_MD').fontSize(15).fontColor(0xCCCCCC).width('90%')
Image($r('app.media.icon')).id("OUTER_FLOATING_MD")
.width('90%')
.height(40)
.shadow(ShadowStyle.OUTER_FLOATING_MD)
}.width('100%').margin({ top: 5 })
}
}
\ No newline at end of file
/**
* Copyright (c) 2023 Huawei Device Co., Ltd.
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
@Entry
@Component
struct TransitionEffectExample1 {
@State flag: boolean = true;
@State show: string = 'show';
build() {
Column() {
Button(this.show).width(80).height(30).margin(30)
.onClick(() => {
// 点击Button控制Image的显示和消失
if (this.flag) {
this.show = 'hide';
} else {
this.show = 'show';
}
this.flag = !this.flag;
})
if (this.flag) {
// Image的显示和消失配置为相同的过渡效果(出现和消失互为逆过程)
// 出现时从指定的透明度为0、绕z轴旋转180°的状态,变为默认的透明度为1、旋转角为0的状态,透明度与旋转动画时长都为2000ms
// 消失时从默认的透明度为1、旋转角为0的状态,变为指定的透明度为0、绕z轴旋转180°的状态,透明度与旋转动画时长都为2000ms
Image($r('app.media.icon')).width(200).height(200)
.transition(TransitionEffect.OPACITY
.animation({ duration: 2000, curve: Curve.Ease }).combine(
TransitionEffect.rotate({ z: 1, centerZ: 1, angle: 180 })
))
}else{
Image($r('app.media.icon')).width(200).height(200)
.transition(TransitionEffect.IDENTITY
.animation({ duration: 2000, curve: Curve.Ease }).combine(
TransitionEffect.rotate({ z: 1, centerZ: 1, angle: 180 })
))
}
Image($r('app.media.icon')).width(200).height(200)
.transition(
TransitionEffect.SLIDE
.animation({ duration: 2000, curve: Curve.Ease })
.combine(
TransitionEffect.rotate({ z: 1, centerZ: 1, angle: 180 })
)
// .asymmetric({
// appear: TransitionEffect,
// disappear: TransitionEffect })
)
}.width('100%')
}
}
\ No newline at end of file
/**
* Copyright (c) 2023 Huawei Device Co., Ltd.
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
@Entry
@Component
struct XComponentType1 {
@State XComponentType1: XComponentType = XComponentType.SURFACE
private surfaceId : string =''
xcomponentController: XComponentController = new XComponentController()
build() {
Column() {
XComponent({
id: 'xcomponent1',
type: XComponentType.SURFACE,
controller: this.xcomponentController
}).id('xcomponent_1')
.onLoad(() => {
this.xcomponentController.setXComponentSurfaceSize({surfaceWidth:1920,surfaceHeight:1080});
this.surfaceId = this.xcomponentController.getXComponentSurfaceId()
console.log(this.surfaceId)
})
.width('640px')
.height('480px')
.margin(5)
XComponent({
id: 'xcomponent2',
type: XComponentType.COMPONENT,
controller: this.xcomponentController
}).id('xcomponent_2')
.onLoad(() => {
this.xcomponentController.setXComponentSurfaceSize({surfaceWidth:1920,surfaceHeight:1080});
this.surfaceId = this.xcomponentController.getXComponentSurfaceId()
console.log(this.surfaceId)
})
.width('640px')
.height('480px')
.margin(5)
XComponent({
id: 'xcomponent3',
type: XComponentType.TEXTURE,
controller: this.xcomponentController
}).id('xcomponent_3')
.onLoad(() => {
this.xcomponentController.setXComponentSurfaceSize({surfaceWidth:1920,surfaceHeight:1080});
this.surfaceId = this.xcomponentController.getXComponentSurfaceId()
console.log(this.surfaceId)
})
.width('640px')
.height('480px')
.margin(5)
}
.backgroundColor(Color.Black)
.position({x: 0, y: 48})
}
}
\ No newline at end of file
......@@ -58,6 +58,8 @@ import NavigationJsunit from './NavigationJsunit.test.ets';
import GridColOffsetJsunit from './GridColoffsetJsunit.test.ets';
import ApiCommponentAddJsunit from './ApiCommponentAddJsunit.test.ets';
import fontJsunit from './fontJsunit.test.ets';
import PanGestureEventJsunit from './PanGestureEventJsunit.test.ets';
import RenderFitJsunit from './RenderFitJsunit.test.ets';
export default function testsuite() {
blankJsunit();
......@@ -105,4 +107,6 @@ export default function testsuite() {
GridColOffsetJsunit();
fontJsunit();
ApiCommponentAddJsunit();
PanGestureEventJsunit();
RenderFitJsunit();
}
\ No newline at end of file
/**
* Copyright (c) 2022 Huawei Device Co., Ltd.
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import { describe, beforeAll, beforeEach, afterEach, afterAll, it, expect } from "@ohos/hypium"
import router from '@system.router';
import {UiComponent, UiDriver, Component, Driver, UiWindow, ON, BY, MatchPattern, DisplayRotation, ResizeDirection, WindowMode, PointerMatrix} from '@ohos.UiTest';
import CommonFunc from '../MainAbility/utils/Common';
import {MessageManager,Callback} from '../MainAbility/utils/MessageManager';
export default function PanGestureEventJsunit() {
describe('PanGestureEventJsunit', function () {
beforeEach(async function (done) {
console.info("PanGestureEventJsunit beforeEach start");
let options = {
uri: 'MainAbility/pages/PanGestureEvent',
}
try {
router.clear();
let pages = router.getState();
console.info("get PanGestureEventJsunit state pages: " + JSON.stringify(pages));
if (!("PanGestureEvent" == pages.name)) {
console.info("get PanGestureEventJsunit state pages.name: " + JSON.stringify(pages.name));
let result = await router.push(options);
await CommonFunc.sleep(2000);
console.info("push PanGestureEventJsunit page result: " + JSON.stringify(result));
}
} catch (err) {
console.error("push PanGestureEventJsunit page error: " + err);
expect().assertFail();
}
done();
});
it('PanGestureEventJsunit_0100', 0, async function (done) {
// Get the information of the GestureEvent
console.info('[PanGestureEventJsunit_0100] START');
let driver = await UiDriver.create()
await driver.swipe(200, 400, 400, 400);
await CommonFunc.sleep(500);
let textComponent = await driver.findComponent(BY.key('velocityX'));
let text = await textComponent.getText();
await CommonFunc.sleep(1000);
expect(text == "0").assertFalse();
console.info('[PanGestureEventJsunit_0100] END');
done();
});
it('PanGestureEventJsunit_0200', 0, async function (done) {
// Get the information of the GestureEvent
console.info('[PanGestureEventJsunit_0200] START');
let driver = await UiDriver.create()
await driver.swipe(200, 400, 400, 400);
await CommonFunc.sleep(500);
let textComponent = await driver.findComponent(BY.key('velocityY'));
let text = await textComponent.getText();
await CommonFunc.sleep(1000);
expect(text == "0").assertFalse();
console.info('[PanGestureEventJsunit_0200] END');
done();
});
it('PanGestureEventJsunit_0300', 0, async function (done) {
// Get the information of the GestureEvent
console.info('[PanGestureEventJsunit_0300] START');
let driver = await UiDriver.create()
await driver.swipe(200, 400, 400, 400);
await CommonFunc.sleep(500);
let textComponent = await driver.findComponent(BY.key('velocity'));
let text = await textComponent.getText();
await CommonFunc.sleep(1000);
expect(text == "0").assertFalse();
console.info('[PanGestureEventJsunit_0300] END');
done();
});
})
}
/**
* Copyright (c) 2022 Huawei Device Co., Ltd.
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import { describe, beforeAll, beforeEach, afterEach, afterAll, it, expect } from "@ohos/hypium"
import router from '@system.router';
import {UiComponent, UiDriver, Component, Driver, UiWindow, ON, BY, MatchPattern, DisplayRotation, ResizeDirection, WindowMode, PointerMatrix} from '@ohos.UiTest';
import CommonFunc from '../MainAbility/utils/Common';
import {MessageManager,Callback} from '../MainAbility/utils/MessageManager';
export default function RenderFitJsunit() {
describe('RenderFitJsunit', function () {
beforeEach(async function (done) {
console.info("RenderFitJsunit beforeEach start");
let options = {
uri: 'MainAbility/pages/RenderFit',
}
try {
router.clear();
let pages = router.getState();
console.info("get RenderFitJsunit state pages: " + JSON.stringify(pages));
if (!("RenderFit" == pages.name)) {
console.info("get RenderFitJsunit state pages.name: " + JSON.stringify(pages.name));
let result = await router.push(options);
await CommonFunc.sleep(2000);
console.info("push RenderFitJsunit page result: " + JSON.stringify(result));
}
} catch (err) {
console.error("push RenderFitJsunit page error: " + err);
expect().assertFail();
}
done();
});
it('RenderFitJsunit_0100', 0, async function (done) {
// Get the information of the RenderFit
console.info('[RenderFitJsunit_0100] START');
let strJson = getInspectorByKey('LEFT');
let obj = JSON.parse(strJson);
console.info("[RenderFitJsunit_0100] LEFT: " + JSON.stringify(obj));
await CommonFunc.sleep(1000);
expect(obj.$attrs.renderFit).assertEqual('RenderFit.LEFT');
console.info('[RenderFitJsunit_0100] END');
done();
});
it('RenderFitJsunit_0200', 0, async function (done) {
// Get the information of the RenderFit
console.info('[RenderFitJsunit_0200] START');
let strJson = getInspectorByKey('RIGHT');
let obj = JSON.parse(strJson);
console.info("[RenderFitJsunit_0200] RIGHT: " + JSON.stringify(obj));
await CommonFunc.sleep(1000);
expect(obj.$attrs.renderFit).assertEqual('RenderFit.RIGHT');
console.info('[RenderFitJsunit_0200] END');
done();
});
it('RenderFitJsunit_0300', 0, async function (done) {
// Get the information of the RenderFit
console.info('[RenderFitJsunit_0300] START');
let strJson = getInspectorByKey('TOP_LEFT');
let obj = JSON.parse(strJson);
console.info("[RenderFitJsunit_0300] TOP_LEFT: " + JSON.stringify(obj));
await CommonFunc.sleep(1000);
expect(obj.$attrs.renderFit).assertEqual('RenderFit.TOP_LEFT');
console.info('[RenderFitJsunit_0300] END');
done();
});
it('RenderFitJsunit_0400', 0, async function (done) {
// Get the information of the RenderFit
console.info('[RenderFitJsunit_0400] START');
let strJson = getInspectorByKey('TOP_RIGHT');
let obj = JSON.parse(strJson);
console.info("[RenderFitJsunit_0400] TOP_RIGHT: " + JSON.stringify(obj));
await CommonFunc.sleep(1000);
expect(obj.$attrs.renderFit).assertEqual('RenderFit.TOP_RIGHT');
console.info('[RenderFitJsunit_0400] END');
done();
});
it('RenderFitJsunit_0500', 0, async function (done) {
// Get the information of the RenderFit
console.info('[RenderFitJsunit_0500] START');
let strJson = getInspectorByKey('BOTTOM_LEFT');
let obj = JSON.parse(strJson);
console.info("[RenderFitJsunit_0500] BOTTOM_LEFT: " + JSON.stringify(obj));
await CommonFunc.sleep(1000);
expect(obj.$attrs.renderFit).assertEqual('RenderFit.BOTTOM_LEFT');
console.info('[RenderFitJsunit_0500] END');
done();
});
it('RenderFitJsunit_0600', 0, async function (done) {
// Get the information of the RenderFit
console.info('[RenderFitJsunit_0600] START');
let strJson = getInspectorByKey('BOTTOM_RIGHT');
let obj = JSON.parse(strJson);
console.info("[RenderFitJsunit_0600] BOTTOM_RIGHT: " + JSON.stringify(obj));
await CommonFunc.sleep(1000);
expect(obj.$attrs.renderFit).assertEqual('RenderFit.BOTTOM_RIGHT');
console.info('[RenderFitJsunit_0600] END');
done();
});
it('RenderFitJsunit_0700', 0, async function (done) {
// Get the information of the RenderFit
console.info('[RenderFitJsunit_0700] START');
let strJson = getInspectorByKey('RESIZE_FILL');
let obj = JSON.parse(strJson);
console.info("[RenderFitJsunit_0700] RESIZE_FILL: " + JSON.stringify(obj));
await CommonFunc.sleep(1000);
expect(obj.$attrs.renderFit).assertEqual('RenderFit.RESIZE_FILL');
console.info('[RenderFitJsunit_0700] END');
done();
});
it('RenderFitJsunit_0800', 0, async function (done) {
// Get the information of the RenderFit
console.info('[RenderFitJsunit_0800] START');
let strJson = getInspectorByKey('RESIZE_CONTAIN');
let obj = JSON.parse(strJson);
console.info("[RenderFitJsunit_0800] RESIZE_CONTAIN: " + JSON.stringify(obj));
await CommonFunc.sleep(1000);
expect(obj.$attrs.renderFit).assertEqual('RenderFit.RESIZE_CONTAIN');
console.info('[RenderFitJsunit_0800] END');
done();
});
it('RenderFitJsunit_0900', 0, async function (done) {
// Get the information of the RenderFit
console.info('[RenderFitJsunit_0900] START');
let strJson = getInspectorByKey('RESIZE_CONTAIN_TOP_LEFT');
let obj = JSON.parse(strJson);
console.info("[RenderFitJsunit_0900] RESIZE_CONTAIN_TOP_LEFT: " + JSON.stringify(obj));
await CommonFunc.sleep(1000);
expect(obj.$attrs.renderFit).assertEqual('RenderFit.RESIZE_CONTAIN_TOP_LEFT');
console.info('[RenderFitJsunit_0900] END');
done();
});
it('RenderFitJsunit_1000', 0, async function (done) {
// Get the information of the RenderFit
console.info('[RenderFitJsunit_1000] START');
let strJson = getInspectorByKey('RESIZE_CONTAIN_BOTTOM_RIGHT');
let obj = JSON.parse(strJson);
console.info("[RenderFitJsunit_1000] RESIZE_CONTAIN_BOTTOM_RIGHT: " + JSON.stringify(obj));
await CommonFunc.sleep(1000);
expect(obj.$attrs.renderFit).assertEqual('RenderFit.RESIZE_CONTAIN_BOTTOM_RIGHT');
console.info('[RenderFitJsunit_1000] END');
done();
});
it('RenderFitJsunit_1100', 0, async function (done) {
// Get the information of the RenderFit
console.info('[RenderFitJsunit_1100] START');
let strJson = getInspectorByKey('RESIZE_COVER');
let obj = JSON.parse(strJson);
console.info("[RenderFitJsunit_1100] RESIZE_COVER: " + JSON.stringify(obj));
await CommonFunc.sleep(1000);
expect(obj.$attrs.renderFit).assertEqual('RenderFit.RESIZE_COVER');
console.info('[RenderFitJsunit_1100] END');
done();
});
it('RenderFitJsunit_1200', 0, async function (done) {
// Get the information of the RenderFit
console.info('[RenderFitJsunit_1200] START');
let strJson = getInspectorByKey('RESIZE_COVER_TOP_LEFT');
let obj = JSON.parse(strJson);
console.info("[RenderFitJsunit_1200] RESIZE_COVER_TOP_LEFT: " + JSON.stringify(obj));
await CommonFunc.sleep(1000);
expect(obj.$attrs.renderFit).assertEqual('RenderFit.RESIZE_COVER_TOP_LEFT');
console.info('[RenderFitJsunit_1200] END');
done();
});
it('RenderFitJsunit_1300', 0, async function (done) {
// Get the information of the RenderFit
console.info('[RenderFitJsunit_1300] START');
let strJson = getInspectorByKey('RESIZE_COVER_BOTTOM_RIGHT');
let obj = JSON.parse(strJson);
console.info("[RenderFitJsunit_1300] RESIZE_COVER_BOTTOM_RIGHT: " + JSON.stringify(obj));
await CommonFunc.sleep(1000);
expect(obj.$attrs.renderFit).assertEqual('RenderFit.RESIZE_COVER_BOTTOM_RIGHT');
console.info('[RenderFitJsunit_1300] END');
done();
});
})
}
......@@ -27,6 +27,14 @@
{
"name": "app_name",
"value": "Demo"
},
{
"name": "MenuItem2_labelInfo",
"value": "labelInfo2"
},
{
"name": "MenuItemGroup2_footer",
"value": "footer2"
}
]
}
......@@ -71,6 +71,24 @@
"MainAbility/pages/createBuilderadd",
"MainAbility/pages/dragAdd",
"MainAbility/pages/TouchAdd",
"MainAbility/pages/drwableAdd"
"MainAbility/pages/drwableAdd",
"MainAbility/pages/ClickMouseTouchEvent",
"MainAbility/pages/DragEvent",
"MainAbility/pages/MenuItemGroupOptions",
"MainAbility/pages/PanGestureEvent",
"MainAbility/pages/RotateOptions",
"MainAbility/pages/ShadowTypeStyle",
"MainAbility/pages/TransitionEffect",
"MainAbility/pages/ApiRect",
"MainAbility/pages/BlurStyle",
"MainAbility/pages/CanvasRenderer",
"MainAbility/pages/CustomDialogControllerOptions",
"MainAbility/pages/DatePickerDialogOptions",
"MainAbility/pages/EntryOptions",
"MainAbility/pages/ModalTransition",
"MainAbility/pages/RenderFit",
"MainAbility/pages/Xcomponent",
"MainAbility/pages/RouteType1",
"MainAbility/pages/RouteType2"
]
}
\ No newline at end of file
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册