提交 5e5f831a 编写于 作者: B bayanxing

api add

Signed-off-by: Nbayanxing <bayanxing@kaihong.com>
上级 05a336a2
...@@ -79,6 +79,7 @@ ...@@ -79,6 +79,7 @@
"pages/common", "pages/common",
"pages/common_ts_ets_api", "pages/common_ts_ets_api",
"pages/curves", "pages/curves",
"pages/dom",
"pages/ellipse", "pages/ellipse",
"pages/featureAbility", "pages/featureAbility",
"pages/focusControl", "pages/focusControl",
...@@ -89,6 +90,7 @@ ...@@ -89,6 +90,7 @@
"pages/grid_col", "pages/grid_col",
"pages/grid_row", "pages/grid_row",
"pages/gridItem", "pages/gridItem",
"pages/image",
"pages/inspector", "pages/inspector",
"pages/lazyForEach", "pages/lazyForEach",
"pages/line", "pages/line",
...@@ -96,6 +98,7 @@ ...@@ -96,6 +98,7 @@
"pages/list_item", "pages/list_item",
"pages/mediaQuery", "pages/mediaQuery",
"pages/navigator", "pages/navigator",
"pages/onVisibleAreaChange",
"pages/page1", "pages/page1",
"pages/pageRoute", "pages/pageRoute",
"pages/page_transition", "pages/page_transition",
......
...@@ -22,6 +22,7 @@ export default ...@@ -22,6 +22,7 @@ export default
struct CircleNe { struct CircleNe {
@State w: string = "100px"; @State w: string = "100px";
@State h: string = "100px"; @State h: string = "100px";
aboutToAppear() { aboutToAppear() {
Log.showInfo(TAG, `aboutToAppear CircleNew start`) Log.showInfo(TAG, `aboutToAppear CircleNew start`)
} }
...@@ -52,6 +53,10 @@ struct CircleNe { ...@@ -52,6 +53,10 @@ struct CircleNe {
.height(`${this.h}`) .height(`${this.h}`)
.key('circle') .key('circle')
Image($rawfile('test.png'))
.mask(new Circle({ width: '150px', height: '150px' }).fill(Color.Gray))
.width('500px').height('280px')
}.width("100%").height("100%") }.width("100%").height("100%")
} }
} }
......
...@@ -21,6 +21,7 @@ const TAG = 'ets_apiLack_add'; ...@@ -21,6 +21,7 @@ const TAG = 'ets_apiLack_add';
@Component @Component
export default struct CommonBackgroundBlurStyle { export default struct CommonBackgroundBlurStyle {
@State value: string = '' @State value: string = ''
aboutToAppear() { aboutToAppear() {
Log.showInfo(TAG, `aboutToAppear CommonBackgroundBlurStyle start`) Log.showInfo(TAG, `aboutToAppear CommonBackgroundBlurStyle start`)
} }
...@@ -42,6 +43,42 @@ export default struct CommonBackgroundBlurStyle { ...@@ -42,6 +43,42 @@ export default struct CommonBackgroundBlurStyle {
.opacity(1) .opacity(1)
} }
buttonTab(){
let keyEventDown = {
isPressed: true,
keyCode: 2049,
keyDownDuration: 0,
isIntercepted: false
}
let res1 = inputEventClient.injectEvent({KeyEvent: keyEventDown});
let keyEventUp = {
isPressed: false,
keyCode: 2049,
keyDownDuration: 0,
isIntercepted: false
}
let res2 = inputEventClient.injectEvent({KeyEvent: keyEventUp});
}
buttonOnKey(){
let keyEventDown = {
isPressed: true,
keyCode: 2054,
keyDownDuration: 0,
isIntercepted: false
}
let res3 = inputEventClient.injectEvent({KeyEvent: keyEventDown});
let keyEventUp = {
isPressed: false,
keyCode: 2054,
keyDownDuration: 0,
isIntercepted: false
}
let res4 = inputEventClient.injectEvent({KeyEvent: keyEventUp});
}
build() { build() {
Flex({ direction: FlexDirection.Column, alignItems: ItemAlign.Center, justifyContent: FlexAlign.Center }) { Flex({ direction: FlexDirection.Column, alignItems: ItemAlign.Center, justifyContent: FlexAlign.Center }) {
...@@ -131,13 +168,8 @@ export default struct CommonBackgroundBlurStyle { ...@@ -131,13 +168,8 @@ export default struct CommonBackgroundBlurStyle {
Button('common-OnKeyEvent') Button('common-OnKeyEvent')
.onClick(()=>{ .onClick(()=>{
let keyEvent = { this.buttonTab()
isPressed: true, this.buttonOnKey()
keyCode: 2054,
keyDownDuration: 0,
isIntercepted: false
}
let res = inputEventClient.injectEvent({KeyEvent: keyEvent});
}) })
.key("onKeyEventButton") .key("onKeyEventButton")
.onKeyEvent((event: KeyEvent) => { .onKeyEvent((event: KeyEvent) => {
......
...@@ -19,7 +19,7 @@ import events_emitter from '@ohos.events.emitter'; ...@@ -19,7 +19,7 @@ import events_emitter from '@ohos.events.emitter';
let varA = AppStorage.Link('varA') let varA = AppStorage.Link('varA')
//Environment.EnvProp("accessibilityEnabled", "default") //Environment.EnvProp("accessibilityEnabled", "default")
//PersistentStorage.PersistProp("highScore", 0) PersistentStorage.PersistProp("highScore", 0)
const TAG = 'ets_apiLack_add'; const TAG = 'ets_apiLack_add';
@Entry @Entry
...@@ -89,7 +89,6 @@ export default struct Common_ts_ets_apiStaticClear { ...@@ -89,7 +89,6 @@ export default struct Common_ts_ets_apiStaticClear {
.key("EnvPropText") .key("EnvPropText")
.onClick(() => { .onClick(() => {
var enable = AppStorage.Get("accessibilityEnabled"); var enable = AppStorage.Get("accessibilityEnabled");
// console.log(enable.toString())
try { try {
var backData = { var backData = {
data: { data: {
......
...@@ -22,6 +22,9 @@ const TAG = 'ets_apiLack_add'; ...@@ -22,6 +22,9 @@ const TAG = 'ets_apiLack_add';
@Component @Component
export default struct CurvesSteps { export default struct CurvesSteps {
@State curveApi:string = "success" @State curveApi:string = "success"
@State curve1:ICurve = Curves.springMotion(0.40, 0.99, 0)
@State curve2:ICurve = Curves.responsiveSpringMotion(0.40, 0.99, 0);
aboutToAppear() { aboutToAppear() {
Log.showInfo(TAG, `aboutToAppear CurvesSteps start`) Log.showInfo(TAG, `aboutToAppear CurvesSteps start`)
} }
...@@ -58,6 +61,8 @@ export default struct CurvesSteps { ...@@ -58,6 +61,8 @@ export default struct CurvesSteps {
var backData = { var backData = {
data: { data: {
"curveApi": this.curveApi, "curveApi": this.curveApi,
"curveSpringMotion": this.curve1,
"curveResSpringMotion": this.curve2
} }
} }
let backEvent = { let backEvent = {
......
// @ts-nocheck
/**
* Copyright (c) 2022 Shenzhen Kaihong Digital Industry Development 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 Log from '../common/Log.ets';
const TAG = 'ets_apiLack_add';
@Entry
@Component
export default struct DomCreateElement {
aboutToAppear() {
Log.showInfo(TAG, `aboutToAppear DomCreateElement start`)
}
aboutToDisappear() {
Log.showInfo(TAG, `aboutToDisAppear DomCreateElement end`)
}
build() {
Flex({ direction: FlexDirection.Column, alignItems: ItemAlign.Center, justifyContent: FlexAlign.Center }) {
Text("dom-CreateElement")
.width(100)
.height(70)
.fontSize(20)
.opacity(1)
.align(Alignment.TopStart)
.fontColor(0xCCCCCC)
.lineHeight(25)
.border({ width: 1 })
.padding(10)
.textAlign(TextAlign.Center)
.textOverflow({ overflow: TextOverflow.None })
.key("createElementText")
.onClick(() => {
dom.createElement('div')
})
}.width("100%").height("100%")
}
}
...@@ -22,6 +22,7 @@ export default ...@@ -22,6 +22,7 @@ export default
struct EllipseNe { struct EllipseNe {
@State w: string = "300.00px"; @State w: string = "300.00px";
@State h: string = "300.00px"; @State h: string = "300.00px";
aboutToAppear() { aboutToAppear() {
Log.showInfo(TAG, `aboutToAppear EllipseNe start`) Log.showInfo(TAG, `aboutToAppear EllipseNe start`)
} }
...@@ -46,6 +47,11 @@ struct EllipseNe { ...@@ -46,6 +47,11 @@ struct EllipseNe {
.textAlign(TextAlign.Center) .textAlign(TextAlign.Center)
.textOverflow({ overflow: TextOverflow.None }) .textOverflow({ overflow: TextOverflow.None })
.key("neText") .key("neText")
Image($rawfile('test.png'))
.mask(new Ellipse({ width: '150px', height: '150px' }).fill(Color.Gray))
.width('500px').height('280px')
Ellipse().width(`${this.w}`).height(`${this.h}`).key('ellipse') Ellipse().width(`${this.w}`).height(`${this.h}`).key('ellipse')
}.width('100%').height('100%') }.width('100%').height('100%')
} }
......
// @ts-nocheck
/**
* Copyright (c) 2022 Shenzhen Kaihong Digital Industry Development 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 Log from '../common/Log.ets';
const TAG = 'ets_apiLack_add';
import events_emitter from '@ohos.events.emitter';
@Entry
@Component
export default
struct ImageExample {
build() {
Column() {
Column() {
Column() {
Image($rawfile('test.png'))
.width(240).height(240)
.colorFilter([1,2,3])
.overlay('colorFilter', { align: Alignment.Bottom, offset: { x: 0, y: -15 } })
}.border({ color: Color.Black, width: 2 })
}.width('100%')
}.padding({ top: 20 })
}
}
\ No newline at end of file
...@@ -15,6 +15,7 @@ ...@@ -15,6 +15,7 @@
import Log from '../common/Log.ets'; import Log from '../common/Log.ets';
const TAG = 'ets_apiLack_add'; const TAG = 'ets_apiLack_add';
let my_line = new Line()
@Entry @Entry
@Component @Component
......
/**
* Copyright (c) 2022 Shenzhen Kaihong Digital Industry Development 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 ScrollExample {
scroller: Scroller = new Scroller()
private arr: number[] = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
@State testTextStr: string = "test"
@State testRowStr: string = "test"
build() {
Column() {
Column() {
Text(this.testTextStr)
.fontSize(20)
Text(this.testRowStr)
.fontSize(20)
}
.height(100)
.backgroundColor(Color.Gray)
.opacity(0.3)
Scroll(this.scroller) {
Column() {
Text("Test Text Visible Change")
.fontSize(20)
.height(200)
.margin({ top: 50, bottom: 20 })
.backgroundColor(Color.Green)
// 通过设置ratios为[0.0, 1.0],实现当组件完全显示或完全消失在屏幕中时触发回调
.onVisibleAreaChange([0.0, 1.0], (isVisible: boolean, currentRatio: number) => {
console.info("Test Text isVisible: " + isVisible + ", currentRatio:" + currentRatio)
if (isVisible && currentRatio >= 1.0) {
console.info("Test Text is fully visible. currentRatio:" + currentRatio)
this.testTextStr = "Test Text is fully visible"
}
if (!isVisible && currentRatio <= 0.0) {
console.info("Test Text is completely invisible.")
this.testTextStr = "Test Text is completely invisible"
}
})
Row() {
Text("Test Row Visible Change")
.fontSize(20)
.margin({ bottom: 20 })
}
.height(200)
.backgroundColor(Color.Yellow)
.onVisibleAreaChange([0.0, 1.0], (isVisible: boolean, currentRatio: number) => {
console.info("Test Row isVisible:" + isVisible + ", currentRatio:" + currentRatio)
if (isVisible && currentRatio >= 1.0) {
console.info("Test Row is fully visible.")
this.testRowStr = "Test Row is fully visible"
}
if (!isVisible && currentRatio <= 0.0) {
console.info("Test Row is is completely invisible.")
this.testRowStr = "Test Row is is completely invisible"
}
})
ForEach(this.arr, (item) => {
Text(item.toString())
.width('90%')
.height(150)
.backgroundColor(0xFFFFFF)
.borderRadius(15)
.fontSize(16)
.textAlign(TextAlign.Center)
.margin({ top: 10 })
}, item => item)
}.width('100%')
}
.backgroundColor(0x317aff)
.scrollable(ScrollDirection.Vertical)
.scrollBar(BarState.On)
.scrollBarColor(Color.Gray)
.scrollBarWidth(30)
.onScroll((xOffset: number, yOffset: number) => {
console.info(xOffset + ' ' + yOffset)
})
.onScrollEdge((side: Edge) => {
console.info('To the edge')
})
.onScrollEnd(() => {
console.info('Scroll Stop')
})
}.width('100%').height('100%').backgroundColor(0xDCDCDC)
}
}
\ No newline at end of file
...@@ -53,6 +53,10 @@ export default struct PathNew { ...@@ -53,6 +53,10 @@ export default struct PathNew {
Path().width("100px").height("100px").commands('M150 0 L300 300 L0 300 Z') Path().width("100px").height("100px").commands('M150 0 L300 300 L0 300 Z')
.key("Path") .key("Path")
Image($rawfile('test.png'))
.mask(new Path({ width: '150px', height: '150px' }).fill(Color.Gray))
.width('500px').height('280px')
}.width("100%").height("100%") }.width("100%").height("100%")
} }
} }
......
...@@ -61,18 +61,6 @@ export default struct PromptShowDialog { ...@@ -61,18 +61,6 @@ export default struct PromptShowDialog {
} catch (err) { } catch (err) {
console.info("showDialog emit action state err: " + JSON.stringify(err.message)) console.info("showDialog emit action state err: " + JSON.stringify(err.message))
} }
// prompt.showDialog({
// title: 'Title Info',
// message: 'Message Info',
// buttons: [
// { text: 'button1', color: 'red' },
// { text: 'button2', color: 'blue' }
// ]
// }).then(data => {
// console.info('showDialog success, click button: ' + data.index)
// }).catch(err => {
// console.info('showDialog error: ' + err)
// })
}) })
Text("prompt-ShowActionMenu") Text("prompt-ShowActionMenu")
...@@ -104,19 +92,6 @@ export default struct PromptShowDialog { ...@@ -104,19 +92,6 @@ export default struct PromptShowDialog {
} catch (err) { } catch (err) {
console.info("showActionMenu emit action state err: " + JSON.stringify(err.message)) console.info("showActionMenu emit action state err: " + JSON.stringify(err.message))
} }
// prompt.showActionMenu({
// title: 'Title Info',
// buttons: [
// { text: 'item1', color: '#666666' },
// { text: 'item2', color: '#000000' }
// ]
// }).then(data => {
// var result=true
// console.info('showDialog success, click button: ' + data.index)
// }).catch(err => {
// console.info('showDialog error: ' + err)
// })
}) })
}.width("100%").height("100%") }.width("100%").height("100%")
......
/**
* Copyright (c) 2022 Shenzhen Kaihong Digital Industry Development 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 prompt from '@ohos.prompt'
import Log from '../common/Log.ets';
import events_emitter from '@ohos.events.emitter';
const TAG = 'ets_apiLack_add';
@Entry
@Component
export default struct PromptShowDialog {
aboutToAppear() {
Log.showInfo(TAG, `aboutToAppear PromptShowDialog start`)
}
aboutToDisappear() {
Log.showInfo(TAG, `aboutToDisAppear PromptShowDialog end`)
}
build() {
Flex({ direction: FlexDirection.Column, alignItems: ItemAlign.Center, justifyContent: FlexAlign.Center }) {
Text("prompt-ShowDialog")
.width(100)
.height(70)
.fontSize(20)
.opacity(1)
.align(Alignment.TopStart)
.fontColor(0xCCCCCC)
.lineHeight(25)
.border({ width: 1 })
.padding(10)
.textAlign(TextAlign.Center)
.textOverflow({ overflow: TextOverflow.None })
.onClick(() => {
prompt.showDialog({
title: 'Title Info',
message: 'Message Info',
buttons: [
{ text: 'button1', color: 'red' },
{ text: 'button2', color: 'blue' }
]
}).then(data => {
console.info('showDialog success, click button: ' + data.index)
}).catch(err => {
console.info('showDialog error: ' + err)
})
})
Text("prompt-ShowActionMenu")
.width(100)
.height(70)
.fontSize(20)
.opacity(1)
.align(Alignment.TopStart)
.fontColor(0xCCCCCC)
.lineHeight(25)
.border({ width: 1 })
.padding(10)
.textAlign(TextAlign.Center)
.textOverflow({ overflow: TextOverflow.None })
.onClick(() => {
prompt.showActionMenu({
title: 'Title Info',
buttons: [
{ text: 'item1', color: '#666666' },
{ text: 'item2', color: '#000000' }
]
}).then(data => {
var result=true
console.info('showDialog success, click button: ' + data.index)
}).catch(err => {
console.info('showDialog error: ' + err)
})
})
}.width("100%").height("100%")
}
}
...@@ -54,6 +54,10 @@ export default struct RectNe { ...@@ -54,6 +54,10 @@ export default struct RectNe {
Rect({ width: '90%', height: "50px" }).radiusHeight(20).radiusWidth(20) Rect({ width: '90%', height: "50px" }).radiusHeight(20).radiusWidth(20)
.key("Rect") .key("Rect")
Image($rawfile('test.png'))
.mask(new Rect({ width: '150px', height: '150px' }).fill(Color.Gray))
.width('500px').height('280px')
}.width("100%").height("100%") }.width("100%").height("100%")
} }
} }
......
...@@ -21,7 +21,6 @@ const TAG = 'ets_apiLack_add'; ...@@ -21,7 +21,6 @@ const TAG = 'ets_apiLack_add';
@Component @Component
export default export default
struct ShapeNe { struct ShapeNe {
aboutToAppear() { aboutToAppear() {
Log.showInfo(TAG, `aboutToAppear ShapeNe start`) Log.showInfo(TAG, `aboutToAppear ShapeNe start`)
} }
...@@ -47,6 +46,16 @@ struct ShapeNe { ...@@ -47,6 +46,16 @@ struct ShapeNe {
.textOverflow({ overflow: TextOverflow.None }) .textOverflow({ overflow: TextOverflow.None })
.key("neText") .key("neText")
Shape() {
Path().width(300).height(10).commands('M0 0 L900 0')
}
.viewPort({ x: 0, y: -5, width: 300, height: 20 })
.stroke(0xEE8443).strokeWidth(10).strokeDashArray([20]).strokeDashOffset(10)
Shape() {
Path().width(300).height(10).commands('M0 0 L900 0')
}.viewPort({ x: 0, y: -5, width: 300, height: 20 }).stroke(0xEE8443).strokeWidth(10).strokeOpacity(0.5)
}.width("100%").height("100%") }.width("100%").height("100%")
} }
} }
......
// @ts-nocheck
/** /**
* Copyright (c) 2021 Huawei Device Co., Ltd. * Copyright (c) 2021 Huawei Device Co., Ltd.
* Licensed under the Apache License, Version 2.0 (the "License"); * Licensed under the Apache License, Version 2.0 (the "License");
...@@ -61,47 +62,47 @@ import webGetTitleJsunit from './web.test.ets'; ...@@ -61,47 +62,47 @@ import webGetTitleJsunit from './web.test.ets';
import xcomponentGetXComponentContextJsunit from './xcomponent.test.ets'; import xcomponentGetXComponentContextJsunit from './xcomponent.test.ets';
export default function testsuite() { export default function testsuite() {
lazyForEachOnDataAddJsunit() // lazyForEachOnDataAddJsunit()
alphabetIndexerOnSelectJsunit() // alphabetIndexerOnSelectJsunit()
checkBoxGroupSelectAllJsunit() // checkBoxGroupSelectAllJsunit()
circleNewJsunit() // circleNewJsunit()
curvesStepsJsunit() // curvesStepsJsunit()
common_ts_ets_apiStaticClearJsunit() common_ts_ets_apiStaticClearJsunit()
commonBackgroundBlurStyleJsunit() commonBackgroundBlurStyleJsunit()
ellipseNeJsunit() // ellipseNeJsunit()
featureAbilityStartAbilityJsunit() // featureAbilityStartAbilityJsunit()
gaugeColorsJsunit() // gaugeColorsJsunit()
gestureSetDirectionJsunit() // gestureSetDirectionJsunit()
globalJsunit() // globalJsunit()
gridMaxCountJsunit() // gridMaxCountJsunit()
gridItemOnSelectJsunit() // gridItemOnSelectJsunit()
inspectorJsunit() // inspectorJsunit()
lineNeJsunit() // lineNeJsunit()
listNewJsunit() // listNewJsunit()
list_itemOnSelectJsunit() // list_itemOnSelectJsunit()
mediaQueryOffJsunit() // mediaQueryOffJsunit()
navigatorTargetJsunit() // navigatorTargetJsunit()
pageRouteTest() // pageRouteTest()
panelBackgroundMaskJsunit() // panelBackgroundMaskJsunit()
pathNewTest() // pathNewTest()
polygonNewJsunit() // polygonNewJsunit()
polyLineNeJsunit() // polyLineNeJsunit()
progressScaleCountJsunit() // progressScaleCountJsunit()
promptShowDialogJsunit() // promptShowDialogJsunit()
rectNeJsunit() // rectNeJsunit()
scrollOnScrollBeginJsunit() // scrollOnScrollBeginJsunit()
searchOnCutJsunit() // searchOnCutJsunit()
selectOnSelectJsunit() // selectOnSelectJsunit()
sideBarShowSideBarJsunit() // sideBarShowSideBarJsunit()
stackAlignContentJsunit() // stackAlignContentJsunit()
stateManagementGetSharedJsunit() // stateManagementGetSharedJsunit()
swiperCurveJsunit() // swiperCurveJsunit()
tabsBarPositionJsunit() // tabsBarPositionJsunit()
textMinFontSizeJsunit() // textMinFontSizeJsunit()
textAreaOnCutJsunit() // textAreaOnCutJsunit()
textInputOnEditChangeJsunit() // textInputOnEditChangeJsunit()
textPickerDefaultPickerItemHeightJsunit() // textPickerDefaultPickerItemHeightJsunit()
videoOnFullscreenChangeJsunit() // videoOnFullscreenChangeJsunit()
webGetTitleJsunit() // webGetTitleJsunit()
xcomponentGetXComponentContextJsunit() // xcomponentGetXComponentContextJsunit()
} }
\ No newline at end of file
...@@ -50,6 +50,9 @@ export default { ...@@ -50,6 +50,9 @@ export default {
want: { want: {
bundleName: "com.example.myapplication", bundleName: "com.example.myapplication",
abilityName: "com.example.myapplication.MainAbility", abilityName: "com.example.myapplication.MainAbility",
"parameters": {
DIMENSION_KEY: FormDimension.Dimension_1_2
}
}, },
name: "plugintemplate", name: "plugintemplate",
data: { data: {
......
// @ts-nocheck
/** /**
* Copyright (c) 2022 Shenzhen Kaihong Digital Industry Development Co., Ltd. * Copyright (c) 2022 Shenzhen Kaihong Digital Industry Development Co., Ltd.
* Licensed under the Apache License, Version 2.0 (the "License"); * Licensed under the Apache License, Version 2.0 (the "License");
...@@ -59,7 +60,7 @@ struct CanvasActualBoundingBoxAscent { ...@@ -59,7 +60,7 @@ struct CanvasActualBoundingBoxAscent {
this.context.fillText("fontBoundingBoxDescent:" + this.context.measureText("Hello World!").fontBoundingBoxDescent, 20, 600) this.context.fillText("fontBoundingBoxDescent:" + this.context.measureText("Hello World!").fontBoundingBoxDescent, 20, 600)
this.context.fillText("hangingBaseline:" + this.context.measureText("Hello World!").hangingBaseline, 20, 650) this.context.fillText("hangingBaseline:" + this.context.measureText("Hello World!").hangingBaseline, 20, 650)
this.context.fillText("ideographicBaseline" + this.context.measureText("Hello World!").ideographicBaseline, 20, 700) this.context.fillText("ideographicBaseline" + this.context.measureText("Hello World!").ideographicBaseline, 20, 700)
//this.context.fillText("antialias" + this.context.measureText("Hello World!").antialias, 20, 700) this.context.fillText("antialias" + this.context.measureText("Hello World!").antialias, 20, 700)
}) })
} }
.width('100%') .width('100%')
......
...@@ -66,6 +66,10 @@ struct CheckBoxGroupPart { ...@@ -66,6 +66,10 @@ struct CheckBoxGroupPart {
.selectedColor(0xed6f21) .selectedColor(0xed6f21)
.onChange((itemName:CheckboxGroupResult) => { .onChange((itemName:CheckboxGroupResult) => {
console.info("TextPicker::dialogResult is" + JSON.stringify(itemName)) console.info("TextPicker::dialogResult is" + JSON.stringify(itemName))
console.info("TextPicker::dialogResult is" + JSON.stringify(itemName.status))
if(itemName.status === SelectStatus.Part){
console.info("CheckboxGroup SelectStatus.Part")
}
try { try {
var backData = { var backData = {
data: { data: {
......
...@@ -100,7 +100,9 @@ struct ListIdle { ...@@ -100,7 +100,9 @@ struct ListIdle {
.chainAnimation(false) // 联动特效关闭 .chainAnimation(false) // 联动特效关闭
.onScroll((scrollOffset: 5, scrollState:ScrollState) => { .onScroll((scrollOffset: 5, scrollState:ScrollState) => {
console.info('scrollOffset' + scrollOffset) console.info('scrollOffset' + scrollOffset)
console.info('scrollState ' + scrollState) console.info('scrollState ' + ScrollState.Scroll)
console.info('scrollState ' + ScrollState.Idle)
console.info('scrollState ' + ScrollState.Fling)
}) })
.onClick(()=>{ .onClick(()=>{
try { try {
......
/**
* Copyright (c) 2021 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 Log from '../common/Log.ets';
const TAG = 'ets_apiLack_add';
@Entry
@Component
struct PopupExample {
@State noHandlePopup: boolean = false
@State handlePopup: boolean = false
@State customPopup: boolean = false
aboutToAppear() {
Log.showInfo(TAG, `aboutToAppear Popup start`)
}
aboutToDisappear(){
Log.showInfo(TAG, `aboutToDisAppear Popup end`)
}
@Builder popupBuilder() {
Row({ space: 2 }) {
Image($rawfile('test.png')).width(24).height(24).margin({ left: -5 })
Text('Custom Popup').fontSize(10)
}.width(100).height(50).backgroundColor(Color.White)
}
build() {
Flex({ direction: FlexDirection.Column }) {
Button('no handle popup')
.onClick(() => {
this.noHandlePopup = !this.noHandlePopup
})
.bindPopup(this.noHandlePopup, {
message: 'content1 content1',
placementOnTop: false,
arrowOffset: "100px",
onStateChange: (e) => {
console.info(e.isVisible.toString())
if (!e.isVisible) {
this.noHandlePopup = false
}
}
})
.position({ x: 100, y: 50 })
Button('with handle popup')
.onClick(() => {
this.handlePopup = !this.handlePopup
})
.bindPopup(this.handlePopup, {
message: 'content2 content2',
placementOnTop: true,
primaryButton: {
value: 'ok',
action: () => {
this.handlePopup = !this.handlePopup
console.info('secondaryButton click')
}
},
onStateChange: (e) => {
console.info(e.isVisible.toString())
}
})
.position({ x: 100, y: 200 })
Button('custom popup')
.onClick(() => {
this.customPopup = !this.customPopup
})
.bindPopup(this.customPopup, {
builder: this.popupBuilder,
placement: Placement.Bottom,
maskColor: 0x33000000,
popupColor: Color.White,
enableArrow: true,
onStateChange: (e) => {
if (!e.isVisible) {
this.customPopup = false
}
}
})
.position({ x: 100, y: 350 })
}.width('100%').padding({ top: 5 })
}
}
\ No newline at end of file
...@@ -82,6 +82,12 @@ struct RefreshDrag { ...@@ -82,6 +82,12 @@ struct RefreshDrag {
}) })
.onStateChange((refreshStatus: RefreshStatus) => { .onStateChange((refreshStatus: RefreshStatus) => {
console.info('Refresh onStatueChange state is ' + refreshStatus) console.info('Refresh onStatueChange state is ' + refreshStatus)
if(refreshStatus === RefreshStatus.Drag){
console.info("refreshStatus RefreshStatus.Drag")
}
if(refreshStatus === RefreshStatus.Refresh){
console.info("refreshStatus RefreshStatus.Refresh")
}
try { try {
var backDataTwo = { var backDataTwo = {
data: { data: {
......
...@@ -15,7 +15,39 @@ ...@@ -15,7 +15,39 @@
export default { export default {
data: { data: {
title: "", appData: 'localData',
appVersion:'1.0',
},
onInit() {
this.appData = this.$app.$def.globalData.appData;
this.appVersion = this.$app.$def.globalData.appVersion;
},
invokeGlobalMethod() {
this.$app.$def.globalMethod();
},
getAppVersion() {
this.appVersion = this.$app.$def.globalData.appVersion;
},
onNewRequest(){
console.info("div onNewRequest ")
},
onStartContinuation() {
console.info('div onStartContinuation');
return true;
},
onRestoreData(data) {
console.info('div onRestoreData' + data);
return true;
},
onSaveData(data) {
console.info('div onSaveData');
return true;
},
onCompleteContinuation(result) {
console.info('onCompleteContinuation:' + result);
},
onConfigurationUpdated(configuration) {
console.info('ActsProcessManageJsTest onConfigurationUpdated:' + JSON.stringify(configuration));
}, },
functionTest1() { functionTest1() {
var div = this.$element('div1'); var div = this.$element('div1');
......
...@@ -32,7 +32,10 @@ export default { ...@@ -32,7 +32,10 @@ export default {
function2.setAttribute("type", "password") function2.setAttribute("type", "password")
}, },
functionTest3() { functionTest3() {
var elem = dom.createElement("button");
elem.setAttribute("value", "buttoncreateElement");
var testDiv = this.$element('testDiv');
testDiv.addChild(elem);
}, },
functionTest4() { functionTest4() {
var function2 = this.$element('function2'); var function2 = this.$element('function2');
......
...@@ -12,6 +12,8 @@ ...@@ -12,6 +12,8 @@
* See the License for the specific language governing permissions and * See the License for the specific language governing permissions and
* limitations under the License. * limitations under the License.
*/ */
import Ability from '@ohos.application.Ability'
import ConfigurationConstant from '@ohos.application.ConfigurationConstant'
export default { export default {
data: { data: {
......
# This file is automatically generated by DevEco Studio.
# Do not modify this file -- YOUR CHANGES WILL BE ERASED!
#
# This file should *NOT* be checked into Version Control Systems,
# as it contains information specific to your local configuration.
#
# For customization when using a Version Control System, please read the header note.
sdk.dir=D:/beta3Sdk
nodejs.dir=D:/software/DevEco Studio 3.0.0.900/tools/nodejs
npm.dir=D:/software/DevEco Studio 3.0.0.900/tools/nodejs
\ No newline at end of file
{
"lockfileVersion": 1
}
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册