PopupWindow基础实现

public class MainActivity extends Activity {

	private Button btn;
	private PopupWindow window;
	private EditText edit_text;
	private Button btn1;

	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.activity_main);
		
		btn = (Button) findViewById(R.id.btn);
		
		View view = View.inflate(MainActivity.this, R.layout.activity_main, null);
		//窗口布局转换成视图对象
		View contentView = View.inflate(MainActivity.this, R.layout.pop_layout, null);
		/**
		 * contentView :popup布局转换成的视图对象
		 * width:窗口显示的宽度
		 * height:窗口显示的高度
		 */
		window = new PopupWindow(contentView, LayoutParams.MATCH_PARENT, LayoutParams.WRAP_CONTENT);
		
		//如果想要设置点击外部窗口消失,,必须2个方法同时使用
		window.setBackgroundDrawable(new BitmapDrawable());//给窗口设置一个完全透明的背景图片//new ColorDrawable(0xc0c0c0c0)
		window.setOutsideTouchable(true);//设置窗口外部可以触摸
		
		//窗口里面的控件没有响应解决方案
		window.setFocusable(true);//设置窗口的焦点事件
		window.setTouchable(true);//设置窗口本身可以触摸
		
		//通过视图对象操控里面的控件
		edit_text = (EditText) contentView.findViewById(R.id.edit_text);
		btn1 = (Button) contentView.findViewById(R.id.btn1);
		
		btn1.setOnClickListener(new OnClickListener() {
			@Override
			public void onClick(View v) {
				Toast.makeText(MainActivity.this, edit_text.getText().toString(), 0).show();
				//一般执行完逻辑操作以后,,,窗口消失
				window.dismiss();
			}
		});
	}
	
	public void show_window(View view) {
		//window.showAsDropDown(btns);//显示在某控件的正左下方
		//window.showAsDropDown(btns, -150, 200);//显示在某控件的左下方(带偏移量)
		/**
		 * parent:父控件--->popupwindow相对于某个父控件的位置
		 * gravity:重力方向
		 * x:x轴的偏移量
		 * y:y轴的偏移量
		 */
		window.showAtLocation(view, Gravity.BOTTOM, 0, 0);
	}
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
SQLAlchemy 是一个 SQL 工具包和对象关系映射(ORM)库,用于 Python 编程语言。它提供了一个高级的 SQL 工具和对象关系映射工具,允许开发者以 Python 类和对象的形式操作数据库,而无需编写大量的 SQL 语句。SQLAlchemy 建立在 DBAPI 之上,支持多种数据库后端,如 SQLite, MySQL, PostgreSQL 等。 SQLAlchemy 的核心功能: 对象关系映射(ORM): SQLAlchemy 允许开发者使用 Python 类来表示数据库表,使用类的实例表示表中的行。 开发者可以定义类之间的关系(如一对多、多对多),SQLAlchemy 会自动处理这些关系在数据库中的映射。 通过 ORM,开发者可以像操作 Python 对象一样操作数据库,这大大简化了数据库操作的复杂性。 表达式语言: SQLAlchemy 提供了一个丰富的 SQL 表达式语言,允许开发者以 Python 表达式的方式编写复杂的 SQL 查询。 表达式语言提供了对 SQL 语句的灵活控制,同时保持了代码的可读性和可维护性。 数据库引擎和连接池: SQLAlchemy 支持多种数据库后端,并且为每种后端提供了对应的数据库引擎。 它还提供了连接池管理功能,以优化数据库连接的创建、使用和释放。 会话管理: SQLAlchemy 使用会话(Session)来管理对象的持久化状态。 会话提供了一个工作单元(unit of work)和身份映射(identity map)的概念,使得对象的状态管理和查询更加高效。 事件系统: SQLAlchemy 提供了一个事件系统,允许开发者在 ORM 的各个生命周期阶段插入自定义的钩子函数。 这使得开发者可以在对象加载、修改、删除等操作时执行额外的逻辑。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值