觉醒时刻
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
juexingshike/assets/Platform/th/ListItem.ts

189 lines
6.0 KiB

1 week ago
/******************************************
* @author kL <klk0@qq.com>
* @date 2019/6/6
* @doc Item组件.
*
* 1List组件使用..
* @end
******************************************/
const { ccclass, property, disallowMultiple, menu, executionOrder } = cc._decorator;
import List from './List';
enum SelectedType {
NONE = 0,
TOGGLE = 1,
SWITCH = 2,
}
@ccclass
@disallowMultiple()
@menu('自定义组件/List Item')
@executionOrder(-5001) //先于List
export default class ListItem extends cc.Component {
//图标
@property({ type: cc.Sprite, tooltip: CC_DEV && '图标' })
icon: cc.Sprite = null;
//标题
@property({ type: cc.Node, tooltip: CC_DEV && '标题' })
title: cc.Node = null;
//选择模式
@property({
type: cc.Enum(SelectedType),
tooltip: CC_DEV && '选择模式'
})
selectedMode: SelectedType = SelectedType.NONE;
//被选标志
@property({
type: cc.Node, tooltip: CC_DEV && '被选标识',
visible() { return this.selectedMode > SelectedType.NONE }
})
selectedFlag: cc.Node = null;
//被选择的SpriteFrame
@property({
type: cc.SpriteFrame, tooltip: CC_DEV && '被选择的SpriteFrame',
visible() { return this.selectedMode == SelectedType.SWITCH }
})
selectedSpriteFrame: cc.SpriteFrame = null;
//未被选择的SpriteFrame
_unselectedSpriteFrame: cc.SpriteFrame = null;
//自适应尺寸
@property({
tooltip: CC_DEV && '自适应尺寸(宽或高)',
})
adaptiveSize: boolean = false;
//选择
_selected: boolean = false;
set selected(val: boolean) {
this._selected = val;
if (!this.selectedFlag)
return;
switch (this.selectedMode) {
case SelectedType.TOGGLE:
this.selectedFlag.active = val;
break;
case SelectedType.SWITCH:
let sp: cc.Sprite = this.selectedFlag.getComponent(cc.Sprite);
if (sp) {
sp.spriteFrame = val ? this.selectedSpriteFrame : this._unselectedSpriteFrame;
}
break;
}
}
get selected() {
return this._selected;
}
//按钮组件
private _btnCom: any;
get btnCom() {
if (!this._btnCom)
this._btnCom = this.node.getComponent(cc.Button);
return this._btnCom;
}
//依赖的List组件
public list: List;
//是否已经注册过事件
private _eventReg = false;
//序列id
public listId: number;
onLoad() {
// //没有按钮组件的话,selectedFlag无效
// if (!this.btnCom)
// this.selectedMode == SelectedType.NONE;
//有选择模式时,保存相应的东西
if (this.selectedMode == SelectedType.SWITCH) {
let com: cc.Sprite = this.selectedFlag.getComponent(cc.Sprite);
this._unselectedSpriteFrame = com.spriteFrame;
}
}
onDestroy() {
this.node.off(cc.Node.EventType.SIZE_CHANGED, this._onSizeChange, this);
}
_registerEvent() {
if (!this._eventReg) {
if (this.btnCom && this.list.selectedMode > 0) {
this.btnCom.clickEvents.unshift(this.createEvt(this, 'onClickThis'));
}
if (this.adaptiveSize) {
this.node.on(cc.Node.EventType.SIZE_CHANGED, this._onSizeChange, this);
}
this._eventReg = true;
}
}
_onSizeChange() {
this.list._onItemAdaptive(this.node);
}
/**
*
* @param {cc.Component} component
* @param {string} handlerName
* @param {cc.Node} node nodecomponent.node
* @returns cc.Component.EventHandler
*/
createEvt(component: cc.Component, handlerName: string, node: cc.Node = null) {
if (!component.isValid)
return;//有些异步加载的,节点以及销毁了。
component['comName'] = component['comName'] || component.name.match(/\<(.*?)\>/g).pop().replace(/\<|>/g, '');
let evt = new cc.Component.EventHandler();
evt.target = node || component.node;
evt.component = component['comName'];
evt.handler = handlerName;
return evt;
}
showAni(aniType: number, callFunc: Function, del: boolean) {
let t: any = this;
let tween: cc.Tween;
switch (aniType) {
case 0: //向上消失
tween = cc.tween(t.node)
.to(.2, { scale: .7 })
.by(.3, { y: t.node.height * 2 });
break;
case 1: //向右消失
tween = cc.tween(t.node)
.to(.2, { scale: .7 })
.by(.3, { x: t.node.width * 2 });
break;
case 2: //向下消失
tween = cc.tween(t.node)
.to(.2, { scale: .7 })
.by(.3, { y: t.node.height * -2 });
break;
case 3: //向左消失
tween = cc.tween(t.node)
.to(.2, { scale: .7 })
.by(.3, { x: t.node.width * -2 });
break;
default: //默认:缩小消失
tween = cc.tween(t.node)
.to(.3, { scale: .1 });
break;
}
if (callFunc || del) {
tween.call(() => {
if (del) {
t.list._delSingleItem(t.node);
for (let n: number = t.list.displayData.length - 1; n >= 0; n--) {
if (t.list.displayData[n].id == t.listId) {
t.list.displayData.splice(n, 1);
break;
}
}
}
callFunc();
});
}
tween.start();
}
onClickThis() {
this.list.selectedId = this.listId;
}
}